文件句柄 查看linux

2018-03-23 17:05:39 lck5602 阅读数 34287

当你的服务器在大并发达到极限时,就会报出“too many open files”。

查看线程占句柄数

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) 59367
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) 59367
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited

其中:
open files                      (-n) 1024         代表每个

查看系统打开句柄最大数量

more /proc/sys/fs/file-max

查看打开句柄总数

lsof|awk '{print $2}'|wc -l

根据打开文件句柄的数量降序排列,其中第二列为进程ID:

lsof|awk '{print $2}'|sort|uniq -c|sort -nr|more

根据获取的进程ID查看进程的详情

ps -ef |grep 

修改linux单进程最大文件连接数

修改linux系统参数。vi /etc/security/limits.conf 添加
*  soft  nofile  65536
*  hard  nofile  65536
修改以后保存,注销当前用户,重新登录,执行ulimit -a ,ok ,参数生效了:
2016-06-30 13:52:12 yuanbinquan 阅读数 2652
    应用程序在一直使用文件句柄,而不释放文件句柄时,可能导致文件句柄资源耗尽,当文件句柄
耗尽自后所用的打开/新建文件函数都会返回错误,open、create、fopen、popen、socket。

1、查看系统默认的进程最大文件句柄数(socket也算文件句柄),linux系统默认是1024

# ulimit -n

1024

2、查看进程打开的文件句柄
step1:查看(App)进程号
#ps
  PID USER       VSZ STAT COMMAND
    1 root      1708 S    init
    2 root         0 SW   [kthreadd]
    3 root         0 SW   [ksoftirqd/0]
    4 root         0 SW   [kworker/0:0]
    6 root         0 SW   [rcu_kthread]
    7 root         0 SW<  [khelper]
    8 root         0 SW   [kworker/u:1]
  194 root         0 SW   [sync_supers]
  196 root         0 SW   [bdi-default]
  198 root         0 SW<  [kblockd]
  204 root         0 SW<  [ata_sff]
  215 root         0 SW   [khubd]
  223 root         0 SW<  [cfg80211]
  224 root         0 SW   [kworker/0:1]
  306 root         0 SW<  [rpciod]
  312 root         0 DW   [kswapd0]
  362 root         0 SW   [fsnotify_mark]
  369 root         0 SW<  [nfsiod]
  380 root         0 SW<  [crypto]
  405 root         0 SW   [scsi_eh_0]
  408 root         0 SW   [scsi_eh_1]
  411 root         0 SW   [kworker/u:2]
  422 root         0 SW   [mtdblock0]
  427 root         0 SW   [mtdblock1]
  432 root         0 SW   [mtdblock2]
  437 root         0 SW   [mtdblock3]
  442 root         0 SW   [mtdblock4]
  445 root         0 SW   [romblock0]
  448 root         0 SW   [romblock1]
  451 root         0 SW   [romblock2]
  454 root         0 SW   [romblock3]
  457 root         0 SW   [romblock4]
  965 root         0 SW   [flush-8:0]
 3954 root      288m S <  /dvr/bin/App

 5798 root      1708 R    ps
#
step2:查看进程占用的文件句柄
#cd /proc/3954
#ls fd -l
lr-x------    1 root     root            64 Jun 30 11:58 0 -> /dev/null
lrwx------    1 root     root            64 Jun 30 11:58 1 -> /dev/console
lr-x------    1 root     root            64 Jun 30 11:58 10 -> /dev/vpss
lr-x------    1 root     root            64 Jun 30 11:58 11 -> /dev/vpss
lr-x------    1 root     root            64 Jun 30 11:58 12 -> /dev/vpss
lr-x------    1 root     root            64 Jun 30 11:58 13 -> /dev/vpss
lr-x------    1 root     root            64 Jun 30 11:58 14 -> /dev/vi
lr-x------    1 root     root            64 Jun 30 11:58 15 -> /dev/vpss
lr-x------    1 root     root            64 Jun 30 11:58 16 -> /dev/vpss
lr-x------    1 root     root            64 Jun 30 11:58 17 -> /dev/vpss
lr-x------    1 root     root            64 Jun 30 11:58 18 -> /dev/vpss
lr-x------    1 root     root            64 Jun 30 11:58 19 -> /dev/vi
lrwx------    1 root     root            64 Jun 30 11:58 2 -> /dev/console
lr-x------    1 root     root            64 Jun 30 11:58 20 -> /dev/vpss
lr-x------    1 root     root            64 Jun 30 11:58 21 -> /dev/vpss
lr-x------    1 root     root            64 Jun 30 11:58 22 -> /dev/vpss

2011-05-23 16:37:00 lastsweetop 阅读数 56062

---查看系统默认的最大文件句柄数,系统默认是1024

# ulimit -n

1024

 

----查看当前进程打开了多少句柄数

# lsof -n|awk '{print $2}'|sort|uniq -c|sort -nr|more

131 24204 

57 24244  

57 24231   ........

其中第一列是打开的句柄数,第二列是进程ID。

可以根据ID号来查看进程名。

# ps aef|grep 24204

nginx  24204 24162 99 16:15 ?    00:24:25 /usr/local/nginx/sbin/nginx -s

 

Linux有硬性限制和软性限制。可以通过ulimit来设定这两个参数。方法如下,以root用户运行以下命令:

# ulimit -HSn 4096

以上命令中,H指定了硬性大小,S指定了软性大小,n表示设定单个进程最大的打开文件句柄数量。个人觉得最好不要超过4096,毕竟打开的文件句柄数越多响应时间肯定会越慢。设定句柄数量后,系统重启后,又会恢复默认值。如果想永久保存下来,可以修改.bash_profile文件,可以修改 /etc/profile 把上面命令加到最后.

2018-07-14 13:51:34 gamekit 阅读数 4277

确认系统设置的最大文件句柄数
ulimit -a

统计系统中当前打开的总文件句柄数
lsof|awk ‘{print $2}’ |wc -l

根据打开文件句柄的数量降序排列,其中第二列为进程ID:
lsof|awk ‘{print $2}’|sort|uniq -c|sort -nr|more

2019-04-02 10:43:07 qq_40910541 阅读数 2343

查看系统的最大文件句柄数和文件句柄的使用者PID

  1. ulimit -n查看当前系统的最大句柄数显示如下
    ulimit命令详解
    在这里插入图片描述
  2. ulimit -HSn x设置当前系统的文件句柄数为x

以上命令中,H指定了硬性大小,S指定了软性大小,n表示设定单个进程最大的打开文件句柄数量。个人觉得最好不要超过4096,毕竟打开的文件句柄数越多响应时间肯定会越慢。设定句柄数量后,系统重启后,又会恢复默认值。如果想永久保存下来,可以修改.bash_profile文件,可以修改 /etc/profile 把上面命令加到最后.

  1. lsof命令查看有关文件句柄的详细信息,如当前系统打开的文件数量,哪些进程在使用这些文件句柄等等。
  2. lsof -p 【PID】查看进程PID打开的文件句柄详细信息
  3. # lsof -n|awk '{print $2}'|sort|uniq -c|sort -nr|more 查看当前进程打开了多少句柄数在这里插入图片描述

其中第一列是打开的句柄数,第二列是进程ID。