分布式锁对比
首页->学习资料->编程语言->java架构师教程->分布式架构 关键词: 发布时间:2020-05-29 23:46:32 浏览次数:2076


image.png

分布式锁对比

(以下订单更新库存为例)

对于数据库来说查询的时候一般是用select for update加锁,更新库存的时候执行sql语句要判断剩余库存大于等于购买数据,如:where amout>=buyNum

redis中是用setnx(value存一个随机数)及delete来实现锁及释放锁,注意释放所时要判断生成锁的随机数和进和获得锁时是否一样,以免删除其它进程产生的锁;

其它几种是第三方的包,zookeeper的原理是高并发时,生成有序树节点,最先生成的占用锁,其它的进程处于等待中,前面的执行完成后删除节点,后面的节点判断自己排在第一位时则获得所;

redisson是对redis的封装,其原理和setnx基本一致,比较好用(为什么会出现redission呢,主要是自己用setnx时写逻辑可能有纰漏);

赞:(0)
踩:(0)
相关文章
navicate连接mycat报1184错误
centos7下mycat安装及配置
读写分离与分库分表
MyCat读写分离和分库分表
热门文章
win7中将文件拷贝到虚拟机linux下
phpexcel设置行高及列宽,背景颜色,
rabbitmq无法启动
intellij idea不显示git push按钮
php7中使用mongodb的aggregate进行
laravel页面静态化的方法
centos7.4 64位下swoole安装及配置
navicate连接mycat报1184错误
curl设置超时不起作用(CURLOPT_TIM
devops-jenkins容器为pending状态
好评文章
phpexcel设置行高及列宽,背景颜色,
php7中使用mongodb的aggregate进行
intellij idea打开文件所在文件夹
windows下使用MongoDB Compass Com
win7中将文件拷贝到虚拟机linux下
laravel 中悲观锁 & 乐观锁的使用
单点登录sso原理及php实现方式及de
navicate连接mycat报1184错误
rabbitmq无法启动
laravel整合dingo/api方法步骤:jwt
标签
rabbitmq mysql备份 elasticsearch golang swoole
我的项目
【github】www.github.com/hurong241
【码云】gitee.com/hu_rong/projects
【docker hub】hub.docker.com/repositories/hurong241
【packagist】packagist.org/users/hurong241/packages
站点信息
建站时间:2011年
文章数:623篇
浏览数:1357698
粤ICP备18028092号-1  微信:hurong241