网站首页 > java教程 正文
高并发
由于分布式系统的问世,高并发(High Concurrency)通常是指通过设计保证系统能够同时并行处理很多请求。通俗来讲,高并发是指在同一个时间点,有很多用户同时的访问同一 API 接口或者 Url 地址。它经常会发生在有大活跃用户量,用户高聚集的业务场景中。
普通单应用并发:
1.使用关键字synchronized就可实现。
即想提高效率不对方法添加synchronized,又想保证数据准确性,最后使用synchronized(userId) 在Controller层加锁(保证了只有重复数据被加锁,在Controller使用的原因是因为事务会在Service调用完毕才被提交,我实验过在Service同步,150并发会出现2条重复数据,因为事务还没来得及提交)
测试结果:测试了3次150并发 不到一秒的时间全部返回,结果1条登记成功,149条返回该作者已登记
2.事物级别设置最大
分布式环境:
1.数据库行级索,优点:简单粗暴;缺点:容易死锁&性能差,非数据库专业人士不建议使用。 使用对数据库添加行锁,实验发现还是会出现2条重复数据 分析: 理论上的结果应该是1条成功,149条失败。 对数据库的select语句添加行锁必须作用于某条记录,但是第一次报送时,数据库中并没有这条数据,因此行锁根本没有加上,导致第二条数据成功异步使用select语句。 第一次报送成功以后,数据库中有了这条数据,select语句成功的对这条记录添加了行锁,所以后边不会出现重复数据。因此此法不可用
2.通过数据库表的唯一索引解决
3.队列
4.分布式锁 (如redis锁,Zookeeper)
转载自GoslingWu,未经许可,严禁抄袭
更多相关内容,Java&python,软件开发等学习资料,电子书及视频还有高级讲师公开课免费资源
需要的可以私聊小编发送【学习】二字
猜你喜欢
- 2025-01-05 Java高并发编程-线程入门
- 2025-01-05 tomcat8.5配置高并发
- 2025-01-05 Java编程-高并发情况下接口性能优化实践-提升吞吐量TPS
- 2025-01-05 Java高并发编程-深入了解Thread类
- 2025-01-05 大促流量激增,通过什么手段提升系统的高并发、高可用性?
- 2025-01-05 Java 多线程与高并发,基础概念回顾
- 2025-01-05 实战场景下的Java高并发知识指南
- 2025-01-05 一篇文章教会你如何搭建高可用高并发系统
- 2025-01-05 一文看透Java高并发:Synchronized锁的性质、原理及其缺陷
- 2025-01-05 Kafka高可用,高吞吐量低延迟的高并发的特性背后实现机制
你 发表评论:
欢迎- 04-24Java Collections 工具类集合框架中常用算法解析
- 04-24桶排序的简单理解
- 04-24Java集合框架底层实现原理大揭秘
- 04-24Java 集合框架全面解析:选对数据结构,提升开发效率
- 04-24c#集合排序
- 04-24Java面试中常被问到的集合类深度解读
- 04-24VBA技术资料MF278:对集合进行排序
- 04-24Spring 最常用的 7 大类注解,史上最强整理
- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)