- netstat/lsof
- netstat命令用于显示与IP、TCP、UDP和ICMP协议相关的统计数据,一般用于检验本机各端口的网络连接情况
- -a 显示一个所有的有效连接信息列表(包括已建立的连接,也包括监听连接请求的那些连接)
- -n 显示所有已建立的有效连接
- -t tcp协议
- -u udp协议
- -l 查询正在监听的程序
- -p 显示正在使用socket的程序识别码和程序名称
- 例如:netstat -ntupl|grep processname
- 如何只查询tomcat的连接?
- netstat -na|grep ESTAB |grep 80 |wc-l
- netstat -na|grep ESTAB |grep 8080 |wc-l
- 常用端口介绍:
- 端口:21
- 服务:FTP服务器所开放的端口,用于上传、下载。
- 端口: 22
- 服务:ssh
- 端口: 80
- 服务:HTTP 用于网页浏览
- 端口:389
- 服务:LDAP ILS 轻型目录访问协议和NetMeetingInternet Locator Server
- 端口:443
- 服务:网页浏览端口 能提供加密和通过安全端口传输的另一种HTTP
- 端口:8080
- 服务:代理端口
- 打开终端,执行如下命令,查看各进程占用端口情况:
- # ps -ef|wc -l //查看后台运行的进程总数
- # ps -fu csvn //查看csvn进程
- # netstat -lntp //查看开启了哪些端口
- # netstat -r //本选项可以显示关于路由表的信息
- # netstat -a //本选项显示一个所有的有效连接信息列表
- # netstat -an|grep 8080
- # netstat -na|grep -i listen //可以看到目前系统侦听的端口号
- # netstat -antup //查看已建立的连接进程,所占用的端口。
- netstat -anp|grep1487
- lsof -i:1487
- 查看哪些进程打开了指定端口1487
- 关闭端口实际上是关闭其对应的服务,比如80端口是HTTPD 关闭80端口可以通过关闭httpd服务来实现
- 每个端口都有一个守护进程,kill掉这个守护进程就可以了
- 主机的端口分为监听端口与随机可用的高级端口
- 监听端口:监听端口就是主机开启了哪些服务,这个服务会在linux系统里启用一个端口来监听客户端的请求
- 随机可用的高级端口:
- linux要向某个主机请求服务时,linux主机需要启用一个端口来对外连接linux会随机去用一个未被使用且端口号大于1024的端口进行连接
- 只有root用户可以开启1-1024端口表明拥有root权限
- netstat-n 显示连接状态
- netstat-tl 显示当前正在监听的服务名称
- linux是一个列出当前系统打开文件的工具,在linux环境下,任何事物都以文件的形式存在。
- lsof输出信息 即可显示系统打开的文件默认显示所有进程打开的所有文件
- lsof filename 显示打开指定文件的所有进程
- lsof -c string 显示command列中包含指定字符的进程所有打开的文件
- lsof -u username 显示所属user进程打开的文件
- lsof -g gid 显示归属gid的进程情况
- lsof -i 显示符合条件的进程情况
- lsof -d 显示指定文件描述符的进程
- lsof -a 标示两个参数都必须满足时才显示结果
- 例如: lsof-i:1487
- 查看所属root用户进程所打开的文件类型为txt的文件:
- lsof -a -u root -d txt
- lsof使用实例
- 1.查找使用文件系统
- 卸载文件系统时,如果文件系统中有任何打开的文件,就会出错。可以通过lsof可以找出那些进程在使用当前卸载的文件系统
- # lsof /GTES11/
- COMMAND PID USER FD TYPE DEVICE SIZE NODE NAME
- bash 4208 root cwd DIR 3,1 40962 /GTES11/
- vim 4230 root cwd DIR 3,1 40962 /GTES11/
- 2.恢复删除的文件
- 当linux计算机受到入侵时,常见的情况是日志文件被删除,管理错误也会导致意外删除重要的文件。
- 当进程打开了某个文件时,只要该进程保持打开该文件时,即使删除,依然存在于磁盘上。这意味着,进程并不知道文件已被删除,在/proc目录下,其中包含了反映内核和进程树的各种文件。
- 当系统中的某个文件被意外地删除了,只要这个时候系统中还有进程正在访问文件,可以通过lsof从/proc目录下恢复该文件
- 使用lsof来查看当前是否有进程打开/var/logmessages文件
- # lsof |grep /var/log/messages syslogd 1283 root 2w REG 3,3 5381017 1773647 /var/log/messages (deleted) 从/proc/1283/fd/2
- 对于许多应用程序,尤其是日志文件和数据库,这种恢复删除文件的方法非常有用
时间: 2024-11-06 09:53:53