首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 操作系统 > UNIXLINUX >

linux务须会的命令lsof,有助于弄死你讨厌的服务器

2012-07-20 
linux必须会的命令lsof,有助于弄死你讨厌的服务器发现linux磁盘一直在增大,但一直没找到占用的文件小心是n

linux必须会的命令lsof,有助于弄死你讨厌的服务器
发现linux磁盘一直在增大,但一直没找到占用的文件
小心是nginx正在用删过的文件哦,会一直写block的,很恐怖哦
nginx的日志文件一定要停止nginx之后再删
lsof -n|grep delete
查找那些进程在使用已经删除的文件

------------------------------------------------
如果不是你程序主动记的日志,那可查一下数据库日志,系统日志,还有一个经常出问题的目录可重点查一下
/var/spool/clientmqueue
-------------------------------------------------------

转载http://tech.ccidnet.com/art/305/20070829/1194715_1.html
一般root用户才能执行lsof命令,普通用户可以看见/usr/sbin/lsof命令,但是普通用户执行会显示“permission denied”
我总结一下lsof指令的用法:
lsof abc.txt 显示开启文件abc.txt的进程
lsof -i :22 知道22端口现在运行什么程序
lsof -c abc 显示abc进程现在打开的文件
lsof -g gid 显示归属gid的进程情况
lsof +d /usr/local/ 显示目录下被进程开启的文件
lsof +D /usr/local/ 同上,但是会搜索目录下的目录,时间较长
lsof -d 4 显示使用fd为4的进程
lsof -i 用以显示符合条件的进程情况
语法: lsof -i[46] [protocol][@hostname|hostaddr][:service|port]
46 --> IPv4 or IPv6
protocol --> TCP or UDP
hostname --> Internet host name
hostaddr --> IPv4位置
service --> /etc/service中的 service name (可以不只一个)
port --> 端口号 (可以不只一个)
例子: TCP:25 - TCP and port 25
@1.2.3.4 - Internet IPv4 host address 1.2.3.4
tcp@ohaha.ks.edu.tw:ftp - TCP protocol hosthaha.ks.edu.tw service name:ftp
lsof -n 不将IP转换为hostname,缺省是不加上-n参数
例子: lsof -i tcp@ohaha.ks.edu.tw:ftp -n
lsof -p 12 看进程号为12的进程打开了哪些文件
lsof +|-r [t] 控制lsof不断重复执行,缺省是15s刷新
-r,lsof会永远不断的执行,直到收到中断信号
+r,lsof会一直执行,直到没有档案被显示
例子:不断查看目前ftp连接的情况:lsof -i tcp@ohaha.ks.edu.tw:ftp -r
lsof -s 列出打开文件的大小,如果没有大小,则留下空白
lsof -u username 以UID,列出打开的文件
一般root用户才能执行lsof命令,普通用户可以看见/usr/sbin/lsof命令,但是普通用户执行会显示“permission denied”
我总结一下lsof指令的用法:
lsof abc.txt 显示开启文件abc.txt的进程
lsof -i :22 知道22端口现在运行什么程序
lsof -c abc 显示abc进程现在打开的文件
lsof -g gid 显示归属gid的进程情况
lsof +d /usr/local/ 显示目录下被进程开启的文件
lsof +D /usr/local/ 同上,但是会搜索目录下的目录,时间较长
lsof -d 4 显示使用fd为4的进程
lsof -i 用以显示符合条件的进程情况
语法: lsof -i[46] [protocol][@hostname|hostaddr][:service|port]
46 --> IPv4 or IPv6
protocol --> TCP or UDP
hostname --> Internet host name
hostaddr --> IPv4位置
service --> /etc/service中的 service name (可以不只一个)
port --> 端口号 (可以不只一个)
例子: TCP:25 - TCP and port 25
@1.2.3.4 - Internet IPv4 host address 1.2.3.4
tcp@ohaha.ks.edu.tw:ftp - TCP protocol hosthaha.ks.edu.tw service name:ftp
lsof -n 不将IP转换为hostname,缺省是不加上-n参数
例子: lsof -i tcp@ohaha.ks.edu.tw:ftp -n
lsof -p 12 看进程号为12的进程打开了哪些文件
lsof +|-r [t] 控制lsof不断重复执行,缺省是15s刷新
-r,lsof会永远不断的执行,直到收到中断信号
+r,lsof会一直执行,直到没有档案被显示
例子:不断查看目前ftp连接的情况:lsof -i tcp@ohaha.ks.edu.tw:ftp -r
lsof -s 列出打开文件的大小,如果没有大小,则留下空白
lsof -u username 以UID,列出打开的文件

[root@tcx160 FILES]# lsof -i tcp:22COMMAND   PID USER   FD   TYPE DEVICE SIZE NODE NAMEsshd     3261 root    3u  IPv6   7301       TCP *:ssh (LISTEN)sshd    19692 root    3u  IPv6 348642       TCP 9.186.96.160:ssh->9.186.96.117:32914 (ESTABLISHED)



---------------------------这个帖子很好玩--------------------
可以看谁机器上有nginx就搞他一下,把他磁盘慢慢弄满,弄死他
转载http://bbs.chinaunix.net/thread-2316153-3-2.html
收藏一下:

这个问题可以这样来理解,咱们简单的做一个测试就拿Nginx程序来测试。
先看看磁盘的大小在说:

此时我们来多刷新一下页面让日志写入Log来增加磁盘空间
经过多次刷新后磁盘的文件大小已经变大。
日志文件路径在/var/log/host.access.log

此时在看看磁盘的大小情况

现在我们来删除日志文件
rm -f /var/log/host.access.log
这个时候你可以看的出来虽然删除了文件但是磁盘的空间一样没有释放。
原因是因为程序在打开了一个句柄后没有释放,始终会占用一定block,如果此时有请求会一直的的往下写。
我们在来看看程序的FD状态

好了具体的你在研究研究。详细的地方你参考一下 程序的一些读写机制吧/


-----------文件描述-------
http://www.cublog.cn/u3/116418/showart_2328888.html

热点排行