博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
3万的支付订单请求并发解决方案
阅读量:6079 次
发布时间:2019-06-20

本文共 700 字,大约阅读时间需要 2 分钟。

作者:李道兵
链接:https://www.zhihu.com/question/27590048/answer/37432988
来源:知乎
著作权归作者所有,转载请联系作者获得授权。
1. 首先要解决掉数据库的压力,3万qps对应的磁盘 iops 很大,不过现在好的 SSD 能提供很好的 iops, 比如这款: 单盘 90000 IOPS,应该能撑住你的数据库,考虑到主备,以及你的sharding需求,3-9 台数据库机器,高内存,高CPU,SSD磁盘应该能抗住
2. 业务逻辑这一层: Java 系,用线程来抗并发的,如果业务逻辑不太复杂,那么基本能做到 100ms 内响应,那么 30000qps, 对应的是 3000并发线程,这部分设计的时候记得保持无状态,单台支撑 300-1000 并发没问题,加上一倍的冗余,那么 6~20 台业务型机器可以抗住。
3. 缓存层: 支付订单一般对缓存需求不高,但缓存层一般都会有,避免把查询压力压到数据库,简单两台缓存,或者缓存平行部署在业务型机器上都可以解决,具体看你的情况了。
4. 接入层: nginx 做LVS就可以了,记得 backlog 配大点就可以了, 3万qps, 假设单个请求的数据在 10KB 左右,那么是 300MB/s,如果是千兆机,每台4网卡,两内两外,加上冗余,我会部署4台入口机,如果是万兆机,两台做主备(心跳或者LVS)即可。
当然,魔鬼在细节,做好机器的监控,慢请求的监控,日志的汇聚与分析。然后逐步推进服务的 SOA 化来降低复杂度。留一台业务机打小流量来做线上测试。优化JVM运行参数,等等,要做的事情还很多。
你可能感兴趣的文章
git学习笔记(二)—— 创建版本库&&版本管理
查看>>
.Net Remoting(应用程序域) - Part.1
查看>>
windows server 2008下的一些设置技巧及优化
查看>>
[置顶] lvs-tun隧道模式搭建
查看>>
PHP ADLogin
查看>>
Web服务器 之 Debian下给apache加载ssl
查看>>
CTreeCtrl控件使用技巧
查看>>
第三届云计算大会 - Dell云计算: 企业的有效转型策略(转载)
查看>>
关于延迟时间的一点智慧
查看>>
33.NET对加密和解密的支持
查看>>
MVC文件图片ajax上传轻量级解决方案,使用客户端JSAjaxFileUploader插件02-多文件上传...
查看>>
jQuery显示和隐藏 常用的状态判断方法
查看>>
[翻译]Shape comparison language
查看>>
【Android Lock Pattern】图案解锁(一):LockPatternView源代码
查看>>
NLP常用信息资源
查看>>
精益求精--卓越的互联网产品设计与管理
查看>>
关于aspnet 2.0
查看>>
JavaScript验证Email地址
查看>>
opencl-Shader
查看>>
Inno Setup打包的安装程序在Vista/Win7上自动提示需要管理员权限的方法
查看>>