前言:

    Semaphore是信号量,作用? 我想大家都知道。semaphore跟mutex的区别我想大家也知道了,我这里就不老生常谈,重复讲解了,有兴趣的朋友可以自行google相关的同步锁文章。

该文章后续会有更新, 原文地址, http://xiaorui.cc/?p=4822

像semaphore,mutex 可以支持多线程,也可以是多进程。但如果是在分布式集群环境想实现类似 semaphore的东西怎么做?  我们可以借助redis来实现,  我这里用了redis的hash、list、string实现的网络信号量。 利用redis hash存token的时间,list用来实现堵塞及非阻塞模式,利用redis string的setnx来实现分布式锁,锁的目的是用来原子性写一致。

该项目是使用golang写的,再具体代码就不详细描述了,有兴趣的可以直接看代码。

github的项目地址:

https://github.com/rfyiamcool/go_redis_semaphore

用法:

具体例子:

END.



对Python及运维开发感兴趣的朋友可以加QQ群 : 478476595 !!!
{ 2000人qq大群内有各厂大牛,常组织线上分享及沙龙,对高性能及分布式场景感兴趣同学欢迎加入该QQ群 }

另外如果大家觉得文章对你有些作用!   帮忙点击广告. 一来能刺激我写博客的欲望,二来好维护云主机的费用.
如果想赏钱,可以用微信扫描下面的二维码. 另外再次标注博客原地址  xiaorui.cc  ……   感谢!
暂无相关产品

评论已关闭。