黑马点评04集群下的并发安全
2023-12-15 17:31:49
实战篇-08.优惠券秒杀-集群下的线程并发安全问题_哔哩哔哩_bilibili
为了应对高并发,需要把项目部署到多个机器构成集群,所以需要配置nginx。
?
1.如何模拟集群
通过idea的ctrl + d修改配置,实现多个tomcat运行模拟集群
然后在nginx上配置节点,8080/api 会代理到backend,然后backend配置了各个节点的信息(upstream)
实现轮询节点达到负载均衡。
2.集群引出了新的并发问题
前文在单节点情况下实现了并发安全,但是如果一个用户发两个秒杀请求,分别被nginx分配到两个节点上,那么你一个节点上的用户锁(以用户id作为监视器),不能在不同的节点上生效,这样还是锁不住同一用户的多个秒杀行为,然后还是不能保证一人一单。所以就需要分布式锁。
原因:
????????前文的intern()函数为什么呢即使你new了只要内容相同就会返回相同的地址呢?因为他会从字符串常量池里去找这个字符串的地址,无论你来几次,返回的都是常量池里那个字符串的地址,所以是一样的。不管你哪个线程都是在一个tomcat上运行的,只有一个jvm就只有一个常量池。
? ? ? ? 而集群部署的时候,不同服务器有自己的tomcat,那么每个服务器都有独立的jvm,所以常量池也不一样。所以无法保证intern()返回值相同,也就无法保证两个服务器上的锁监视器是同一个,也就锁不住同一个用户。
只能保证一个jvm内部锁住同一个用户,不能保证所有的jvm都锁住一个用户。
文章来源:https://blog.csdn.net/m0_50973548/article/details/135019136
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!