Revel 提供了一个服务器端、临时的、低延迟存储的缓存库。对于频繁访问数据库中缓慢变化的数据,使用缓存一个很好的方法,并且它也可以用于实现用户session (如果基于cookie的session不足).
参考 缓存接口
缓存有三种过期时间:
time.Duration
,指定一个过期时间。cache.DEFAULT
, 默认过期时间(1小时)。cache.FOREVER
, 永不过期。重要提示:调用者不能依赖于存在于缓存中内容,因为数据是不持久保存,重新启动后,会清除所有缓存数据。
缓存读写接口自动为调用者序列化任何类型的的值。有以下几种方式:
[]byte
类型, 数据保持不变。encoding/gob
进行编码。缓存通过以下几种方式进行配置:
在app.conf
中配置缓存:
cache.expires
- 一个字符串,time.ParseDuration
类型,指定一个过期时间 (默认1小时)cache.memcached
-一个布尔值,是否开启memcached缓存 (默认不开启)cache.redis
-一个布尔值,是否开启redis缓存 (默认不开启)cache.hosts
- 缓存的主机列表(多个主机使用逗号分隔),cache.memcached
开启后有效。下面是常见操作的一个例子。请注意,如果不需要调用的结果来处理请求,调用者可以在新的goroutine调用缓存操作。
import (
"github.com/revel/revel"
"github.com/revel/revel/cache"
)
func (c App) ShowProduct(id string) revel.Result {
var product Product
if err := cache.Get("product_"+id, &product); err != nil {
product = loadProduct(id)
go cache.Set("product_"+id, product, 30*time.Minute)
}
return c.Render(product)
}
func (c App) AddProduct(name string, price int) revel.Result {
product := NewProduct(name, price)
product.Save()
return c.Redirect("/products/%d", product.id)
}
func (c App) EditProduct(id, name string, price int) revel.Result {
product := loadProduct(id)
product.name = name
product.price = price
go cache.Set("product_"+id, product, 30*time.Minute)
return c.Redirect("/products/%d", id)
}
func (c App) DeleteProduct(id string) revel.Result {
product := loadProduct(id)
product.Delete()
go cache.Delete("product_"+id)
return c.Redirect("/products")
}
缓存有一个全球性的key空间 - 使用它作为一个session存储,调用方应采用session UUID的优点,如下图所示:
cache.Set(c.Session.Id(), products)
// 然后在随后的请求中使用它
err := cache.Get(c.Session.Id(), &products)
Revel 支持四类日志信息:TRACE - 调试信息INFO - 一般信息WARN - 警告信息ERROR - 错误信息下面是在Revel中使用日志的例子:now :...
静态文件服务配置默认情况下,gfServer关闭了静态文件服务的功能,如果开发者配置了静态文件目录,那么静态文件服务将会自动...
使用goframe框架进行websocket开发相当简单。我们以下通过实现一个简单的echo服务器来演示goframe框架的webso...
获取Query参数在Gin框架中,可以通过Query来获取URL中?后面所携带的参数。例如/name=adminpwd=123456。获取方法如下package...
func main() {r := gin.Default()// gin.H 是 map[string]interface{} 的一种快捷方式r.GET("/someJSON", func(c *gin.Context) ...
使用Response参数您可以Response在路径操作函数中声明类型参数。然后您可以在该时间响应对象中设置 cookie。from fastapi import...
您可以在JSON模式中定义额外的信息。一个常见的用例是添加一个将在文档中显示的example。有几种方法可以声明额外的 JSON 模式信...
FastAPI 支持同时使用File和Form定义文件和表单字段。说明接收上传文件或表单数据,要预先安装python-multipart。例如,pip inst...
通过向规则参数添加变量部分,可以动态构建URL。此变量部分标记为variable-name。它作为关键字参数传递给与规则相关联的函数。在...