找回密码
 注册
关于网站域名变更的通知
查看: 286|回复: 1
打印 上一主题 下一主题

netstat

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2020-3-21 11:15 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x

1 `: W# l" d" t2 I+ u) z; Rnetstat命令是一个监控TCP/IP网络的非常有用的工具,它可以显示路由表、实际的网络连接以及每一个网络接口设备的状态信息,6 x7 F9 F+ {% Z
语  法:netstat [-acCeFghilMnNoprstuvVwx][-A网络类型>][--ip]4 k7 ?- x5 l+ s! \
补充说明:利用netstat指令可让你得知整个Linux系统的网络情况。
7 D( s; k$ ^+ B/ Q( ]. T4 P: p' U3 l参  数:
% _2 `! V# }3 u- g9 J# P-a或--all   显示所有连线中的Socket。
1 H" d% A; d' v  C- y-A网络类型>或--网络类型>   列出该网络类型连线中的相关地址。/ l: ~. c! u8 {' L: k+ Y
-c或--continuous   持续列出网络状态。
$ k0 W: `  ?" g7 ~) [0 A6 F-C或--cache   显示路由器配置的快取信息。7 [# O' Y' k$ ]# S  m' Z6 N( y
-e或--extend   显示网络其他相关信息。
* @+ Z* h0 e6 P) M7 I2 H$ h9 u-F或--fib   显示FIB。4 W: _: Y3 k( B. }, k# s
-g或--groups   显示多重广播功能群组组员名单。$ o- D) l* e/ j* R
-h或--help   在线帮助。
! `9 Q) J' t: x' a-i或--inteRFaces   显示网络界面信息表单。
- D; ]5 W& E+ ~  C; _. R-l或--listening   显示监控中的服务器的Socket。
# }. o& L3 [4 h- @0 C-M或--masquerade   显示伪装的网络连线。
" N2 P7 J$ R; S-n或--numeric   直接使用IP地址,而不通过域名服务器。9 \5 R5 B) N; ^$ S
-N或--netlink或--symbolic   显示网络硬件外围设备的符号连接名称。9 |' X: c. I8 r4 r
-o或--timers   显示计时器。% G* |7 K! ]8 o
-p或--programs   显示正在使用Socket的程序识别码和程序名称。- I% w* A5 ?6 x( O' V
-r或--route   显示Routing Table。7 j  h! _; z2 J9 g5 W0 e  i
-s或--statistice   显示网络工作信息统计表。2 @7 f0 V4 b4 u- n7 e0 b
-t或--tcp   显示TCP传输协议的连线状况。
7 s1 \3 O' ?  d9 @, ?. X4 b" e- F-u或--udp   显示UDP传输协议的连线状况。
/ u/ c) k: m& g$ |. |3 j-v或--verbose   显示指令执行过程。
, T5 \  O! G+ `4 m; B! Y-V或--version   显示版本信息。8 o5 |; `. f4 ?3 P) J( V
-w或--raw   显示RAW传输协议的连线状况。
) u: c( _- \6 W3 Q-x或--unix   此参数的效果和指定"-A unix"参数相同。
0 a4 _* z3 b" s  ?) D7 M4 d" |--ip或--inet   此参数的效果和指定"-A inet"参数相同。. h' \* v+ o: l

( z8 i$ p! G' T: t7 i, X6 t- o1) netstat -tl    -nltp+ T% f9 Z8 B+ ]6 j  F
查看当前tcp监听端口9 X, e4 c0 E7 @$ R, m8 Z
Active Internet connections (only servers)8 a0 t4 K* y7 Z9 A
Proto Recv-Q Send-Q Local Address           Foreign Address         State      
" j  v4 u2 Y* O6 c0 \7 ^+ b/ _tcp        0      0 *:rrac                  *:*                     LISTEN      ) u2 `5 W9 d' [$ g1 C8 l
tcp        0      0 *:34006                 *:*                     LISTEN      
# C1 r' N. w  Z/ e# `# p4 }......
* z& h" Y/ ?$ C) t! ]6 @
3 i0 |' }5 k: N7 T2) netstat -tlp
0 c8 D) t* R# K: K2 e+ u查看当前tcp监听端口, 需要显示监听的程序名,当不清楚mysql的监听端口时比较好用
; S+ H. U" @! K0 l2 y7 o7 k8 O' eActive Internet connections (only servers)
  L4 J: w4 y; K* C) HProto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name   
: P4 A! V& p% _: Atcp        0      0 *:rrac                  *:*                     LISTEN      -                          * s( ?6 }9 X! n
tcp        0      0 *:34006                 *:*                     LISTEN      23425/mysqld   
" l) X* v& T; I" M5 d$ o......
, X* Y. }7 K2 O5 @/ V/ ^$ m$ e' s  u) }; L9 h% T

2 w" }  w( e6 L2 s/ u$ e" |3) netstat -tl | grep 34006" n3 V; I0 E$ A9 W8 I
    只查看mysql的监听端口,当前启动的mysql端口为34006,明确知道mysql监听端口时使用5 k7 d) d1 U: b" L

/ @8 Y7 Z/ C( X" X2 m5 G4) netstat -ta | grep 34006
' g' }4 @1 \9 G5 h# i2 otcp        0      0 *:34006                 *:*                     LISTEN      
4 y5 W5 k, L5 B: z  ptcp        0      0 linux.local:34006       linux.local:41485       ESTABLISHED : o) j4 U5 ?3 t1 }7 s; N4 G
tcp        0      0 linux.local:34006       linux.local:41486       ESTABLISHED
5 V, r$ H. ^# g' V% c  {...
1 v1 A1 i3 o! M4 ]; h; S2 X0 P+ ytcp        0      0 10.3.2.35:41488         10.3.2.35:34006         ESTABLISHED
7 M: o4 A8 N1 j) M% l# Jtcp        0      0 10.3.2.35:41489         10.3.2.35:34006         ESTABLISHED
3 E5 c6 y( R4 L/ @tcp        0      0 10.3.2.35:41490         10.3.2.35:34006         ESTABLISHED
. ^# U/ g1 _) Z- J
/ L( t+ q+ G% S: \. ]# Q! y由于数据库和运用程序都放在同一台机器了,因此这里连接被显示了两次. 可以使用-p参数来显示PID,然后grep PID.
6 b; w7 u" A+ }" A) j0 Z4 w  {
1 ~" }; E+ I% ]! u3 [
' m/ r# H+ V/ r3 X4 F5) netstat -tap | grep 34006 | grep 234255 ^& _; k' j$ _. a
    23425是当前mysql的PID+ g( d7 P; U# R. i7 ?$ V3 H
tcp        0      0 *:34006                 *:*                     LISTEN      23425/mysqld        , v& F4 d5 l( @1 m
tcp        0      0 linux.local:34006       linux.local:41510       ESTABLISHED 23425/mysqld        $ x( q4 ~- t& n( N
tcp        0      0 linux.local:34006       linux.local:41511       ESTABLISHED 23425/mysqld        8 @7 Q* x- f! c( w
tcp        0      0 linux.local:34006       linux.local:41516       ESTABLISHED 23425/mysqld 从 整体上看,netstat的输出结果可以分为两个部分,一个是Active Internet connections,称为有源TCP连接,另一个是Active UNIX domain sockets,称为有源Unix域套接口。在上面的输出结果中,第一部分有5个输出结果,显示有源TCP连接的情况,而第二部分的输出结果显示的是 Unix域套接口的连接情况。Proto显示连接使用的协议;RefCnt表示连接到本套接口上的进程号;Types显示套接口的类型;State显示套 接口当前的状态;Path表示连接到套接口的其它进程使用的路径名。
0 q/ a0 d+ m2 {* ]% m* g事实上,netstat是若干个工具的汇总。
/ k# [8 \( i) Q" s! v1 }
" p* J3 I( `3 z/ _% F) e1 L6 X" U; D◆ 显示路由表
" R4 F7 i, E+ S- p2 _/ m在随- r标记一起调用n e t s t a t时,将显示内核路由表,就像我们利用r o u t e命令一样。产生的输出如下:+ c; B: i" @& ?& d( u$ C8 f5 Z

( s& J- O9 v, A4 W8 }[root@machine1 /]$ netstat -nr0 j* {- ?) c7 z) u4 Z
Kernel IP routing table
8 m$ }4 J* j  ^7 {3 {Destination Gateway Genmask Flags MSS Window irtt Iface
$ B& J& f. I  Z- Z: T7 k' y7 Q6 C210.34.6.0 0.0.0.0 255.255.255.128 U 0 0 0 eth0) R$ a4 r( o: W) p, }- T
192.168.1.0 0.0.0.0 255.255.255.0 U 0 0 0 eth1
2 ]) ?) n- x# X' V( f; ~127.0.0.0 0.0.0.0 255.0.0.0 U 0 0 0 lo0 G7 Q/ ^9 n; w7 m2 f# a3 d" g, E0 o
0.0.0.0 210.34.6.2 0.0.0.0 UG 0 0 0 eth02 k: G# G( d/ \/ `
0 R8 x1 G2 G- R/ ~7 z( ^' @! R0 _
- n 选项令netstat以点分四段式的形式输出IP地址,而不是象征性的主机名和网络名。如果想避免通过网络查找地址(比如避开DNS或NIS服务器),这一点是特别有用的。, ]+ m7 \3 D( ~" K  L8 s' {- U9 A- x
netstat 输出结果中,第二列展示的是路由条目所指的网关,如果没有使用网关,就会出现一个星号(*)或者0.0.0.0;第三列展示路由的概述,在为具体的I P地址找出最恰当的路由时,内核将查看路由表内的所有条目,在对找到的路由与目标路由比较之前,将对I P地址和genmask进行按位“与”计算;第四列显示了不同的标记,这些标记的说明如下:
) l# e; P# P6 |9 q; N0 x% e  u6 }# m! j2 R7 f, ~: f( b2 \/ ?- J
■ G 路由将采用网关。
& ^+ S( N" E1 d! ~0 l! b■ U 准备使用的接口处于“活动”状态。9 |3 C  c* G; }5 x
■ H 通过该路由,只能抵达一台主机。
3 M6 T) \% ]! s7 D( M+ _/ O■ D 如果路由表的条目是由ICMP重定向消息生成的,就会设置这个标记。$ G' W5 f; y' e5 {# B& I0 R
■ M 如果路由表条目已被ICMP重定向消息修改,就会设置这个标记。3 _" D( L& X  v! U5 ?9 w: W

% [3 U6 D' y) R4 m# ?9 f; bnetstat输出结果的Iface显示该连接所用的物理网卡,如eth0表示用第一张,eth1表示用第二张。
3 P( N3 h3 D' h9 U7 w& U" }  l" N- t7 x4 @8 Q
◆ 显示接口特性, J3 K$ A5 q. }' x
4 z* |/ t2 c* Y$ \; U  J3 v6 ~1 S
在随- i标记一起调用时, netstat将显示网络接口的当前配置特性。除此以外,如果调用时还带上-a选项,它还将输出内核中所有接口,并不只是当前配置的接口。netstat-i的输出结果是这样的:) V' s! L9 u7 i. {  F4 z( y/ k

9 h" ?5 ^- |  d) B: ^8 Z) `" G4 {[root@machine1 /]$ netstat -i
% Z  R+ M  A3 n4 N6 t) zKernel Interface table2 H6 b1 ~$ I' G& \2 X
Iface MTU Met RX-OK RX-ERR RX-DRP RX-OVR TX-OK TX-ERR TX-DRP TX-OVR Flg
* f; n1 X! O  o" Eeth0 1500 0 787165 0 0 1 51655 0 0 0 BRU2 S/ U" K1 r% ]2 r4 [% I. v
eth1 1500 0 520811 0 0 0 1986 0 0 0 BRU
- r8 ]! G# B+ s- E0 }lo 3924 0 1943 0 0 0 43 0 0 0 LRU5 x9 J5 d0 [* n0 j, d. v* n9 [
! @2 ^2 G- }4 U3 \1 g
MTU 和Met字段表示的是接口的MTU和度量值值;RX和TX这两列表示的是已经准确无误地收发了多少数据包( RX - OK / TX - OK)、产生了多少错误( RX-ERR/TX-ERR)、丢弃了多少包(RX-DRP/TX-DRP),由于误差而遗失了多少包(RX-OVR/TX-OVR);最后一列展示的是 为这个接口设置的标记,在利用ifconfig显示接口配置时,这些标记都采用一个字母。它们的说明如下:
4 \6 _" K' D( C" N. d. J* n* Z. T! S
■ B 已经设置了一个广播地址。
7 Z4 z. r) v$ g+ z) ^% l■ L 该接口是一个回送设备。
# M) q. E, N; V) F$ a■ M 接收所有数据包(混乱模式)。
, L& }' S! D: W: J8 a■ N 避免跟踪。/ B; P% m% K# P! e
■ O 在该接口上,禁用A R P。
+ Z1 ]9 ~! E, F■ P 这是一个点到点链接。
" I4 [5 T$ `. z/ h# s  H& G( Y2 f■ R 接口正在运行。
0 o# s. k7 u$ m$ s. Z■ U 接口处于“活动”状态。: t2 ]& g9 _- E7 v* L7 Q' P* [

6 l, i$ M- _: ?: G◆ 显示链接( U1 o6 L. H; h' [
netstat 支持用于显示活动或被动套接字的选项集。选项- t、- u、- w和- x分别表示TCP、UDP、RAW和UNIX套接字连接。如果你另外还提供了一个- a标记,还会显示出等待连接(也就是说处于监听模式)的套接字。这样就可以得到一份服务器清单,当前所有运行于系统中的所有服务器都会列入其中。
! A, T3 R) l: W+ N
  e$ z% i& h  Z  y& M4 b( o- @调用netstat -ta时,输出结果如下:- V  d/ x3 k5 S& }( m
/ ]. _9 \. G2 C: p" M8 s3 m$ Z, q
[root@machine1 /]$ netstat -ta
* S' c" V5 o% Q! _7 d4 U* hActive Internet connections (servers and established)
; _# c5 G, K4 lProto Recv-Q Send-Q Local Address Foreign Address State
; {( C, R7 h, G, O, |3 L. m/ z6 Z% r/ ftcp 0 2 210.34.6.89:telnet 210.34.6.96:2873 ESTABLISHED
8 _0 }5 ~" h+ X6 `0 a% B* y' ktcp 0 0 210.34.6.89:1165 210.34.6.84:netbios-ssn ESTABLISHED2 C- O4 X- ?+ k6 S
tcp 0 0 localhost.localdom:9001 localhost.localdom:1162 ESTABLISHED0 b. N$ d* m$ `# `/ H( [
tcp 0 0 localhost.localdom:1162 localhost.localdom:9001 ESTABLISHED' u0 Y3 V' ~/ B( h
tcp 0 0 *:9001 *:* LISTEN
  L: `! \; [( Atcp 0 0 *:6000 *:* LISTEN  z; I+ L; J) P# v7 s5 I' Z) {
tcp 0 0 *:socks *:* LISTEN
  S" m( D: p4 |4 i$ Jtcp 0 80 210.34.6.89:1161 210.34.6.10:netbios-ssn CLOSE
' }& w% [# a% @8 w# z+ D
& ?* C0 Q5 j$ K/ e; L上 面的输出表明部分服务器处于等待接入连接状态。利用- a选项的话,netstat还会显示出所有的套接字。注意根据端口号,可以判断出一条连接是否是外出连接。对呼叫方主机来说,列出的端口号应该一直是一个 整数,而对众所周知服务(well known service)端口正在使用中的被呼叫方来说,netstat采用的则是取自/etc/services文件的象征性服务名。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-11-25 15:22 , Processed in 0.187500 second(s), 24 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表