# netstat - 查看Linux中网络系统状态信息
netstat命令 用来打印Linux中网络系统的状态信息,可让你得知整个Linux系统的网络情况。
netstat指令可以显示当前的网络连接、路由表、接口统计信息、伪装连接和多播成员资格等信息。
# 适用范围
RedHat
RHEL
Ubuntu
CentOS
Debian
Deepin
SUSE
openSUSE
Fedora
Linux Mint
Alpine Linux
Arch Linux
# 语法
netstat [address_family_options] [--tcp|-t] [--udp|-u] [--raw|-w] [--listening|-l] [--all|-a] [--numeric|-n] [--numeric-hosts] [--numeric-ports] [--numeric-ports] [--symbolic|-N] [--extend|-e[--extend|-e]] [--timers|-o] [--program|-p] [--verbose|-v] [--continuous|-c] [delay]
netstat {--route|-r} [address_family_options] [--extend|-e[--extend|-e]] [--verbose|-v] [--numeric|-n] [--numeric-hosts] [--numeric-ports] [--numeric-ports] [--continuous|-c] [delay]
netstat {--interfaces|-I|-i} [iface] [--all|-a] [--extend|-e] [--verbose|-v] [--program|-p] [--numeric|-n] [--numeric-hosts] [--numeric-ports] [--numeric-ports] [--continuous|-c] [delay]
netstat {--groups|-g} [--numeric|-n] [--numeric-hosts] [--numeric-ports] [--numeric-ports] [--continuous|-c] [delay]
netstat {--masquerade|-M} [--extend|-e] [--numeric|-n] [--numeric-hosts] [--numeric-ports] [--numeric-ports] [--continuous|-c] [delay]
netstat {--statistics|-s} [--tcp|-t] [--udp|-u] [--raw|-w] [delay]
netstat {--version|-V}
netstat {--help|-h}
address_family_options:
[--protocol={inet,inet6,unix,ipx,ax25,netrom,ddp, ... }] [--unix|-x] [--inet|--ip] [--ax25] [--ipx] [--netrom] [--ddp]
# 选项
-v, --verbose # 显示执行过程
-n, --numeric # 直接显示数字ip
--numeric-hosts # 显示主机的数字地址,不影响端口和用户名
--numeric-ports # 显示端口,不影响主机和用户名
--numeric-users # 显示用户id,不影响主机和端口
-A, --protocol # 指定网络类型
-c, --continuous # 持续显示
-e, --extend # 显示其他附加信息
-o, --timers # 显示计时器
-p, --program # 显示正在使用的socket程序pid和名字
-l, --listen # 只显示监听的socket信息
-a, -all # 显示所有连接中的socket信息
-F # 显示FIB
-C # 显示路由的缓存
-Z, --context # 如果打开了SELinux,那么就打印SELinux的上下文
-T, --notrim # 停止修剪长地址
--help # 显示帮助文档
--version # 显示命令版本信息
# 说明
netstat打印有关Linux网络子系统的信息。打印的信息类型由第一个参数控制
参数 | 说明 |
---|---|
(none) | 默认情况下,netstat显示打开的套接字列表。如果不指定任何地址族,则将打印所有已配置地址家族的活动套接字。 |
-r | --route | 打印内核路由表 |
-g | --groups | 显示IPv4和IPv6的多播组成员信息 |
-i| --interfaces=iface , -I=iface | 显示所有网络接口的表,或指定的ifaces。 |
-M | --masquerade | 显示假连接列表。 |
-s | --statistics | 显示每个协议的汇总统计信息。 |
# 输出
Active Internet connections(TCP, UDP, raw) | 说明 |
---|---|
Proto | socket使用的协议,tcp, udp, raw。 |
Recv-Q | 连接到此套接字的用户程序未复制的字节数。 |
Send-Q | 远程主机未确认的字节数。 |
Local Address | 套接字的本地端的地址和端口号。除非指定了“--numeric (-n)“选项,否则套接字地址将解析为其规范主机名(FQDN),端口号将被转换为相应的服务名称。 |
Foreign Address | 套接字的远程端的地址和端口号。类似于“本地地址”。 |
State | socket的状态。由于在原始模式中没有状态,通常在UDP中也没有使用状态,因此这一列可以保留为空白。通常,这可以是几个值之一:ESTABLISHED,套接字有一个已建立的连接。SYN_SENT,套接字正在积极尝试建立连接。SYN_RECV,已从网络接收到连接请求。FIN_WAIT1,套接字关闭,连接正在关闭。FIN_WAIT2,连接被关闭,套接字正在等待来自远程端的关闭。TIME_WAIT,套接字在关闭后等待处理仍在网络中的数据包。CLOSED,没有使用套接字。CLOSE_WAIT,远程终端已关闭,等待套接字关闭。LAST_ACK,远程终端已关闭,套接字已关闭。等待确认LISTEN,套接字正在监听传入的连接。除非您指定“--listening”或“--all(-a)”选项,否则输出中不包含此类套接字。CLOSING,两个套接字都已关闭,但我们仍然没有发送所有数据。UNKNOWN,套接字的状态未知。 |
User | |
PID/Program name | |
Timer |
Active UNIX domain Sockets | 说明 |
---|---|
Proto | 套接字使用的协议(通常是Unix)。 |
RefCnt | 参考计数(即通过这个套接字附加的进程)。 |
Flags | 所显示的标志是SO_ACCEPTON (显示为ACC)、SO_WAITDATA(W)或SO_NOSPACE(N)。如果未连接套接字的相应进程正在等待连接请求,则在未连接套接字上使用SO_ACCECPTON。其他的标志不正常。 |
Type | 可能的几种值:SOCK_DGRAM,套接字以数据报(无连接)模式使用。SOCK_STREAM,这是一个流(连接)套接字。SOCK_RAW,套接字用作原始套接字。SOCK_RDM,这个服务提供可靠传递的消息。SOCK_SEQPACKET,这是一个顺序的数据包套接字。SOCK_PACKET,原始接口访问套接字。UNKNOWN,不知道的状态 |
State | FREE,套接字还没有分配LISTENING,套接字正在监听请求。CONNECTING,套接字正在尝试连接。CONNECTED,套接字已经连接。 DISCONNECTING,套接字断开连接。(empty),套接字没有连接到其他地方。UNKNOWN,未知的状态 |
PID/Program name | 打开套接字的进程ID(PID)和进程名。更多信息可在上面写的活动互联网连接部分获得。 |
Path | 这是连接到套接字上的相应进程的路径名。 |
# 相关文件
- /etc/services,服务翻译文件
- /proc,proc文件系统的挂载点,它允许访问内核状态。
- /proc/net/dev,设备信息。
- /proc/net/raw,raw套接字信息。
- /proc/net/tcp,tcp套接字信息。
- /proc/net/udp,udp套接字信息。
- /proc/net/igmp,IGMP多播信息。
- /proc/net/unix,Unix域名套接字信息。
- /proc/net/ipx,IPX套接字信息。
- /proc/net/ax25,AX25套接字信息。
- /proc/net/appletalk,DDP (appletalk) 套接字信息。
- /proc/net/nr,NET/ROM套接字信息
- /proc/net/route,IP路由信息。
- /proc/net/ax25_route,AX25路由信息。
- /proc/net/ipx_route,IPX路由信息。
- /proc/net/nr_nodes,NET/ROM 节点列表。
- /proc/net/nr_neigh,NET/ROM邻居。
- /proc/net/ip_masquerade,伪装连接。
- /proc/net/snmp,静态。
# 举例
显示指定类型的网络信息
[root@localhost ~]$ netstat -A inet #指定网络类型inet
Active Internet connections (w/o servers)
Proto Recv-Q Send-Q Local Address Foreign Address State
udp 0 0 192.168.0.113:33423 192.168.0.1:domain ESTABLISHED
udp 0 0 192.168.0.113:40242 192.168.1.1:domain ESTABLISHED
udp 0 0 192.168.0.113:50786 192.168.0.1:domain ESTABLISHED
显示路由表
[root@localhost ~]$ netstat –r #显示路由表
Kernel IP routing table
Destination Gateway Genmask Flags MSS Window irtt Iface
255.255.255.255 - 255.255.255.255 !H - - - -
192.168.1.0 * 255.255.255.0 U 0 0 0 eth0
224.0.0.0 - 255.255.255.0 ! - - - -
default 192.168.1.1 0.0.0.0 UG 0 0 0 eth0
显示网卡状态
[root@localhost ~]$ 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 121817 0 0 0 79998 0 0 0 BMRU
lo 16436 0 8374 0 0 0 8374 0 0 0 LRU