Redis KeyValue Storage
文件存储的方式在单节点的场景下非常不错,但是涉及到对应用进行多节点部署的场景下,各个节点的Session
无法共享,因此需要将Session
存储单独剥离出来管理,Redis
服务器是比较常见的一个选择。
gsession
的Redis
存储使用StorageRedis
对象实现,与文件存储比较类似,为了提高执行效率,也是采用了内存+Redis
的方式。与文件存储唯一不同的是,在每一次请求中如果需要对Session
进行操作时,将会从Redis
中拉取一次最新的Session
数据(而文件存储只会在Session
不存在时读取一次文件)。在每一次请求结束之后,将全量的Session
数据通过JSON
序列化之后通过KeyValue
方式更新到Redis
服务中。
使用示例
在该实例中,为了方便观察过期失效,我们将Session
的过期时间设置为1分钟
。执行后,
- 首先,访问 http://127.0.0.1:8199/set 设置一个
Session
变量; - 随后,访问 http://127.0.0.1:8199/get 可以看到该
Session
变量已经设置并成功获取; - 接着,我们停止程序,并重新启动,再次访问 http://127.0.0.1:8199/get ,可以看到
Session
变量已经从Redis
存储中恢复;如果我们手动修改Redis
中的对应键值数据,页面刷新时也会读取到最新的值; - 等待1分钟后,再次访问 http://127.0.0.1:8199/get 可以看到已经无法获取该
Session
,因为该Session
已经过期;
5 Comments
金小勇
session采用Redis-keyValue可以在配置文件中设置吗? 还是必须在代码中s.SetSessionStorage(gsession.NewStorageRedis(g.Redis()))
石小志
redis的配置就是在config.yaml里
马江红
能贴个config.yaml 中的配置实例吗?
热情sily
redis配置在前面。 Redis-配置管理
goodhunting
你没发现即便存在config.yaml,按照你的代码,会报错no configuration found for creating Redis client吗?