当前位置: 首页 > news >正文

Gone框架介绍25 - Redis模块参考文档

文章目录

  • Redis 参考文档
    • 配置项
    • import 和 bury
    • 使用分布是缓存 redis.Cache
      • 接口定义
      • 使用示例
    • 使用分布式锁 redis.Locker
      • 接口定义
      • 使用示例
    • 操作Key,使用 redis.Key
      • 接口定义
    • 使用 Provider 注入 redis 接口
      • 使用示例
    • 直接使用redis连接池
      • 接口定义
      • 使用示例

Redis 参考文档

本文件介绍如何利用Gone内置模块,操作redis,包括使用分布式缓存、分布式锁、操作键值、操作Hash等内容,是对Gone框架介绍18 - redis 分布式缓存 和 分布式锁 的补充和完善。

已经收录到官方文档:https://goner.fun/zh/references/redis.html

配置项

  • redis.max-idle:最大空闲链接数,不配置默认为2
  • redis.max-active:最大活跃链接数,不配置默认为10
  • redis.db:使用的db,不配置默认为0
  • redis.cache.prefix:key前缀,如果设置了,对redis的增删改查都会拼接该前缀,拼接方式KaTeX parse error: Expected 'EOF', got '#' at position 9: {prefix}#̲{key};默认为空

import 和 bury

  • import
import "github.com/gone-io/gone/goner/redis"
  • bury
//使用 goner.RedisPriest 函数,将 redis 相关的Goner 埋葬到 Cemetery 中
_ = goner.RedisPriest(cemetery)

使用分布是缓存 redis.Cache

接口定义

type Cache interface {//设置缓存,Set的别名Put(key string, value any, ttl ...time.Duration) error//设置缓存Set(key string, value any, ttl ...time.Duration) error//获取缓存Get(key string, value any) error//删除缓存Remove(key string) (err error)//根据模式获取缓存的keyKeys(pattern string) ([]string, error)//获取当前Cache使用的前缀Prefix() string
}

使用示例

type redisUser struct {gone.Flagcache  redis.Cache  `gone:"gone-redis-cache"`
}func (r *redisUser) UseCache() {key := "gone-address"value := "https://github.com/gone-io/gone"//设置缓存err := r.cache.Put(key,            //第一个参数为 缓存的key,类型为 `string`value,          // 第二参数为 需要缓存的值,类型为any,可以是任意类型;传入的值会被编码为 `[]byte` 发往redis10*time.Second, // 第三个参数为 过期时间,类型为 `time.Duration`;省略,表示不设置过期时间)if err != nil {fmt.Printf("err:%v", err)return}//获取缓存var getValue stringerr = r.cache.Get(key,       //第一个参数为 缓存的key,类型为 `string`&getValue, //第二参数为指针,接收获取缓存的值,类型为any,可以是任意类型;从redis获取的值会被解码为传入的指针类型)if err != nil {fmt.Printf("err:%v", err)return}fmt.Printf("getValue:%v", getValue)
}

使用分布式锁 redis.Locker

接口定义

// Locker redis 分布式缓存
type Locker interface {//TryLock 尝试将key锁定一段时间,成功返回一个解锁函数,失败返回错误TryLock(key string, ttl time.Duration) (unlock Unlock, err error)//LockAndDo 尝试获取锁,并执行fn函数,函数未执行完自动续期,函数执行完后自动释放锁LockAndDo(key string, fn func(), lockTime, checkPeriod time.Duration) (err error)
}

使用示例

type redisUser struct {gone.Flaglocker redis.Locker `gone:"gone-redis-locker"`
}func (r *redisUser) UseLock() {lockKey := "gone-lock-key"//尝试获取锁 并 锁定一段时间//返回的第一个参数为一个解锁的函数unlock, err := r.locker.TryLock(lockKey,        //第一个参数为 锁的key,类型为 `string`10*time.Second, //第二参数为 锁的过期时间,类型为 `time.Duration`)if err != nil {fmt.Printf("err:%v", err)return}//操作完后,需要解锁defer unlock()//获取锁成功后,可以进行业务操作//todo
}func (r *redisUser) LockFunc() {lockKey := "gone-lock-key"err := r.locker.LockAndDo(lockKey, //第一个参数为 锁的key,类型为 `string`func() { //第二个参数为 需要执行的函数,类型为 `func()`,代表一个操作//获取锁成功后,可以进行业务操作//todoprintln("do some options")},100*time.Second, //第三个参数为 锁的过期时间,类型为 `time.Duration`;第一次加锁和后续锁续期都将使用该值5*time.Second,   //第四个参数为 锁续期的间隔时间,类型为 `time.Duration`;周期性检查所是否将过期,如果在下个周期内会过期则对锁续期)if err != nil {fmt.Printf("err:%v", err)}
}

操作Key,使用 redis.Key

接口定义

type Key interface {//Expire 给key设置一段时间后过期Expire(key string, ttl time.Duration) error//ExpireAt 设置key在某个时间点过期ExpireAt(key string, time time.Time) error//Ttl 获取key的过期时间Ttl(key string) (time.Duration, error)//Del 删除一个keyDel(key string) (err error)//Incr 使key自增一个量Incr(field string, increment int64) (int64, error)//Keys 根据模式获取缓存的keyKeys(pattern string) ([]string, error)//Prefix 获取redis配置的key前缀Prefix() string
}

使用 Provider 注入 redis 接口

通过标签 gone:"gone-redis-provider,${key}使用redis Provider 创建一个接口给注入属性。支持注入的接口包括前面的redis.Cacheredis.Lockerredis.Key;另外还支持注入 redis.Hash接口,用于操作redis hash。

Hash接口定义

type Hash interface {//设置hash字段Set(field string, v interface{}) (err error)//获取hash字段Get(field string, v interface{}) error//删除hash字段Del(field string) error//扫描hash字段Scan(func(field string, v []byte)) error//hash字段自增Incr(field string, increment int64) (int64, error)
}

使用示例

  1. 使用 Provider 创建一个redis.Cache接口,该缓存接口的前缀将使用配置中的前缀拼接${key}得到新的前缀,可以用于有按模块隔离的场景。
    如果配置了redis.cache.prefix=member,那么下面注入的redis.Cache接口将使用的前缀为:member#points;执行操作r.redis.Set("use-110", "value")操作,保存到redis中的key为:member#points#use-110
type redisUser struct {gone.Flagredis redis.Cache `gone:"gone-redis-provider,points"`
}func (r *redisUser) UseProvidedCache() {r.redis.Set("use-110", "value")
}

redis.Locker 和 redis.Key 接口的注入 与 redis.Cache 接口类似。

  1. 从配置文件中读取一个值作为前缀来拼接
    如果配置了redis.cache.prefix=orderapp.order.sell.redis-prefix=sell,下面注入的接口将使用的前缀为:order#sell;执行操作r.redis.Set("use-110", "value")操作,保存到redis中的key为:order#sell#use-110
type redisUser struct {gone.Flagredis redis.Cache `gone:"gone-redis-provider,config=app.order.sell.redis-prefix"` //读取配置中的 app.order.sell.redis-prefix 的值用于创建 redis.Cache
}func (r *redisUser) UseProvidedCache() {r.redis.Set("use-110", "value")
}

redis.Locker 和 redis.Key 接口的注入 与 redis.Cache 接口类似。

  1. 使用 redis.Hash 接口
    在注入redis.Hash接口时,key不在为前缀,而就是当前redis要操作的key。

如果配置了redis.cache.prefix=user,下面代码中的r.hash.Set("use-110", "value")将会被翻译为指令:HSET user-set use-110 value

type redisUser struct {gone.Flaghash redis.Hash `gone:"gone-redis-provider,user-set"`
}
func (r *redisUser) UseHash() {r.hash.Set("use-110", "value")
}

直接使用redis连接池

接口定义

type Pool interface {//获取链接Get() Conn//释放链接Close(conn redis.Conn)
}

使用示例

type redisUser struct {gone.Flagpool redis.Pool `gone:"gone-redis-pool"`
}func (r *redisUser) UsePool() {conn := r.pool.Get()defer r.pool.Close(conn)//执行redis命令_, err := conn.Do("SET", "key", "value")
}
http://www.lryc.cn/news/350916.html

相关文章:

  • SpringBoot前置知识02-spring注解发展史
  • C++ TCP发送Socket数据
  • 鸿蒙HarmonyOS开发中的易混点归纳-持续补充中
  • ue引擎游戏开发笔记(45)——添加游戏音效
  • 202472读书笔记|《首先你要快乐,其次都是其次》——快乐至上,允许一切发生
  • 8.STL中Vector容器的常见操作(附习题)
  • 5.23小结
  • 文心一言 VS 讯飞星火 VS chatgpt (265)-- 算法导论20.1 4题
  • Flutter 中的 EditableText 小部件:全面指南
  • H800基础能力测试
  • 2024/5/24 Day38 greedy 435. 无重叠区间 763.划分字母区间 56. 合并区间
  • 【python】使用函数名而不加括号是什么情况?
  • 全文检索ElasticSearch简介
  • Github上传时报错The file path is empty的解决办法
  • Adobe Bridge BR v14.0.3 安装教程 (多媒体文件组织管理工具)
  • 嵌入式学习——3——TCP-UDP 数据交互,握手,挥手
  • 【LeetCode】【3】无重复字符的最长子串(1113字)
  • 溪谷联运SDK功能全面解析
  • Vitis HLS 学习笔记--控制驱动TLP - Dataflow视图
  • 蓝桥杯物联网竞赛_STM32L071KBU6_关于sizo of函数产生的BUG
  • Wpf 使用 Prism 实战开发Day22
  • 遍历列表
  • 创建vue工程、Vue项目的目录结构、Vue项目-启动、API风格
  • 为了更全面地分析开发人员容易被骗的原因和提供更加深入的防范措施
  • 虹科Pico汽车示波器 | 免拆诊断案例 | 2020款奔驰G350车行驶中急加速时发动机抖动
  • 大模型落地竞逐,云计算大厂“百舸争流”
  • 物体检测算法-R-CNN,SSD,YOLO
  • 区块链开发:区块链软件开发包装相关解析
  • 一个月速刷leetcodeHOT100 day07 轮转数组 除自身以外的乘积 找到字符串中所有字母异位词
  • Plotly数据可视化宝典