Linux 提高文件并发性,启用高级算法 hybla

  • 技术文档
  • 2021.12.22
  • 浏览:1520

在Linux下,我们使用命令ulimit -n来查看单个进程可以打开的最大文件句柄数(socket连接包括在此)。系统默认值为 1024,1024 对一般应用程序(如 Apache、系统进程)完全足够。但是单进程,比如squid、mysql、java等应用如何处理大量的请求就有点捉襟见肘了。如果单个进程打开的文件句柄数超过系统定义的值,则会提示“打开的文件太多”错误。为了处理更多的并发 TCP 连接,我们应该增加最大并发打开文件数的限制。

增加最大并发文件数
将两行文本添加到limits.conf

echo '* soft nofile 51200
* hard nofile 51200' >> /etc/security/limits.conf

然后继续设置ulimit

ulimit -n 51200

调整内核参数+启用高级算法hybl
注意:这一步不适用于OpenVZ或更低版本的内核,否则最后一步sysctl -p会报很多错误,如果不行就说明内核支持hibla等高级算法等参数调整。
在 /etc/sysctl.conf 中添加一些参数

echo 'fs.file-max = 51200
net.core.rmem_max = 67108864
net.core.wmem_max = 67108864
net.core.netdev_max_backlog = 250000
net.core.somaxconn = 4096
net.ipv4.tcp_syncookies = 1
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_tw_recycle = 0
net.ipv4.tcp_fin_timeout = 30
net.ipv4.tcp_keepalive_time = 1200
net.ipv4.ip_local_port_range = 10000 65000
net.ipv4.tcp_max_syn_backlog = 8192
net.ipv4.tcp_max_tw_buckets = 5000
net.ipv4.tcp_fastopen = 3
net.ipv4.tcp_mem = 25600 51200 102400
net.ipv4.tcp_rmem = 4096 87380 67108864
net.ipv4.tcp_wmem = 4096 65536 67108864
net.ipv4.tcp_mtu_probing = 1
net.ipv4.tcp_congestion_control = hybla' >> /etc/sysctl.conf

然后运行“sysctl -p”重新加载配置。
如果提示类似如下信息,说明你的内核不支持提示错误的功能或命令

sysctl: cannot stat /proc/sys/net/ipv4/xxxxx: No such file or directory