Java面试中常见的高并发解决方案

Java面试中常见的高并发解决方案

一般来讲,提高系统应对高并发能力的解决方案可以从以下几个方面入手:
(1)高性能服务器
(2)高性能数据库
(3)高效编程语言
(4)高性能web容器

提高数据库性能,解决高并发问题

  1. 分布式数据库:主从复制、读写分离、负载均衡(M-S或者M-M-S)。M-M-S模式中两个M只有一个是处于Active状态的,当处于Active态的数据库服务器崩溃的时候,另一个M快速替代。这种方式也可以使用哨兵模式进行操作。在使用数据库主从复制的过程中,当某一个表数据量过大的时候,也会造成数据库效率的下降,此时,我们可以使用库表散列对其进行调优。
  2. 数据库缓存:使用Redis做数据库缓存
  3. 数据库连接池
  4. 数据库索引
  5. 数据库集群
  6. 库表散列:不同模块对应不同的数据库或者表,再按照一定的策略,对某个页面或者功能进行更小的数据库散列,比如用户表,按照用户ID进行表散列。

提高项目语言效率,解决高并发问题

  1. 内存池、线程池、进程池
  2. 分布式锁
  3. 多线程的使用(多线程引发的并发操作问题)
  4. 多线程、超发、悲观锁、乐观锁。
  • 7
    点赞
  • 55
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值