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

万江区仿做网站一学一做看视频网站有哪些

万江区仿做网站,一学一做看视频网站有哪些,游戏网站代理,做刷票的网站文章目录 Redis 参考文档配置项import 和 bury使用分布是缓存 redis.Cache接口定义使用示例 使用分布式锁 redis.Locker接口定义使用示例 操作Key,使用 redis.Key接口定义 使用 Provider 注入 redis 接口使用示例 直接使用redis连接池接口定义使用示例 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.yayakq.cn/news/322922/

相关文章:

  • 做网站公司凡科网站后台需要多少
  • 湖南建设网站获客系统wordpress建网站主页
  • 网易企业邮箱密码格式要求济宁seo优化
  • 兰州专业做网站做网站建设公司赚钱吗
  • 南阳网站制作公司做网站竞价还需要推广公司
  • .net开发的网站 能做成app吗如何模板建站
  • 网站外包一般多少钱啊电子商务公司有什么职位
  • 建产品网站怎么做白城市住房建设局网站
  • 长沙网站设计哪家专业云主机重装系统后网站重新部署吗
  • 山东卓创 网站建设哪个免费建站好
  • 江苏港口建设费申报网站wordpress 主页重定向
  • 网站开发前的准备工作wordpress编辑header
  • 苏州网站建设代理渠道做网站竞价没有点击率
  • 电子上网站建设与维护网站模板 登陆
  • 微网官方网站新浪微舆情大数据平台
  • 国内服务器做网站要备案装潢设计学校有哪些
  • 网站建设平台硬件要求网站可以做2个公司的吗
  • 网站建设网站制作提供服务清新区住房和城乡建设局网站
  • 上海最大的网络推广公司百度seo费用
  • 网站建设课程感想企业网站推广过程
  • 做网站去哪个公司制作网页工具按工作方式
  • 在线探测网站开发语言跨境电商公司注册
  • 无锡网站排名优化视频做网站
  • 桂林什么公司做网站推广好wordpress 验证码
  • 北京建设企业网站在线html网页制作工具
  • 公司注册好了怎么做网站seo引擎搜索网址
  • 做网站后台搭建都用什么苏州网站推广去苏州聚尚网络
  • 单位门户网站建设工作建议鄂州网红打卡地
  • 维护一个网站难吗上海公司网站制作
  • 织梦移动端网站模板下载地址在线学习建设网站