书法老师简介:netstat命令详解

来源:百度文库 编辑:中财网 时间:2024/04/28 05:47:56
2009-06-17 00:53 netstat命令的功能是显示网络连接、路由表和网络接口信息,能够让用户得知现在都有哪些网络连接正在运作。
该命令的一般格式为:
netstat [选项]
命令中各选项的含义如下:
-a 显示任何socket,包括正在监听的。
-c 每隔1秒就重新显示一遍,直到用户中断他。
-i 显示任何网络接口的信息,格式同“ifconfig -e”。
-n 以网络IP地址代替名称,显示出网络连接情形。
-r 显示核心路由表,格式同“route -e”。
-t 显示TCP协议的连接情况。
-u 显示UDP协议的连接情况。
-v 显示正在进行的工作。
netstat命令是个监控TCP/IP网络的很有用的工具,他能够显示路由表、实际的网络连接连同每一个网络接口设备的状态信息,在我的上执行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连接,另一个是Active UNIX domain
sockets,称为有源Unix域套接口。在上面的输出结果中,第一部分有5个输出结果,显示有源TCP连接的情况,而第二部分的输出结果显示的是
Unix域套接口的连接情况。Proto显示连接使用的协议;RefCnt表示连接到本套接口上的进程号;Types显示套接口的类型;State显示套
接口当前的状态;Path表示连接到套接口的其他进程使用的路径名。
事实上,netstat是若干个工具的汇总。
◆ 显示路由表
在随- r标记一起调用n e t s t a t时,将显示内核路由表,就像我们利用r o u t e命令相同。产生的输出如下:
[root@machine1 /]$ netstat -nr
Kernel IP routing table
Destination Gateway Genmask Flags MSS Window irtt Iface
210.34.6.0 0.0.0.0 255.255.255.128 U 0 0 0 eth0
192.168.1.0 0.0.0.0 255.255.255.0 U 0 0 0 eth1
127.0.0.0 0.0.0.0 255.0.0.0 U 0 0 0 lo
0.0.0.0 210.34.6.2 0.0.0.0 UG 0 0 0 eth0
- n 选项令netstat以点分四段式的形式输出IP地址,而不是象征性的主机名和网络名。假如想避免通过网络查找地址(比如避开DNS或NIS服务器),这一点是特别有用的。
netstat
输出结果中,第二列展示的是路由条目所指的网关,假如没有使用网关,就会出现一个星号(*)或0.0.0.0;第三列展示路由的概述,在为具体的I
P地址找出最恰当的路由时,内核将查看路由表内的任何条目,在对找到的路由和目标路由比较之前,将对I
P地址和genmask进行按位“和”计算;第四列显示了不同的标记,这些标记的说明如下:
■ G 路由将采用网关。
■ U 准备使用的接口处于“活动”状态。
■ H 通过该路由,只能抵达一台主机。
■ D 假如路由表的条目是由ICMP重定向消息生成的,就会配置这个标记。
■ M 假如路由表条目已被ICMP重定向消息修改,就会配置这个标记。
netstat输出结果的Iface显示该连接所用的物理网卡,如eth0表示用第一张,eth1表示用第二张。
◆ 显示接口特性
在随- i标记一起调用时, netstat将显示网络接口的当前配置特性。除此以外,假如调用时还带上-a选项,他还将输出内核中任何接口,并不只是当前配置的接口。netstat-i的输出结果是这样的:
[root@machine1 /]$ netstat -i
Kernel Interface table
Iface MTU Met RX-OK RX-ERR RX-DRP RX-OVR TX-OK TX-ERR TX-DRP TX-OVR Flg
eth0 1500 0 787165 0 0 1 51655 0 0 0 BRU
eth1 1500 0 520811 0 0 0 1986 0 0 0 BRU
lo 3924 0 1943 0 0 0 43 0 0 0 LRU
MTU
和Met字段表示的是接口的MTU和度量值值;RX和TX这两列表示的是已准确无误地收发了多少数据包( RX - OK / TX -
OK)、产生了多少错误(
RX-ERR/TX-ERR)、丢弃了多少包(RX-DRP/TX-DRP),由于误差而遗失了多少包(RX-OVR/TX-OVR);最后一列展示的是
为这个接口配置的标记,在利用ifconfig显示接口配置时,这些标记都采用一个字母。他们的说明如下:
■ B 已配置了一个广播地址。
■ L 该接口是个回送设备。
■ M 接收任何数据包(混乱模式)。
■ N 避免跟踪。
■ O 在该接口上,禁用A R P。
■ P 这是个点到点链接。
■ R 接口正在运行。
■ U 接口处于“活动”状态。
◆ 显示链接
netstat
支持用于显示活动或被动套接字的选项集。选项- t、- u、- w和-
x分别表示TCP、UDP、RAW和UNIX套接字连接。假如您另外还提供了一个-
a标记,还会显示出等待连接(也就是说处于监听模式)的套接字。这样就能够得到一份服务器清单,当前任何运行于系统中的任何服务器都会列入其中。
调用netstat -ta时,输出结果如下:
[root@machine1 /]$ netstat -ta
Active Internet connections (servers and established)
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 0 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 0 *:9001 *:* LISTEN
tcp 0 0 *:6000 *:* LISTEN
tcp 0 0 *:socks *:* LISTEN
tcp 0 80 210.34.6.89:1161 210.34.6.10:netbios-ssn CLOSE

面的输出表明部分服务器处于等待接入连接状态。利用-
a选项的话,netstat还会显示出任何的套接字。注意根据端口号,能够判断出一条连接是否是外出连接。对呼叫方主机来说,列出的端口号应该一直是个
整数,而对众所周知服务(well known
service)端口正在使用中的被呼叫方来说,netstat采用的则是取自/etc/services文档的象征性服务名。

Netstat 命令的使用技巧
  Netstat用于显示和IP、TCP、UDP和ICMP协议相关的统计数据,一般用于检验本机各端口的网络连接情况。
  
假如我们的电脑有时候接受到的数据报会导致出错数据删除或故障,我们不必感到奇怪,TCP/IP能够容许这些类型的错误,并能够自动重发数据报。但假如
累计的出错情况数目占到所接收的IP数据报相当大的百分比,或他的数目正迅速增加,那么我们就应该使用Netstat查一查为什么会出现这些情况了。

  1、netstat 的一些常用选项
  ?netstat ?s
  本选项能够按照各个协议分别显示其统计数据。假如我们的应用程式(如Web浏览器)运行速度比较慢,或不能显示Web页之类的数据,那么我们就能够用本选项来查看一下所显示的信息。我们需要仔细查看统计数据的各行,找到出错的关键字,进而确定问题所在。
  ?netstat ?e
  本选项用于显示关于以太网的统计数据。他列出的项目包括传送的数据报的总字节数、错误数、删除数、数据报的数量和广播的数量。这些统计数据既有发送的数据报数量,也有接收的数据报数量。这个选项能够用来统计一些基本的网络流量)。
  ?netstat ?r
  本选项能够显示关于路由表的信息,类似于后面所讲使用route print命令时看到的 信息。除了显示有效路由外,还显示当前有效的连接。
  ?netstat ?a
  本选项显示一个任何的有效连接信息列表,包括已建立的连接(ESTABLISHED),也包括监听连接请求(LISTENING)的那些连接。
  ?netstat ?n
  显示任何已建立的有效连接。
类别:Cmd | 添加到搜藏 | 浏览(487) | 评论 (0) 上一篇:net use命令详解    下一篇:Net Accounts命令详解 /**/相关文章: • Nbtstat和Netstat命令详解          • inux netstat 命令详解 • netstat命令详解(三)          • netstat命令详解(一) • LPI知识点滴之六-----linux nets...          • ARP,Tracert,Route与netStat命令... • Netstat命令详解3          • Netstat命令详解4 • [命令详解] Netstat命令用法          • windows dos 常用命令详解 ping ... 更多>>