一、优化思路
二、nginx优化配置
//nginx层面
//nginx.conf中配置
worker_rlimit_nofile 10000; //子进程允许打开的文件数
keepalive_timeout 0; //结束响应后立即断开tcp连接。
//keeplive_timeout表示tcp完成响应后,继续保持连接多久。如果这个值过大,会造成资源无效占用。
events{
worker_connections 10240;
}
//系统层面
echo 500000 > /proc/sys/net/core/somaxconn //设置最大连接数
echo 1 > /proc/sys/net/ipv4/tcp_tw_recycle //加快tcp回收
echo 1 > /proc/sys/net/ipv4/tcp_tw_reuse //空的tcp允许回收利用
echo 0 > /proc/sys/net/ipv4/tcp_syncookies //关闭洪水抵御
ulimit -n 30000
三、nginx&php-fpm优化配置
nginx将请求转发给php-fpm处理,当nginx转发很多请求时,php-fpm进程不够用,就会生成子进程。然而生成子进程需要内核来调度,比较耗时。如果网站并发比较大,可以用静态方式一次性生成多个子进程,保持的内存中。
//修改phjp-fpm.conf
pm=static //让php-fpm进程始终保持,不需要动态生成
pm.max_children=32 始终保持的子进程数量
四、php&mysql优化
思路
内核层面:加大连接数,加快tcp回收
mysql层面:增大连接数
php层面:用长连接,节省连接数
用内存缓存(memcached),减轻mysql压力
注意
内存缓存适用于缓存复杂的sql查询。因为php与memcached也要建立tcp连接,所以简单的sql查询不需要用缓存。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。