基于高速缓存redis的session,可以在多个平台下共享
发布于 2年前 作者 qq32245163 1803 次浏览

1.安装 npm install reids-sessions 2.方法/属性 1.每一个session都属于一个app 2.create : 一个session通过接受一个appName,唯一id被创建,返回值是一个token 3.get: 通过appName 与 token可以查询一个session 4.set: 在session上附加数据 5.kill: 通过appName + token可以杀掉一个session 6.killall: 通过appName可以杀掉所有session 3.附加方法 1.activity: 获取最近n秒内的活动session数量 2.soid: 获取一个id的所有session 3.killsoid: 杀死一个id的所有session 4.TODO: 获取n秒内被激活的所有session数组 5.Automatic 清除所有旧session 4.性能 测试环境描述:硬件:2011年的mac,部署在同一台机器的redis 测试命令:npm test 1.创建1000个session在170ms以内 2.获取这1000个session并校验在155ms内 3.移除这1000个session 18ms 5.在nodejs内使用

//初始化redis-session
RedisSession = require("redis-session");
var rs = new RedisSession(
    {    
        //*optional* Default:6379,redis prot
        port:6379,

        //*optional* Defalut:127.0.0.1, redis host
        host:127.0.0.1,

        //*optional* Default:"rs", 这个模块的redis key前缀
        namespace:"rs",
    
        //*optional* Default:600,擦除过期session的时间间隔,最少是10
        wipe:600
    }
);

//应用程序名
var appName="myapp";

//创建一个session
rs.create(
{
    app:appName,
    
    //用户唯一id
    id:"user01",
    
    //用户ip
    ip:"192.168.22.58",
    
    //*optional* Default:7200 过期时间
    ttl:3600
},
function(err,resp)
{
    // resp 应该是类似这样
    // {token: "r30kKwv3sA6ExrJ9OmLSm4Wo3nt9MQA1yG94wn6ByFbNrVWhcwAyOM7Zhfxqh8fe"}
}
);

//在session附加数据
rs.set(
{    
    app:appName,
    token:"r30kKwv3sA6ExrJ9OmLSm4Wo3nt9MQA1yG94wn6ByFbNrVWhcwAyOM7Zhfxqh8fe",
    d:{
        "msg1":"asd",
        "msg2":"asd2"
    }
},function(err,resp)
{
    /*
    resp contains the session with the new values:

    {  
    "id":"user01",
    "r": 1,
    "w": 2,
    "idle": 1,
    "ttl": 3600, 
    "d":
    {
        "msg1":"asd",
        "msg2":"asd2"
    }
    }
    */ 
}
);

//通过一个token获取session
rs.get(
{
    app:appName,
    token:"r30kKwv3sA6ExrJ9OmLSm4Wo3nt9MQA1yG94wn6ByFbNrVWhcwAyOM7Zhfxqh8fe",
    funtion(err,resp){
        /*
        resp contains the session:

        {  
            "id":"user01",
            "r": 1,  // The number of reads on this token
            "w": 1,  // The number of writes on this token
            "idle": 21,  // The idle time in seconds.
            "ttl": 7200, // Timeout after 7200 idle time
            "d":
            {
                "msg1":"asd",
                "msg2":"asd2"
            }
        }

        */        
    }
}
);

//设置/更新/删除
rs.set(
{
    app:rsapp,
    token:"r30kKwv3sA6ExrJ9OmLSm4Wo3nt9MQA1yG94wn6ByFbNrVWhcwAyOM7Zhfxqh8fe",
    d:{    
        //删除一个属性,设置为null即可
        "msg1":null,
        //设置一个新属性
        "msg3":123,    
    }
}    
);


//通过appName + token可以杀掉一个session
rs.kill({
    app: rsapp,
    token: "r30kKwv3sA6ExrJ9OmLSm4Wo3nt9MQA1yG94wn6ByFbNrVWhcwAyOM7Zhfxqh8fe"},
    function(err, resp) {
    /*
    resp contains the result:

    {kill: 1}
    */
    }
});

//获取活动session
rs.activity({
    app: rsapp,

    //时间区间
    dt: 600},
    function(err, resp) {
    /*
    resp contains the activity:

    {activity: 12}
    */ 
    } 
});


//获取一个用户的所有session
rs.soid({
    app: rsapp,
    id: "bulkuser_999"},
    function(err, resp) {
    /*
    resp contains the sessions:

    { sessions: 
    [ 
        {
            id: 'bulkuser_999',
            r: 1,
            w: 1,
            ttl: 30,
            idle: 0,
            ip: '127.0.0.2' 
        },
        { 
            id: 'bulkuser_999',
            r: 1,
            w: 1,
            ttl: 7200,
            idle: 0,
            ip: '127.0.0.1' 
        }
    ] 
    }
    */  
});

//杀死某用户的所有session
rs.killsoid({app: appName, id: 'bulkuser_999'},
  function(err, resp) {
    /*
    resp contains the result:

    {kill: 2} // The amount of sessions that were killed
    */  
  });

//杀死一个app内的所有session
rs.killall({app: appName},
  function(err, resp) {
    /*
    resp contains the result:

    {kill: 12} // The amount of sessions that were killed
    */  
  });
回到顶部