RedisHashTableStorage

RedisKeyValueStorage不同的地方在于RedisHashTableStorage底层使用HashTable存储Session数据,每一次对Session的增删查改都是直接访问Redis服务实现(单条数据项操作),不存在像RedisKeyValueStorage那样初始化全量拉取一次,请求结束后如有修改再全量更新到Redis服务的操作。

使用示例

  1. package main
  2. import (
  3. "github.com/gogf/gf/v2/frame/g"
  4. "github.com/gogf/gf/v2/net/ghttp"
  5. "github.com/gogf/gf/v2/os/gsession"
  6. "github.com/gogf/gf/v2/os/gtime"
  7. "time"
  8. )
  9. func main() {
  10. s := g.Server()
  11. s.SetConfigWithMap(g.Map{
  12. "SessionMaxAge": time.Minute,
  13. "SessionStorage": gsession.NewStorageRedisHashTable(g.Redis()),
  14. })
  15. s.Group("/", func(group *ghttp.RouterGroup) {
  16. group.ALL("/set", func(r *ghttp.Request) {
  17. r.Session.Set("time", gtime.Timestamp())
  18. r.Response.Write("ok")
  19. })
  20. group.ALL("/get", func(r *ghttp.Request) {
  21. r.Response.Write(r.Session.Map())
  22. })
  23. group.ALL("/del", func(r *ghttp.Request) {
  24. r.Session.Clear()
  25. r.Response.Write("ok")
  26. })
  27. })
  28. s.SetPort(8199)
  29. s.Run()
  30. }

在该实例中,为了方便观察过期失效,我们将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已经过期;