• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

distlock: Golang的分布式锁通用组件,支持 Redis,Postgres

原作者: [db:作者] 来自: 网络 收藏 邀请

开源软件名称:

distlock

开源软件地址:

https://gitee.com/go-locks/distlock

开源软件介绍:

Go-Locks License

通用的Golang分布式锁组件,更多使用案例详见 examples

Driver列表

若有意向贡献未完成的驱动代码,请通过 ISSUES 或 邮箱 [email protected] 联系我

Driver代码完成度测试完成度依赖包使用说明
redis100%100%letsfire/redigo详见 README.md
pgsql100%100%lib/pq详见 README.md
etcd未完成未测试etcd/client详见 README.md
etcdv3未完成未测试etcd/clientv3详见 README.md

方法说明

配置项 mutex.OptFunc 以及返回值锁的使用详见 mutex/README.md

  • NewMutex(name string, optFuncs ...mutex.OptFunc) (*mutex.Mutex, error)
    创建互斥锁,若 name 已用于创建读写锁则返回 error,本方法单例模式
  • NewRWMutex(name string, optFuncs ...mutex.OptFunc) (*mutex.RWMutex, error)
    创建读写锁,若 name 已用于创建互斥锁则返回 error,本方法单例模式

注意事项

  • 不可重入(如果您有强烈的需求场景,请通过 ISSUES 提供反馈)
  • 非公平锁(Golang的本地锁 sync.Locker 视乎也不是公平锁,若您有需求或建议,请通过 ISSUES 提供反馈)
  • 有互斥锁 mutex 和 读写锁 rwmutex 两种类型,具体支持程度详见各个 Driver 对应的 README.md
  • 虽有完整的单元测试,但暂未经过实际项目考验,故慎用于生产环境,如有问题请通过 ISSUES 来共同完善

项目结构

  • 主线调用层级为 distlock.go -> mutex.go -> driver.go
  • distlock.go 提供了创建锁的工厂类,单例模式(相同名称的锁有且仅有一个,有且仅为一种)
  • mutex.go提供了各类锁的实现,欢迎各位同学贡献其他类型锁,详见 mutex/README.md
  • driver.go提供驱动接口的定义,欢迎各位同学贡献其他驱动,详见 driver/README.md

鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
EventBus: 发布时间:2022-03-25
下一篇:
LNMT: LNMT一键安装包 – CentOS/RedHat下自动编译安装Nginx,JRE,Tomcat,MySQL 如需 ...发布时间:2022-03-25
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap