在默认情况下,ghttp.Server
的Session
存储使用了内存+文件的方式,使用StorageFile
对象实现。具体原理为:
Session
的数据操作完全基于内存;
gcache
进程缓存模块控制数据过期;
Session
数据;
Session
被标记为dirty
时(数据有更新)才会执行Session
序列化并执行文件持久化存储;
Session
不存在时,才会从文件存储中反序列化恢复Session
数据到内存中,降低IO调用;
json.Marshal
/UnMarshal
方法;从原理可知,当Session
为读多写少的场景中,Session
的数据操作非常高效。
有个注意的细节,由于文件存储涉及到文件操作,为便于降低IO
开销并提高Session
操作性能,并不是每一次Session
请求结束后都会立即刷新对应Session
的TTL
时间。而只有当涉及到更新操作(被标记为dirty
)时才会立即刷新其TTL
;针对于读取请求,将会每隔一分钟更新前一分钟内读取操作对应的Session
文件TTL
时间,以便于Session
自动续活。
package main
import (
"github.com/gogf/gf/v2/frame/g"
"github.com/gogf/gf/v2/net/ghttp"
"github.com/gogf/gf/v2/os/gtime"
"time"
)
func main() {
s := g.Server()
s.SetConfigWithMap(g.Map{
"SessionMaxAge": time.Minute,
})
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分钟。执行后,
Session
变量;
Session
变量已经设置并成功获取;
Session
变量已经从文件存储中恢复;
Session
,因为该Session
已经过期;额外特性主要的教程教程 - 用户指南应该足以让你了解FastAPI的所有主要特性。你会在接下来的章节中了解到其他的选项、配置以及额...
Django 提供了有关返回 HTTP 错误代码的帮助。HttpResponse 的子类除了200外,还有很多常见的 HTTP 状态代码。返回这些子类...
Django 自动转换视图引发的异常,或者带有错误状态代码的特定 HTTP 响应内的中间件引发的异常。某些异常( Certain exceptions...
我们已经简单的描述过了HTML 表单,但是一个HTMLform只是其所需的一部分。在网络应用的上下文中,“表单”可能指的是那个HTM...
class django.utils.deprecation.MiddlewareMixinDjango 提供了 django.utils.deprecation.MiddlewareMixin 来方便创建同时...