服务器架构为:css
Nginx+resin+memcached+db
nginx
1、故障缘由服务器
一、服务器负载高架构
(1)访问量突增memcached
(2)代码逻辑问题线程
(3)部分服务失效(ATS,DB,MC......)xml
PS:Linux服务器负载通常在2如下。接口
二、Direct Buffer Memory内存
Direct Buffer Memory指本地应用与MC通信区域(本地缓冲区),若MC块设置过大,GC不能及时回收。开发
三、大量静态文件占用resin线程
Resin线程通常为256
四、JVM配置过大,GC时间长,致使线程堵塞
通常应用JVM配置2~2.5G内存,大的应用配置为3G,小的应用配置为1.5G
2、措施
一、分离静态文件
js,css,image,xml....这类文件直接经过nginx进行跳转,不占用resin线程
二、访问量高的页面和接口根据业务需求适当静态化,如使用nginxPeoxyCache或者Ats(Apache Traffic Server)下降resin占用线程数
client--->ATS--->Nginx--->NginxProxyCache--->Memcached--->Db
三、切忌MC块设置过大,或者大量XML文件读取。
四、注意代码质量(开发规范)
五、JVM设置中,Xms,Xmx不要设置过大,Xmm设置通常为Xmx/Xms的1/3.