gfast 后端开发-数据缓存

2022-03-29 16:34 更新

gfast 的数据缓存是使用了gf框架的 gcache 模块,进行了轻量的service封装,主要是添加了缓存标签支持,可以对同类型的数据定义一个标签,清除缓存时可以按照标签分类清除。

使用方式

例如用户权限的缓存,当缓存了用户权限的时候,我们在后台又修改过角色信息(角色重新授权),修改了用户信息(用户重新设置了所属角色)后就需要清空旧的缓存生成新的缓存,就可以使用缓存标签将角色和用户的增删改设置同一个标签,在清除缓存的时候只清理权限相关的标签,不影响其他模块缓存数据。

示例代码:

import "gfast/app/common/service"
//获取所有菜单并缓存
func (s *rule) GetMenuList() (list []*model.SysAuthRuleInfoRes, err error) {
    cache := service.Cache.New()
    //从缓存获取
    iList := cache.Get(global.SysAuthMenu)
    if iList != nil {
        err = gconv.Struct(iList, &list)
        return
    }
    //从数据库获取
    list, err = dao.SysAuthRule.GetMenuList()
    if err != nil || list == nil {
        return
    }
    //缓存菜单
    cache.Set(global.SysAuthMenu, list, 0, global.SysAuthTag)
    return
}
// GetRoleList 获取角色列表
func (s *sysRole) GetRoleList() (list []*model.SysRole, err error) {
    cache := service.Cache.New()
    //从缓存获取
    iList := cache.Get(global.SysRole)
    if iList != nil {
        err = gconv.Struct(iList, &list)
        return
    }
    //从数据库获取
    list, err = dao.SysRole.Order(dao.SysRole.Columns.ListOrder + " asc," + dao.SysRole.Columns.Id + " asc").All()
    if err != nil {
        g.Log().Error(err)
        err = gerror.New("获取角色数据失败")
    }
    //缓存数据
    cache.Set(global.SysRole, list, 0, global.SysAuthTag)
    iList = cache.Get(global.SysRole)
    return
}

可以看到上面我们都使用同一个缓存标签​global.SysAuthTag​ 这样当我们修改了用户信息,或者角色,或者菜单信息后,就不用依次去根据缓存键去删除缓存的菜单、角色等信息,只要通过这个标签就能一次性更新这几个缓存数据。

//当修改了角色后通过缓存标签删除和权限相关的缓存数据
func (s *sysRole) EditRolePost(m map[string]interface{}, id int) error {
    tx, err := g.DB("default").Begin() //开启事务
    if err != nil {
        return err
    }
    err = s.EditRole(tx, m)
    if err != nil {
        tx.Rollback()
        return err
    }
    err = s.EditRoleRule(m["menuIds"], int64(id))
    if err != nil {
        tx.Rollback() //回滚
        return err
    }
    tx.Commit()
    //清除TAG缓存
    service.Cache.New().RemoveByTag(global.SysAuthTag)
    return nil
}

同时对应的缓存标签为了好维护,可以设置对应的常量来区分:

package global

const (
    //缓存前缀
    cachePrefix = "cache_"  //缓存前缀可以用来区分在同一台服务器环境部署多个系统缓存数据(防止缓存混淆)

    // SysAuthMenu 缓存菜单KEY
    SysAuthMenu = cachePrefix + "sysAuthMenu"
    // SysDict 字典缓存菜单KEY
    SysDict = cachePrefix + "sysDict"
    // SysRole 角色缓存key
    SysRole = cachePrefix + "sysRole"
    // SysWebSet 站点配置缓存key
    SysWebSet = cachePrefix + "sysWebSet"

    // SysAuthTag 权限缓存TAG标签
    SysAuthTag = cachePrefix + "sysAuthTag"
    // SysDictTag 字典缓存标签
    SysDictTag = cachePrefix + "sysDictTag"
    // SysConfigTag 系统参数配置
    SysConfigTag = cachePrefix + "sysConfigTag"
)

m_86afdcf6c563be6d43d8c873845717ae_r

数据缓存配置

# Redis数据库配置
[redis]
    open = true #是否开启 redis 缓存 若不开启使用gchache缓存方式
    default = "127.0.0.1:6379,9?idleTimeout=600"


以上内容是否对您有帮助:
在线笔记
App下载
App下载

扫描二维码

下载编程狮App

公众号
微信公众号

编程狮公众号