Skip to content

基于redigo、config封装的redis库,支持连接池、多实例等,且对分布式锁lock、数据存储器storer、延迟回调timer等常用场景进行封装

License

Notifications You must be signed in to change notification settings

ant-libs-go/redis

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

49 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Redis

基于redigo封装的Redis库

License GoDoc Go Report Card

特性

  • 简化Redis实例初始化流程,基于配置自动对Redis进行初始化
  • 支持连接池、多实例等场景
  • 基于Redis实现的分布式锁lock,支持加锁、等待锁释放、等待锁释放并加锁、基于锁实现幂等 等能力
  • 基于Redis实现延迟定时器timer,支持业务中触发延迟回调
  • 基于Redis和timer实现Storer,维护Mem、Redis、MySQL三者之间的数据同步关系(暂无法保证特殊情况下数据一致性),有助于基于对象开发时维护对象的同步

快速开始

  • toml 配置文件

    [redis.default]
        addr = "127.0.0.1:6379"
        pawd = "123456"
    [redis.stats]
        addr = "127.0.0.1:6379"
        pawd = "123456"
    
  • 使用方法

     // 初始化config包,参考config模块
     code...
    
     // 验证Redis实例的配置正确性与连通性。非必须
     if err = redisp.Valid(); err != nil {
         fmt.Printf("redis error: %s\n", err)
         os.Exit(-1)
     }
    
     // 如下方式可以直接使用Redis实例
     conn := redis.Client("default")
     defer conn.Close()
    
     conn.Do("GET", "key")
    
     // lock、timer、storer 的使用方法见代码

高级用法

  • 分布式锁、延迟定时器、Storer 使用方法参考代码

About

基于redigo、config封装的redis库,支持连接池、多实例等,且对分布式锁lock、数据存储器storer、延迟回调timer等常用场景进行封装

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages