linux_netstat
一、简介
netstat命令用于显示各种网络相关信息,如网络链接,路由表,接口状态(interface statistics), masquerade连接,
多播成员(Multicast Memberships)等等
二、输出信息含义
-
执行netstat后,其输出结果为:
Active Internet connections (w/o servers) Proto Recv-Q Send-Q Local Address Foreign Address State tcp 0 2 210.34.6.89:telnet 210.34.6.96:2873 ESTABLISHED tcp 296 0 210.34.6.89:1165 210.34.6.84:netbios-ssn ESTABLISHED tcp 0 0 localhost.localdom:9001 localhost.localdom:1162 ESTABLISHED tcp 0 0 localhost.localdom:1162 localhost.localdom:9001 ESTABLISHED tcp 0 80 210.34.6.89:1161 210.34.6.10:netbios-ssn CLOSE Active UNIX domain sockets (w/o servers) Proto RefCnt Flags Type State I-Node Path unix 1 [ ] STREAM CONNECTED 16178 @000000dd unix 1 [ ] STREAM CONNECTED 16176 @000000dc unix 9 [ ] DGRAM 5292 /dev/log unix 1 [ ] STREAM CONNECTED 16182 @000000df
-
从整体上看,netstat的输出结果可以分为两个部分:
- 一个是active internet connections,称为有源tcp连接,其中'Recv-Q'和'Send-Q'指%OA的是接收队列和发送队列。这些数字一般都应该是0,如果不是则表示软件包正在队列中堆积。这种情况只能在非常少的情况见到。
- 另一个是active unix domain sockets, 称为有源unix域套接口(和网络套接字一样,但是只能用于本机通信,性能可以提高一倍)。proto显示连接使用的协议,refcnt表示连接到本套接口上的进程号,Types显示套接口的类型,state显示套接口当前的状态,path表示连接到套接口的其他进程使用的路经名。
三、常见参数
- -a (all)显示所有选项,默认不显示LISTEN相关
- -u (udp)仅显示udp相关选项
- -n 拒绝显示别名,能显示数字的全部转化成数字
- -l 仅列出有在listen(监听)的服务状态
- -p 显示建立相关链接的程序名
- -r 显示路由信息,路由表
- -e 显示扩展信息,例如uid等
- -s 按各个协议进行统计
- -c 每隔一个固定时间,执行该netstat命令
提示:listen和listening的状态只有用-a或-l才能看到
四、实例
-
查看80端口的占用情况:
lsof -i:80
或者:
netstat -apn | grep 80
上面的命令执行之后可以显示进程号,找到进程号以后,再使用以下命令查看详细信息:
ps -aux | grep <进程号>
附:
- windows下查看端口占用命令:
netstat -ano | findstr 80
- windows下查看进程列表命令:
tasklist