Redis存储

文件存储的方式在单节点的场景下非常不错,但是涉及到对应用进行多节点部署的场景下,各个节点的Session无法共享,因此需要将Session存储单独剥离出来管理,Redis服务器是比较常见的一个选择。

gsessionRedis存储使用StorageRedis对象实现,与文件存储比较类似,为了提高执行效率,也是采用了内存+Redis的方式。与文件存储唯一不同的是,在每一次请求中如果需要对Session进行操作时,将会从Redis中拉取一次最新的Session数据(而文件存储只会在Session不存在时读取一次文件)。

使用示例

https://github.com/gogf/gf/blob/master/.example/os/gsession/storage-redis/redis.go

package main

import (
    "github.com/gogf/gf/frame/g"
    "github.com/gogf/gf/net/ghttp"
    "github.com/gogf/gf/os/gsession"
    "github.com/gogf/gf/os/gtime"
    "time"
)

func main() {
    s := g.Server()
    s.SetConfigWithMap(g.Map{
        "SessionMaxAge":  time.Minute,
        "SessionStorage": gsession.NewStorageRedis(g.Redis()),
    })
    s.Group("/", func(group *ghttp.RouterGroup) {
        group.ALL("/set", func(r *ghttp.Request) {
            r.Session.Set("time", gtime.Timestamp())
            r.Response.Write("ok")
        })
        group.ALL("/get", func(r *ghttp.Request) {
            r.Response.Write(r.Session.Map())
        })
        group.ALL("/del", func(r *ghttp.Request) {
            r.Session.Clear()
            r.Response.Write("ok")
        })
    })
    s.SetPort(8199)
    s.Run()
}

在该实例中,为了方便观察过期失效,我们将Session的过期时间设置为1分钟。执行后,

  1. 首先,访问 http://127.0.0.1:8199/set 设置一个Session变量;
  2. 随后,访问 http://127.0.0.1:8199/get 可以看到该Session变量已经设置并成功获取;
  3. 接着,我们停止程序,并重新启动,再次访问 http://127.0.0.1:8199/get ,可以看到Session变量已经从Redis存储中恢复;如果我们手动修改Redis中的对应键值数据,页面刷新时也会读取到最新的值;
  4. 等待1分钟后,再次访问 http://127.0.0.1:8199/get 可以看到已经无法获取该Session,因为该Session已经过期;
最后编辑: kuteng  文档更新时间: 2021-01-09 18:11   作者:kuteng