文件句柄数设置-linux

在使用Linux时我们需要同时打开多个文件,来适配高并发的需求,这时就需要设置一下文件句柄数了,默认打开的是1024

文件句柄,文件描述符,会随着进程数增加而增加。
Linux是有文件句柄限制的,而且默认都是1024,作为一台生产服务器,其实很容易就达到 这个数量,因此我们需要把这个值改大一些。我们可以用ulimit -n 来查看当前用户句柄数限制

ulimit 命令
1、查看当前打开文件句柄数

ulimit -n
2、查看所有配置参数

ulimit -a
3、临时修改句柄数

unlimit -HSn 2048
4、永久修改句柄数(系统全局设置)

sudo vim /etc/security/limits.conf

#                 
##*               soft    core            0
#root            hard    core            100000
#*               hard    rss             10000
#@student        hard    nproc           20
#@faculty        soft    nproc           20
#@faculty        hard    nproc           50
#ftp             hard    nproc           0
#ftp             -       chroot          /ftp
#@student        -       maxlogins       4*       soft    nofile  65535
*       hard    nofile  65535

* #代表所有用户

- #超过文件句柄数时,什么都不干

soft #超过文件句柄数时,仅提示

hard #超过文件句柄数时,直接限制

用户局部设置, vim /etc/security/limits.conf


root - nofile 65535
root soft nofile 65535
root hard nofile 65535


5、系统优化

sudo vim /etc/sysctl.conf

net.ipv4.tcp_fin_timeout = 2
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_tw_recycle = 1
net.ipv4.tcp_syncookies = 1
net.ipv4.tcp_keepalive_time = 600
net.ipv4.ip_local_port_range = 4000   65000
net.ipv4.tcp_max_syn_backlog = 16384
net.ipv4.tcp_max_tw_buckets = 36000
net.ipv4.route.gc_timeout = 100
net.ipv4.tcp_syn_retries = 1
net.ipv4.tcp_synack_retries = 1
net.core.somaxconn = 16384
net.core.netdev_max_backlog = 16384
net.ipv4.tcp_max_orphans = 16384
net.ipv4.ip_forward = 1

在底部追加:fs.file-max=655350
配置立即生效:

sudo sysctl -p


这样就修改完毕了,用户级句柄数的修改需要重启一下才能生效,最好执行一下reboot,再次输入ulimit -n查看已经修改好了。

针对nginx服务vim /etc/nginx/nginx.conf 


user  www;
worker_processes  1;
#添加下面一行
worker_rlimit_nofile 65535;

你可能感兴趣的:(linux,服务器,运维)