【运维笔记】linux最大文件句柄数

在linux服务器大并发调优时,其修改linux最大文件句柄数是最常修改的参数之一

目前:阿里云服务器默认为:open files (-n) 65535

[root@iZbp16qstyvxjc2nlzquvpZ ~]# ulimit -a
core file size          (blocks, -c) 0
data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited
pending signals                 (-i) 63457
max locked memory       (kbytes, -l) 64
max memory size         (kbytes, -m) unlimited
open files                      (-n) 65535
pipe size            (512 bytes, -p) 8
POSIX message queues     (bytes, -q) 819200
real-time priority              (-r) 0
stack size              (kbytes, -s) 8192
cpu time               (seconds, -t) unlimited
max user processes              (-u) 63457
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited

亚马逊服务器默认为open files: (-n) 1024

[root@localhost ~]# ulimit -a
core file size          (blocks, -c) 0
data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited
pending signals                 (-i) 39188
max locked memory       (kbytes, -l) 64
max memory size         (kbytes, -m) unlimited
open files                      (-n) 1024
pipe size            (512 bytes, -p) 8
POSIX message queues     (bytes, -q) 819200
real-time priority              (-r) 0
stack size              (kbytes, -s) 8192
cpu time               (seconds, -t) unlimited
max user processes              (-u) 655350
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited

备注:

  • 默认情况下,linux最大文件句柄数为1024个。
  • 当你的服务器在大并发达到极限时,就会报出 " Too many open files "

执行下面命令即可修改最大句柄数为655350:

[root@demo  /root]#ulimit -n 655350

但是,这种方法只针对当前进程有效。重新打开一个shell或者开启一个进程,你就会发现参数还是
ulimit -n xx修改之前的数字。

另一种方法就是修改linux系统参数。vi /etc/security/limits.conf 添加:

# End of file
# -----------分割线,上面是配置文件的模板,下面是自己添加的------------------------
*                soft   nofile           655350         #表示任何一个用户可以打开的最大的文件描述符数量
*                hard    nofile          655350
*                soft    nproc           655350         #表示任何一个用户可以打开的最大的进程数
*                hard    nproc           655350
@student         hard    nofile          65535          #student组中的任何人最多能打开文件描述符数量是65535,并且会在打开65000个时发出警告
@student         soft    nofile          65000
"/etc/security/limits.conf" 70L, 3225C

修改以后保存,注销当前用户,重新登录,执行ulimit -a ,ok ,参数生效了:

[root@localhost ~]# ulimit -a
core file size          (blocks, -c) 0
data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited
pending signals                 (-i) 39182
max locked memory       (kbytes, -l) 64
max memory size         (kbytes, -m) unlimited
open files                      (-n) 655350
pipe size            (512 bytes, -p) 8
POSIX message queues     (bytes, -q) 819200
real-time priority              (-r) 0
stack size              (kbytes, -s) 8192
cpu time               (seconds, -t) unlimited
max user processes              (-u) 655350
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited
[root@localhost ~]# 














参考文献:
linux最大文件句柄数:https://jinjiajin.net/101.html


























注:以上内容仅提供参考和交流,请勿用于商业用途,如有侵权联系本人删除!


持续更新中…

如有对思路不清晰或有更好的解决思路,欢迎与本人交流,微信:seesun2012(非紧急项目请加QQ群解答),QQ群:273557553
你遇到的问题是小编创作灵感的来源!


### 回答1: 要查看Linux系统中打开的文件句柄,可以使用以下命令: ``` $ cat /proc/sys/fs/file-nr ``` 该命令会输出三个字,分别表示当前已分配的文件句柄、当前已使用的文件句柄和系统最大允许的文件句柄。其中,第一个字表示已分配但未使用的文件句柄,第二个字表示已经使用的文件句柄,第三个字表示系统最大允许的文件句柄。 ### 回答2: 在Linux中,每个进程都有一个默认的文件句柄限制,用于限制进程能够打开的文件量。如果进程试图打开超过这个限制的文件,则会收到一个错误。在大多情况下,这个限制被设置为1024个文件句柄,但是根据系统配置的不同,它也可能更高或更低。 在Linux中,可以使用许多不同的命令来检查当前的文件句柄限制和进程打开的文件句柄。以下是一些最常见的命令: 1. ulimit命令 ulimit是一个用于控制操作系统资源限制的命令,包括文件句柄限制。默认情况下,ulimit -n命令将显示进程的文件句柄限制。要查看当前进程已经打开的文件句柄,可以使用lsof命令。 2. /proc/sys/fs/file-max文件 /proc/sys/fs/file-max是一个包含系统文件句柄文件。这个值表示系统上允许的最大文件句柄。要查看这个值,可以使用cat /proc/sys/fs/file-max命令。 3. lsof命令 lsof命令可以列出当前进程打开的文件和网络连接。可以使用以下命令来列出当前进程打开的文件: lsof -u username | wc -l 其中,username是进程所有者的用户名。这将返回打开的文件。 4. ss命令 ss命令用于列出所有活动的套接字连接。可以使用以下命令来列出所有进程的文件句柄: ss -s 这将返回所有进程当前打开的文件句柄量。 总的来说,在Linux中查看文件句柄可以使用既定的命令,如ulimit、/proc/sys/fs/file-max、lsof和ss等,但要注意选择合适的命令来查看所需的信息。 ### 回答3: 在Linux系统中,文件句柄是指进程能够保持的打开文件量。每个进程在运行时都会分配一定量的文件句柄,而每次使用文件时,进程都会使用其中的一个句柄来表示该文件。如果该进程打开了过多的文件,就可能会导致文件句柄耗尽,从而无法打开更多的文件。 要查看Linux系统中的文件句柄,可以使用以下命令: 1. 查看当前用户的文件句柄: 命令:ulimit -n 该命令将显示当前用户可以打开的文件句柄。如果该值为默认值,则通常为1024。如果需要增加文件句柄,可以编辑/etc/security/limits.conf文件并添加以下行: * soft nofile 65535 * hard nofile 65535 这将允许所有用户同时打开多达65535个文件。 2. 查看某个进程的文件句柄: 命令:lsof -p <pid> | wc -l 该命令将显示指定进程的文件句柄。要查找特定进程的PID,请使用ps或top命令。 3. 查看系统中所有进程的文件句柄: 命令:cat /proc/sys/fs/file-nr 该命令将显示系统中所有进程使用的文件句柄,以及系统可以分配的最大文件句柄。这个值应该是当前文件句柄文件句柄限制之间的最小值。如果当前的文件句柄接近最大量,则可能需要增加文件句柄的限制。 总之,要查看Linux系统中的文件句柄,可以使用ulimit、lsof和cat等命令。了解文件句柄量对于确保系统的稳定性和可靠性非常重要。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值