黑马点评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都锁住一个用户。

相关推荐
EverydayJoy^v^5 小时前
RH134学习进程——十二.运行容器(1)
linux·运维·容器
岁岁种桃花儿5 小时前
MySQL从入门到精通系列:InnoDB记录存储结构
数据库·mysql
b***25115 小时前
电池组PACK自动化生产线的关键流程与核心优势
运维·自动化
郝亚军6 小时前
如何在Ubuntu和win10/11之间通过samba访问对方的文件
linux·服务器·ubuntu
jiunian_cn6 小时前
【Redis】hash数据类型相关指令
数据库·redis·哈希算法
冉冰学姐7 小时前
SSM在线影评网站平台82ap4(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm框架·在线影评平台·影片分类
哲伦贼稳妥7 小时前
职场发展-遇到以下情况请直接准备后手吧
运维·经验分享·其他·职场和发展
Exquisite.8 小时前
企业高性能web服务器(4)
运维·服务器·前端·网络·mysql
北塔软件8 小时前
北塔方案 | 政府行业IT运维解决方案
运维·it运维·解决方案·政务
知识分享小能手8 小时前
SQL Server 2019入门学习教程,从入门到精通,SQL Server 2019数据库的操作(2)
数据库·学习·sqlserver