博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【并发控制】并发控制与分布式锁(redis/zookeeper)实现【图文教程】_ 第2章
阅读量:2140 次
发布时间:2019-04-30

本文共 648 字,大约阅读时间需要 2 分钟。

平凡也就两个字: 懒和惰;

成功也就两个字: 苦和勤;
优秀也就两个字: 你和我。
跟着我从0学习JAVA、spring全家桶和linux运维等知识,带你从懵懂少年走向人生巅峰,迎娶白富美!
关注微信公众号【 IT特靠谱 】,每一篇文章都是心得总结,跟我学习你就是大牛!

 

并发控制与分布式锁(redis/zookeeper)实现【图文教程】_第2章

---java同步锁(synchronized或Lock)实现并发控制

特别注意:

      synchronizedLock方式只适用于单实例服务的并发控制,如果集群部署就失效了!集群分布式系统只能用分布式锁!!

synchronized方式实现并发控制

      在库存系统的减库存操作方法手动添加同步锁。

2 Lock方式方式实现并发控制

      给库存系统的减库存方法手动lock()和unLock()。注意:unlock()必须放到finally中,防止抛出异常后锁未释放!

3 总结

      对于单实例应用而言,通过synchronizedLock方式完全可以满足实现并发控制,竞争到锁的线程会执行代码块,未竞争到锁的线程会被阻塞,直到竞争到锁!

      对于k8s、nginx代理、物理负载均衡器等代理/托管的服务集群而言,synchronizedLock方式并不能解决并发问题,因此分布式锁就应运而生了! redis或zookeeper却是生产过程中常用的分布式锁实现。

      下节将分享分布式锁的最佳实践,敬请期待~

如果以上教程对您有帮助,为了不迷路,请关注一下吧~

 

转载地址:http://tupgf.baihongyu.com/

你可能感兴趣的文章
Redis学习笔记(四)—— redis的常用命令和五大数据类型的简单使用
查看>>
Win10+VS2015编译libcurl
查看>>
Windows下使用jsoncpp
查看>>
Ubuntu下测试使用Nginx+uWsgi+Django
查看>>
Windows下编译x264
查看>>
visual studio调试内存泄漏工具
查看>>
开源Faac实现PCM编码AAC
查看>>
Windows下wave API 音频采集
查看>>
借船过河:一个据说能看穿你的人性和欲望的心理测试
查看>>
AndroidStudio 导入三方库使用
查看>>
Ubuntu解决gcc编译报错/usr/bin/ld: cannot find -lstdc++
查看>>
解决Ubuntu14.04 - 16.10版本 cheese摄像头灯亮却黑屏问题
查看>>
解决Ubuntu 64bit下使用交叉编译链提示error while loading shared libraries: libz.so.1
查看>>
VS生成DLL文件供第三方调用
查看>>
Android Studio color和font设置
查看>>
Python 格式化打印json数据(展开状态)
查看>>
Centos7 安装curl(openssl)和libxml2
查看>>
Centos7 离线安装RabbitMQ,并配置集群
查看>>
Centos7 or Other Linux RPM包查询下载
查看>>
运行springboot项目出现:Type javax.xml.bind.JAXBContext not present
查看>>