gone是可以高效开发Web服务的Golang依赖注入框架
github地址:https://github.com/gone-io/gone
文档地址:https://goner.fun/zh/
请帮忙在github上点个 ⭐️吧,这对我很重要 ;万分感谢!!
文章目录
利用redis提供分布式锁和分布式缓存
在本文中,我们将分享在gone中如何使用分布式缓存和分布式锁,其中分布式锁中实现了一种较为自由的处理方式———“智能锁”,对一个处理函数进行上锁,函数执行中会周期性检测锁过期的剩余时间并自动给锁续期,函数执行完后会自动解锁。
第一步:将redis相关Goner埋葬到Cemetery
什么是 Goner?
什么是 埋葬?
什么是 Cemetery?
参考 Gone的核心概念
在Priest函数中增加_ = goner.RedisPriest(cemetery)
,如下:
func priest(cemetery gone.Cemetery) error {
//使用 goner.RedisPriest 函数,将 redis 相关的Goner 埋葬到 Cemetery 中
_ = goner.RedisPriest(cemetery)
cemetery.Bury(&redisUser{
})
return nil
}
第二步:在配置文件中增加redis相关配置
创建配置文件 config/default.properties
,内容如下:
# redis服务地址,格式为 `host:port`
redis.server=localhost:6379
# redis服务密码,不配置默认为空
redis.password=
其中,redis服务地址需要改你能访问到的redis服务地址。
更多配置:
redis.max-idle
:最大空闲链接数,不配置默认为2redis.max-active
:最大活跃链接数,不配置默认为10redis.db
:使用的db,不配置默认为0redis.cache.prefix
:key前缀,如果设置了,对redis的增删改查都会拼接该前缀,拼接方式${prefix}#${key}
;默认为空
关于配置文件,更多参考:通过内置Goners支持配置文件
第三步,使用redis
注入接口
在需要使用的结构体中注入 接口redis.redis.Cache
和 redis.Locker
,他们的GonerId
分别为:gone-redis-cache
和gone-redis-locker
:
type redisUser struct {
gone.Flag
cache redis.Cache `gone:"gone-redis-cache"`
locker redis.Locker `gone:"gone-redis-locker"`
}
使用分布是缓存
请看下面代码中的注释:
func (r *redisUser) UseCache() {
key := "gone-address"
value := "https://github.com/gone-io/gone"
//设置缓存
err := r.cache.Put(
key, //第一个参数为 缓存的key,类型为 `string`
value, // 第二参数为 需要缓存的值,类型为any,可以是任意类型;传入的值会被编码为 `[]byte` 发往redis
10*time.Second, // 第三个参数为 过期时间,类型为 `time.Duration`;省略,表示不设置过期时间
)
if err