- 1.2 快速入门
- 1.3 集成第三方应用
- 1.4 线程安全的 Map
- 1.5 Bee Watch
- 1.6 开发团队
- 1.7 开发案例
- 1.8 API自动化文档
- 1.9 进程内监控
- 1.10 beego 高级编程
- 1.11 第三方库
- 1.12 Apache 配置
- 1.13 独立部署
- 1.14 nginx 部署
- 1.15 发行部署
- 1.16 Supervisord
- 1.17 在线聊天室
- 1.18 示例程序
- 1.19 短域名服务
- 1.20 Todo 列表
- 1.21 bee 工具简介
- 1.22 beego 的安装
- 1.23 为 beego 做贡献
- 1.24 beego 简介
- 1.26 升级指南
- 1.27 模块介绍
- 1.28 缓存模块
- 1.29 配置文件解析
- 1.30 上下文模块
- 1.31 热升级是什么?
- 1.32 客户端请求
- 1.33 国际化介绍
- 1.34 日志处理
- 1.35 特别注意
- 1.36 核心工具模块
- 1.37 beego 的 MVC 架构介绍
- 1.39 参数配置
- 1.40 控制器介绍
- 1.41 错误处理
- 1.43 flash 数据
- 1.44 JSON、XML、JSONP
- 1.45 日志处理
- 1.46 获取参数
- 1.47 路由设置
- 1.48 session 控制
- 1.49 URL 构建
- 1.51 跨站请求伪造
- 1.53 命令模式
- 1.54 Custom Fields
- 1.55 FAQ
- 1.56 模型定义
- 1.57 对象的 CRUD 操作
- 1.58 ORM 使用方法
- 1.59 模型(Models)- beego ORM
- 1.60 高级查询
- 1.61 构造查询
- 1.62 使用SQL语句进行查询
- 1.63 ORM Test
- 1.64 事务处理
- 1.66 分页处理
- 1.67 静态文件
- 1.68 模板函数
- 1.69 beego 模板语法指南
- 1.70 模板处理
- 1.71 快速入门
- 1.72 controller 逻辑
- 1.73 model 分析
- 1.74 创建项目
- 1.75 项目路由设置
- 1.76 静态文件处理
- 1.77 View 编写
- 1.80 分页
- 1.81 FAQ
- 1.50 表单验证
- 1.42 过滤器
文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
1.28 缓存模块
beego 的 cache 模块是用来做数据缓存的,设计思路来自于 database/sql
,目前支持 file、memcache、memory 和 redis 四种引擎,安装方式如下:
go get github.com/astaxie/beego/cache
如果你使用memcache 或者 redis 驱动就需要手工安装引入包
go get -u github.com/astaxie/beego/cache/memcache
而且需要在使用的地方引入包
import _ "github.com/astaxie/beego/cache/memcache"
使用入门
首先引入包:
import (
"github.com/astaxie/beego/cache"
)
然后初始化一个全局变量对象:
bm, err := cache.NewCache("memory", `{"interval":60}`)
然后我们就可以使用bm增删改缓存:
bm.Put("astaxie", 1, 10*time.Second)
bm.Get("astaxie")
bm.IsExist("astaxie")
bm.Delete("astaxie")
引擎设置
目前支持四种不同的引擎,接下来分别介绍这四种引擎如何设置:
memory
配置信息如下所示,配置的信息表示 GC 的时间,表示每隔 60s 会进行一次过期清理:
{"interval":60}
file
配置信息如下所示,配置
CachePath
表示缓存的文件目录,FileSuffix
表示文件后缀,DirectoryLevel
表示目录层级,EmbedExpiry
表示过期设置{"CachePath":"./cache","FileSuffix":".cache","DirectoryLevel":"2","EmbedExpiry":"120"}
redis
配置信息如下所示,redis 采用了库 redigo:
{"key":"collectionName","conn":":6039","dbNum":"0","password":"thePassWord"}
- key: Redis collection 的名称
- conn: Redis 连接信息
- dbNum: 连接 Redis 时的 DB 编号. 默认是0.
- password: 用于连接有密码的 Redis 服务器.
memcache
配置信息如下所示,memcache 采用了 vitess的库,表示 memcache 的连接地址:
{"conn":"127.0.0.1:11211"}
开发自己的引擎
cache 模块采用了接口的方式实现,因此用户可以很方便的实现接口,然后注册就可以实现自己的 Cache 引擎:
type Cache interface {
Get(key string) interface{}
GetMulti(keys []string) []interface{}
Put(key string, val interface{}, timeout time.Duration) error
Delete(key string) error
Incr(key string) error
Decr(key string) error
IsExist(key string) bool
ClearAll() error
StartAndGC(config string) error
}
用户开发完毕在最后写类似这样的:
func init() {
Register("myowncache", NewOwnCache())
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论