系统默认的ulimit对文件打开数量的限制是1024,修改/etc/security/limits.conf并加入以下配置,永久生效
* soft nofile 65535
* hard nofile 65535
统计各进程、各用户、各命令打开句柄数
(1)统计各进程打开句柄数:lsof -n | awk '{print $2}' | sort | uniq -c | sort -nr
(2)统计各用户打开句柄数:lsof -n | awk '{print $3}' | sort | uniq -c | sort -nr
(3)统计各命令打开句柄数:lsof -n | awk '{print $1}' | sort | uniq -c | sort -nr
通过lsof恢复误删除的文件
rm -fr messages
lsof | grep messages | grep deleted
rsyslogd 892 root 4w REG 253,0 678349 70159614 /var/log/messages (deleted)
in:imjour 892 938 root 4w REG 253,0 678349 70159614 /var/log/messages (deleted)
rs:main 892 940 root 4w REG 253,0 678349 70159614 /var/log/messages (deleted)
cat /proc/892/fd/4 > /var/log/messages
lsof的其他用法
1.列出所有打开的文件:
lsof
备注: 如果不加任何参数,就会打开所有被打开的文件,建议加上一下参数来具体定位
2. 查看谁正在使用某个文件
lsof /filepath/file
3.递归查看某个目录的文件信息
lsof +D /filepath/filepath2/
备注: 使用了+D,对应目录下的所有子目录和文件都会被列出
4. 比使用+D选项,遍历查看某个目录的所有文件信息 的方法
lsof | grep ‘/filepath/filepath2/’
5. 列出某个用户打开的文件信息
lsof -u username
备注: -u 选项,u其实是user的缩写
6. 列出某个程序所打开的文件信息
lsof -c mysql
备注: -c 选项将会列出所有以mysql开头的程序的文件,其实你也可以写成**lsof | grep mysql, 但是第一种方法明显比第二种方法要少打几个字符了
7. 列出多个程序多打开的文件信息
lsof -c mysql -c apache
8. 列出某个用户以及某个程序所打开的文件信息
lsof -u test -c mysql
9. 列出除了某个用户外的被打开的文件信息
lsof -u ^root
备注:^这个符号在用户名之前,将会把是root用户打开的进程不让显示
10. 通过某个进程号显示该进行打开的文件
lsof -p 1
11. 列出多个进程号对应的文件信息
lsof -p 123,456,789
14. 列出所有tcp 网络连接信息
lsof -i tcp
15. 列出所有udp网络连接信息
lsof -i udp
16. 列出谁在使用某个端口
lsof -i :3306
17. 列出谁在使用某个特定的udp端口**
lsof -i udp:55
特定的tcp端口
lsof -i tcp:80
18. 列出某个用户的所有活跃的网络端口
lsof -a -u test -i
19. 列出所有网络文件系统
lsof -N
20. 使用@host来显示指定到指定主机的连接
lsof -i@172.16.12.5
21. 使用@host:port显示基于主机与端口的连接
lsof -i@172.16.12.5:22
网友评论