这篇文章主要讲解了“Linux基础命令netstat的用法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Linux基础命令netstat的用法”吧!
netstat
netstat指令可以显示当前的网络连接、路由表、接口统计信息、伪装连接和多播成员资格等信息。
此命令的适用范围:RedHat、RHEL、Ubuntu、CentOS、SUSE、openSUSE、Fedora。
1、语法
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]
2、选项列表
选项 | 说明 |
--help | 显示帮助信息 |
--version | 显示版本信息 |
-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 | 停止修剪长地址 |
3、说明
netstat打印有关Linux网络子系统的信息。打印的信息类型由第一个参数控制
参数 | 说明 |
(none) | 默认情况下,netstat显示打开的套接字列表。如果不指定任何地址族,则将打印所有已配置地址家族的活动套接字。 |
-r | --route | 打印内核路由表 |
-g | --groups | 显示IPv4和IPv6的多播组成员信息 |
-i| --interfaces=iface, -I=iface | 显示所有网络接口的表,或指定的ifaces。 |
-M | --masquerade | 显示假连接列表。 |
-s | --statistics | 显示每个协议的汇总统计信息。 |
4、输出
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 | 这是连接到套接字上的相应进程的路径名。 |
5、文件
/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,静态。
6、实例
1)显示指定类型的网络信息
|
2)显示路由表
|
3)显示网卡状态
|
感谢各位的阅读,以上就是“Linux基础命令netstat的用法”的内容了,经过本文的学习后,相信大家对Linux基础命令netstat的用法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!