【并发控制】并发控制与分布式锁(redis/zookeeper)实现【图文教程】_ 第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却是生产过程中常用的分布式锁实现。

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

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

猜你喜欢

转载自blog.csdn.net/IT_Most/article/details/108735578