• Cache
    • 过期时间
    • 序列化
    • 实现
    • 配置
    • 例如
    • Session 用法

    Cache

    Revel 提供了一个服务器端、临时的、低延迟存储的缓存库。对于频繁访问数据库中缓慢变化的数据,使用缓存一个很好的方法,并且它也可以用于实现用户session (如果基于cookie的session不足).

    参考 缓存接口

    过期时间

    缓存有三种过期时间:

    • time.Duration,指定一个过期时间。
    • cache.DEFAULT, 默认过期时间(1小时)。
    • cache.FOREVER, 永不过期。
      重要提示:调用者不能依赖于存在于缓存中内容,因为数据是不持久保存,重新启动后,会清除所有缓存数据。

    序列化

    缓存读写接口自动为调用者序列化任何类型的的值。有以下几种方式:

    • 如果是 []byte类型, 数据保持不变。
    • 如果是 整数类型, 数据被保存为 ASCII。
    • 其他类型,使用 encoding/gob进行编码。

    实现

    缓存通过以下几种方式进行配置:

    • 分布式memcached 主机缓存
    • 单独 redis 主机缓存
    • 本地内存缓存

    配置

    app.conf中配置缓存:

    • cache.expires - 一个字符串,time.ParseDuration 类型,指定一个过期时间 (默认1小时)
    • cache.memcached -一个布尔值,是否开启memcached缓存 (默认不开启)
    • cache.redis -一个布尔值,是否开启redis缓存 (默认不开启)
    • cache.hosts - 缓存的主机列表(多个主机使用逗号分隔),cache.memcached开启后有效。

    例如

    下面是常见操作的一个例子。请注意,如果不需要调用的结果来处理请求,调用者可以在新的goroutine调用缓存操作。

    1. import (
    2. "github.com/revel/revel"
    3. "github.com/revel/revel/cache"
    4. )
    5.  
    6. func (c App) ShowProduct(id string) revel.Result {
    7. var product Product
    8. if err := cache.Get("product_"+id, &product); err != nil {
    9. product = loadProduct(id)
    10. go cache.Set("product_"+id, product, 30*time.Minute)
    11. }
    12. return c.Render(product)
    13. }
    14.  
    15. func (c App) AddProduct(name string, price int) revel.Result {
    16. product := NewProduct(name, price)
    17. product.Save()
    18. return c.Redirect("/products/%d", product.id)
    19. }
    20.  
    21. func (c App) EditProduct(id, name string, price int) revel.Result {
    22. product := loadProduct(id)
    23. product.name = name
    24. product.price = price
    25. go cache.Set("product_"+id, product, 30*time.Minute)
    26. return c.Redirect("/products/%d", id)
    27. }
    28.  
    29. func (c App) DeleteProduct(id string) revel.Result {
    30. product := loadProduct(id)
    31. product.Delete()
    32. go cache.Delete("product_"+id)
    33. return c.Redirect("/products")
    34. }

    Session 用法

    缓存有一个全球性的key空间 - 使用它作为一个session存储,调用方应采用session UUID的优点,如下图所示:

    1. cache.Set(c.Session.Id(), products)
    2.  
    3. // 然后在随后的请求中使用它
    4. err := cache.Get(c.Session.Id(), &products)