本文共 648 字,大约阅读时间需要 2 分钟。
平凡也就两个字: 懒和惰;
成功也就两个字: 苦和勤; 优秀也就两个字: 你和我。 跟着我从0学习JAVA、spring全家桶和linux运维等知识,带你从懵懂少年走向人生巅峰,迎娶白富美! 关注微信公众号【 IT特靠谱 】,每一篇文章都是心得总结,跟我学习你就是大牛!
特别注意:
synchronized或Lock方式只适用于单实例服务的并发控制,如果集群部署就失效了!集群分布式系统只能用分布式锁!!
在库存系统的减库存操作方法手动添加同步锁。
给库存系统的减库存方法手动lock()和unLock()。注意:unlock()必须放到finally中,防止抛出异常后锁未释放!
3 总结
对于单实例应用而言,通过synchronized或Lock方式完全可以满足实现并发控制,竞争到锁的线程会执行代码块,未竞争到锁的线程会被阻塞,直到竞争到锁!
对于k8s、nginx代理、物理负载均衡器等代理/托管的服务集群而言,synchronized或Lock方式并不能解决并发问题,因此分布式锁就应运而生了! redis或zookeeper却是生产过程中常用的分布式锁实现。
下节将分享分布式锁的最佳实践,敬请期待~
如果以上教程对您有帮助,为了不迷路,请关注一下吧~
转载地址:http://tupgf.baihongyu.com/