1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > Linux中使用netstat命令的基本操作 排查端口号的占用情况

Linux中使用netstat命令的基本操作 排查端口号的占用情况

时间:2020-02-12 01:19:29

相关推荐

Linux中使用netstat命令的基本操作 排查端口号的占用情况

Linux中netstat命令详解

Netstat是控制台命令,是一个监控TCP/IP网络的非常有用的工具,它可以显示路由表、实际的网络连接以及每一个网络接口设备的状态信息。Netstat用于显示与IP、TCP、UDP和ICMP协议相关的统计数据,一般用于检验本机各端口的网络连接情况。

linux上面排查某个端口号是否被占用

stat -anp |grep 端口号

如下,我以3306为例,netstat -anp |grep 3306(此处备注下,我是以普通用户操作,故加上了sudo,如果是以root用户操作,不用加sudo即可查看)

主要看监控状态为LISTEN表示已经被占用,最后一列显示被服务mysqld占用,查看具体端口号,只要有如图这一行就表示被占用了。

stat -nultp(此处不用加端口号)

该命令是查看当前所有已经使用的端口情况:

可以看出我的82端口没有被占用

stat -anp |grep 82查看82端口的使用情况,如图3:

​ 图3

可以看出并没有LISTEN那一行,所以就表示没有被占用。此处注意,图中显示的LISTENING并不表示端口被占用,不要和LISTEN混淆哦,查看具体端口时候,必须要看到tcp,端口号,LISTEN那一行,才表示端口被占用了

下面是一些常用的命令

常见参数

-a (all)显示所有选项,默认不显示LISTEN相关

-t (tcp)仅显示tcp相关选项

-u (udp)仅显示udp相关选项

-n 拒绝显示别名,能显示数字的全部转化成数字。

-l 仅列出有在 Listen (监听) 的服務状态

-p 显示建立相关链接的程序名

-r 显示路由信息,路由表

-e 显示扩展信息,例如uid等

-s 按各个协议进行统计

-c 每隔一个固定时间,执行该netstat命令。

提示:LISTEN和LISTENING的状态只有用-a或者-l才能看到

1、列出所有的连接(包括监听和未监听的)

netstat -a

$ netstat -aActive Internet connections (servers and established)Proto Recv-Q Send-Q Local Address Foreign Address Statetcp 00 enlightened:domain*:* LISTENtcp 00 localhost:ipp *:* LISTENtcp 00 enlightened.local:54750 li240-5.members.li:http ESTABLISHEDtcp 00 enlightened.local:49980 del01s07-in-f14.1:https ESTABLISHEDtcp6 00 ip6-localhost:ipp [::]:* LISTENudp 00 enlightened:domain*:* udp 00 *:bootpc*:* udp 00 enlightened.local:ntp *:* udp 00 localhost:ntp *:* udp 00 *:ntp *:* udp 00 *:58570 *:* udp 00 *:mdns *:* udp 00 *:49459 *:* udp6 00 fe80::216:36ff:fef8:ntp [::]:* udp6 00 ip6-localhost:ntp [::]:* udp6 00 [::]:ntp[::]:* udp6 00 [::]:mdns[::]:* udp6 00 [::]:63811 [::]:* udp6 00 [::]:54952 [::]:* Active UNIX domain sockets (servers and established)Proto RefCnt Flags Type State I-Node Pathunix 2[ ACC ]STREAMLISTENING12403 @/tmp/dbus-IDgfj3UGXXunix 2[ ACC ]STREAMLISTENING40202 @/dbus-vfs-daemon/socket-6nUC6CCx

上述命令会列出tcp,udp和unix协议下所有套接字的所有连接。

2、只列出tcp和udp协议的连接。

使用-at选项查看tcp协议的连接

$ netstat -atActive Internet connections (servers and established)Proto Recv-Q Send-Q Local Address Foreign Address Statetcp 00 enlightened:domain*:* LISTENtcp 00 localhost:ipp *:* LISTENtcp 00 enlightened.local:36310 del01s07-in-f24.1:https ESTABLISHEDtcp 00 enlightened.local:45038 a96-17-181-10.depl:http ESTABLISHEDtcp 00 enlightened.local:37892 ABTS-North-Static-:http ESTABLISHED.....

使用-au选项使用udp协议的连接:

# netstat -auActive Internet connections (servers and established)Proto Recv-Q Send-Q Local Address Foreign Address Stateudp 00 *:34660 *:* udp 00 enlightened:domain*:* udp 00 *:bootpc*:* udp 00 enlightened.local:ntp *:* udp 00 localhost:ntp *:* udp 00 *:ntp *:* udp6 00 fe80::216:36ff:fef8:ntp [::]:* udp6 00 ip6-localhost:ntp [::]:* udp6 00 [::]:ntp[::]:*

上面同时显示了 IPv4 和 IPv6 的连接。

3、禁用反向域名,加快查询的速度

默认情况下netstat会通过反向域名解析技术查找每个ip地址对应的主机名。这会降低查找的速度,如果你觉得iop地址已经足够,而没有必要知道主机名,就使用-n选项禁用域名解析功能。

$ netstat -antActive Internet connections (servers and established)Proto Recv-Q Send-Q Local Address Foreign Address Statetcp 00 127.0.1.1:53 0.0.0.0:*LISTENtcp 00 127.0.0.1:631 0.0.0.0:*LISTENtcp 00 192.168.1.2:49058 173.255.230.5:80 ESTABLISHEDtcp 00 192.168.1.2:33324 173.194.36.117:443ESTABLISHEDtcp6 00 ::1:631 :::*LISTEN

4、列出所有处于监听状态的 Sockets

只显示监听端口 netstat -l

# netstat -l Active Internet connections (only servers) Proto Recv-Q Send-Q Local Address Foreign Address State tcp 00 localhost:ipp *:* LISTEN tcp6 00 localhost:ipp [::]:* LISTEN udp 00 *:49119 *:*

只列出所有监听 tcp 端口 netstat -lt

# netstat -lt Active Internet connections (only servers) Proto Recv-Q Send-Q Local Address Foreign Address State tcp 00 localhost:30037 *:* LISTEN tcp 00 *:smtp *:* LISTEN tcp6 00 localhost:ipp [::]:* LISTEN

只列出所有监听 udp 端口 netstat -lu

# netstat -lu Active Internet connections (only servers) Proto Recv-Q Send-Q Local Address Foreign Address State udp 00 *:49119 *:* udp 00 *:mdns *:*

只列出所有监听 UNIX 端口 netstat -lx

# netstat -lx Active UNIX domain sockets (only servers) Proto RefCnt Flags Type State I-Node Path unix 2[ ACC ]STREAMLISTENING6294private/maildrop unix 2[ ACC ]STREAMLISTENING6203public/cleanup unix 2[ ACC ]STREAMLISTENING6302private/ifmail unix 2[ ACC ]STREAMLISTENING6306private/bsmtp

5、获取进程名、进程号以及用户ID

查看端口和连接的信息时,能查看到他们对应的进程名和进程号对系统管理员来说是非常有帮助的。举个栗子,Apache的http服务开启80端口,如果要查看http服务是否已经启动,或者http服务是由apache还是nginx启动的,这时候你可以看看进程号。

使用-p选项查看进程信息

~$ sudo netstat -nlptActive Internet connections (only servers)Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program nametcp 00 127.0.1.1:53 0.0.0.0:*LISTEN1144/dnsmasq tcp 00 127.0.0.1:631 0.0.0.0:*LISTEN661/cupsd tcp6 00 ::1:631 :::*LISTEN661/cupsd

使用-p选项时,netstat必须运行在root权限之下,不然他就不能得到运行在root权限下的进程名,而很多服务包括http和ftp都运行在root权限之下。

相比进程名和进程号而言,查看进程的拥有者会更有用。使用-ep选项可以同时查看进程名和用户名。

$ sudo netstat -ltpeActive Internet connections (only servers)Proto Recv-Q Send-Q Local Address Foreign Address State User Inode PID/Program nametcp 00 enlightened:domain*:* LISTENroot 11090 1144/dnsmasq tcp 00 localhost:ipp *:* LISTENroot 9755 661/cupsd tcp6 00 ip6-localhost:ipp [::]:* LISTENroot 9754 661/cupsd

上面列出tcp协议下的监听套接字,同时显示进程信息和一些额外的信息。

这些额外的信息包括用户名和进程的索引节点号。这个命令对网管来说很有用。

注意– 假如你将 -n 和-e选项一起使用,User 列的属性就是用户的 ID 号,而不是用户名。

6、打印统计数据

netstat可以打印网络统计数据,包括某个协议的收发包数量。

下面列出所有网络的统计情况:

$ netstat -sIp:32797 total packets received0 forwarded0 incoming packets discarded32795 incoming packets delivered29115 requests sent out60 outgoing packets droppedIcmp:125 ICMP messages received0 input ICMP message failed.ICMP input histogram:destination unreachable: 125125 ICMP messages sent0 ICMP messages failedICMP output histogram:destination unreachable: 125... OUTPUT TRUNCATED ...

如果想只打印tcp或udp协议的统计数据,只要加上对应的选项(-t和-u)即可。

7、显示内核路由信息

使用-r选项打印内核路由信息。打印出来的信息与route命令输出的信息一样。我们可以使用-n选项禁止域名解析。

$ netstat -rnKernel IP routing tableDestinationGateway Genmask Flags MSS Window irtt Iface0.0.0.0 192.168.1.10.0.0.0 UG 0 00 eth0192.168.1.00.0.0.0 255.255.255.0 U 0 00 eth0

8、打印网络接口

netstat也能打印网络接口信息,-i选项就是为这个功能而生。

$ netstat -iKernel Interface tableIface MTU Met RX-OK RX-ERR RX-DRP RX-OVR TX-OK TX-ERR TX-DRP TX-OVR Flgeth0 1500 03161100 0 27503000 BMRUlo 65536 0291300 02913000 LRU

上面输出的信息比较原始。我们将-e选项和-i选项搭配使用,可以输出用户友好的信息。

$ netstat -ieKernel Interface tableeth0Link encap:Ethernet HWaddr 00:16:36:f8:b2:64 inet addr:192.168.1.2 Bcast:192.168.1.255 Mask:255.255.255.0inet6 addr: fe80::216:36ff:fef8:b264/64 Scope:LinkUP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1RX packets:31682 errors:0 dropped:0 overruns:0 frame:0TX packets:27573 errors:0 dropped:0 overruns:0 carrier:0collisions:0 txqueuelen:1000 RX bytes:29637117 (29.6 MB) TX bytes:4590583 (4.5 MB)Interrupt:18 Memory:da000000-da020000 lo Link encap:Local Loopback inet addr:127.0.0.1 Mask:255.0.0.0inet6 addr: ::1/128 Scope:HostUP LOOPBACK RUNNING MTU:65536 Metric:1RX packets:2921 errors:0 dropped:0 overruns:0 frame:0TX packets:2921 errors:0 dropped:0 overruns:0 carrier:0collisions:0 txqueuelen:0 RX bytes:305297 (305.2 KB) TX bytes:305297 (305.2 KB)

上面的输出信息与ifconfig输出的信息一样。

9、netstat持续输出

我么可以使用netstat的-c选项持续输出信息。

$ netstat -ct

这个命令可以持续输出tcp协议信息。

10、显示多播组信息

选项-g会输出ipv4和ipv6的多播组信息

$ netstat -gIPv6/IPv4 Group MembershipsInterface RefCnt Group--------------- ------ ---------------------lo 1all-eth0 1224.0.0.251eth0 1all-lo 1ip6-allnodeslo 1ff01::1eth0 1ff02::fbeth0 1ff02::1:fff8:b264eth0 1ip6-allnodeseth0 1ff01::1wlan0 1ip6-allnodeswlan0 1ff01::1

打印active 的状态连接

active状态的套接字连接用“ESTABLISHED”字段表示,所以我们可以使用grep命令获取active状态的连接:

$ netstat -atnp | grep ESTA(Not all processes could be identified, non-owned process infowill not be shown, you would have to be root to see it all.)tcp 00 192.168.1.2:49156 173.255.230.5:80 ESTABLISHED 1691/chrometcp 00 192.168.1.2:33324 173.194.36.117:443ESTABLISHED 1691/chrome

配合watch命令监听active状态的连接:

$ watch -d -n0 "netstat -atnp | grep ESTA"

查看服务是否在运行

如果想看看http,smtp或ntp服务是否在运行,使用grep

$ sudo netstat -aple | grep ntpudp 00 enlightened.local:ntp *:* root 17430 1789/ntpd udp 00 localhost:ntp *:* root 17429 1789/ntpd udp 00 *:ntp *:* root 17422 1789/ntpd udp6 00 fe80::216:36ff:fef8:ntp [::]:*root 17432 1789/ntpd udp6 00 ip6-localhost:ntp [::]:*root 17431 1789/ntpd udp6 00 [::]:ntp[::]:*root 17423 1789/ntpd unix 2[ ] DGRAM17418 1789/ntpd

11. IP和TCP分析

查看连接某服务端口最多的的IP地址

wss8848@ubuntu:~$ netstat -nat | grep "192.168.1.15:22" |awk '{print $5}'|awk -F: '{print $1}'|sort|uniq -c|sort -nr|head - 221.136.168.363 154.74.45.2422 78.173.31.2362 62.183.207.982 192.168.1.142 182.48.111.2152 124.193.219.342 119.145.41.22 114.255.41.301 75.102.11.99

TCP各种状态列表

wss8848@ubuntu:~$ netstat -nat |awk '{print $6}'established)ForeignLISTENTIME_WAITESTABLISHEDTIME_WAITSYN_SENT

先把状态全都取出来,然后使用uniq -c统计,之后再进行排序。

wss8848@ubuntu:~$ netstat -nat |awk '{print $6}'|sort|uniq -c143 ESTABLISHED1 FIN_WAIT11 Foreign1 LAST_ACK36 LISTEN6 SYN_SENT113 TIME_WAIT1 established)

最后的命令如下:

netstat -nat |awk '{print $6}'|sort|uniq -c|sort -rn分析access.log获得访问前10位的ip地址 awk '{print $1}' access.log |sort|uniq -c|sort -nr|head -10

参考:/item/Netstat/527020?fr=aladdin

参考:/hindy/p/7249234.html

参考:/netstat-common-method.html

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。