所谓Linux服务器内核参数优化(适合Apache、Nginx、Squid等多种web应用,特殊的业务有可能需要做略微调整),主要是指在Linux系统中针对业务服务应用而进行的系统内核参数调整,优化并无一定的标准。下面是生产环境下Linux常见的内核优化为例子进行说明,供大家参考。
优化的方法是执行vim /etc/sysctl.conf命令到文件结尾,然后拷贝如下内容并保存。
net.ipv4.tcp_fin_timeout = 2
net.ipv4.tcp_tw_reuse = 1
net.ivp4.tcp_tw_recycle = 1
net.ivp4.tcp_syncookies = 1
net.ivp4.tcp_keepalive_time = 600
net.ivp4.ip_local_port_range = 4000 65000
net.ivp4.tcp_max_syn_backlog = 16384
net.ipv4.tcp_max_tw_buckets = 36000
net.ivp4.route.gc_timeout = 100
net.ivp4.tcp_syn_retries = 1
net.ivp4.tcp_synack_retries = 1
net.core.somaxconn = 16384
net.core.netdev_max_backlog = 16384
net.ivp4.tcp_max_orphans = 16384
#以下参数是对iptables防火墙的优化,防火墙不开会提示,可以忽略不理
net.nf_conntrack_max = 25000000
net.netfilter.nf_conntrack_tcp_timeout_established = 180
net.netfilter.nf_conntrack_tcp_timeout_time_wait = 120
net.netfilter.nf_conntrack_tcp_timeout_close_wait = 60
net.netfilter.nf_conntrack_tcp_timeout_fin_wait = 120
将上面的内核参数加入/etc/sysctl.conf文件中,然后执行如下命令使之生效:
如果是在Centos6环境中,必须开启iptables服务才不会出现上面显示的报错,其实报错也可以暂时不理,这时针对防火墙的优化,而此时防火墙并没有开启,将来开启就没问题了。
sysctl.conf内核文件中的参数含义见表1 。
表1: