高并发系统的演进(如何设计一个高并发系统架构)

一:系统拆分:将一个系统拆分为多个子系统,用dubbo或springCloud来搞,然后每个系统连接一个数据库,这样就可以对并发访问起到一定的作用。

二:缓存:必须得用缓存。大部分的高并发场景,都是读多写少,完全可以在数据库和缓存中都写一份,然后读的时候大量都是走的缓存。毕竟redis轻松单机几万的并发是完全没有问题的。

三:MQ:可能你还是会出现高并发写的场景,比如一个业务操作里要频繁操作数据库多次,这时候就得用MQ了,大量写请求到MQ里,后边的系统消费后慢慢写,控制在mysql承载范围之内,MQ单机抗几万并发也是没有问题的。

四:分库分表,可能到了最后数据库层面还是免不了抗高并发的压力,那么就将一个数据库拆分为多个库,多个数据库来抗更高的并发;然后将一个表拆分为多个表,每个表的数据量保持少点,提高查询sql的性能。

五:读写分离,大多数情况数据库也是读多写少,没必要将所有请求都集中到一个库上,可以搞个主从架构,主库写入,从库读取,这样读流量再次上涨的时候,多加几个从库就行了。

六:Elasticsearch:对于全文检索方面的高并发,es是分布式的,可以随便扩容,因为分布式天然就可以支撑高并发。

注:以上整理自互联网

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

softwareDragon

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值