黑马点评04集群下的并发安全

实战篇-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都锁住一个用户。

相关推荐
用户0328472220708 小时前
如何搭建本地yum源(上)
运维
倔强的石头_2 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab2 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence3 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神3 天前
三、用户与权限管理
数据库·mysql
大树883 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠3 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
霸道流氓气质3 天前
领域驱动设计(DDD)在 Spring Boot 微服务中的实践指南
运维·spring boot·微服务
小宇宙Zz3 天前
Maven依赖冲突
java·服务器·maven
Inhand陈工3 天前
基于台达PLC与映翰通IG502的智慧水产养殖精准投喂与远程运维解决方案
运维·人工智能·物联网·阿里云·信息与通信