JavaWeb应用常见故障以及处理方法

服务器架构为: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.

相关文章
相关标签/搜索