Linux 中的 `netstat` 命令 | Linux `netstat` 命令详解

简介: 【8月更文挑战第20天】

netstat(网络统计信息)是一个用于显示网络连接、路由表和网络接口统计信息的命令行工具。它在 Linux 系统中广泛用于网络故障排除、监控和分析网络活动。尽管在某些 Linux 发行版中,netstat 已被 ssip 等工具所取代,但它仍然是一个强大的工具,可以提供有价值的网络信息。本文将详细介绍 netstat 命令的用法及其各个选项,并提供一些实用的示例。

一、netstat 命令基本概述

netstat 命令用于显示网络连接、监听端口、路由表以及网络接口的统计信息。基本命令格式如下:

netstat [选项]

以下是 netstat 常用选项的介绍:

  • -a:显示所有网络连接和监听端口。
  • -t:显示 TCP 连接。
  • -u:显示 UDP 连接。
  • -l:仅显示正在监听的端口。
  • -n:以数字形式显示地址和端口号,而不是尝试解析主机名和服务名称。
  • -p:显示哪个进程正在使用该端口。
  • -r:显示路由表。
  • -i:显示网络接口的统计信息。
  • -s:显示网络统计信息。
  • -c:持续输出结果,每隔一段时间更新一次。

二、查看网络连接

  1. 显示所有连接和监听端口

    使用 -a 选项显示所有的网络连接和监听端口:

    netstat -a
    

    这个命令列出所有 TCP 和 UDP 的连接及其状态,包括 ESTABLISHED(已建立连接)、LISTEN(监听中)、TIME_WAIT(连接关闭后的等待状态)等。

  2. 仅显示 TCP 连接

    使用 -t 选项只显示 TCP 连接:

    netstat -t
    

    这个命令只显示 TCP 连接,过滤掉 UDP 连接。

  3. 仅显示 UDP 连接

    使用 -u 选项只显示 UDP 连接:

    netstat -u
    

    这个命令只显示 UDP 连接,过滤掉 TCP 连接。

  4. 查看正在监听的端口

    使用 -l 选项显示所有正在监听的端口:

    netstat -l
    

    这个命令显示所有监听中(LISTEN 状态)的端口,无论是 TCP 还是 UDP。

三、显示数字地址和进程信息

  1. 以数字形式显示地址和端口

    使用 -n 选项以数字形式显示地址和端口号,而不解析主机名和服务名称:

    netstat -n
    

    这个命令将显示 IP 地址和端口号,而不是解析为主机名和服务名称,通常有助于提高命令执行速度。

  2. 显示进程信息

    使用 -p 选项显示每个连接或监听端口所对应的进程信息:

    netstat -p
    

    这个命令显示每个网络连接或监听端口的进程 ID 和进程名称,需要有相应的权限(如 root 用户)才能查看所有进程的信息。

四、显示路由表和接口统计信息

  1. 显示路由表

    使用 -r 选项显示路由表:

    netstat -r
    

    这个命令列出系统的路由表信息,包括目的网络、网关、路由标志、接口等。

  2. 显示网络接口的统计信息

    使用 -i 选项显示网络接口的统计信息:

    netstat -i
    

    这个命令显示每个网络接口的统计信息,如接收和发送的字节数、包数、错误数等。

五、显示网络统计信息

  1. 显示网络统计信息

    使用 -s 选项显示网络统计信息:

    netstat -s
    

    这个命令提供网络协议(如 TCP、UDP、IP)的统计数据,包括接收和发送的包数、错误数、丢弃的包等信息。

  2. 持续输出网络状态

    使用 -c 选项持续输出网络状态,每隔一定时间更新一次:

    netstat -c
    

    这个命令持续显示网络连接和接口的状态,通常用于实时监控网络活动。

六、常见的 netstat 用例

  1. 检查服务器的开放端口

    查看服务器上哪些端口正在监听:

    netstat -tuln
    

    这个命令结合了 -t(TCP)、-u(UDP)、-l(监听)、-n(数字形式)选项,列出所有监听中的端口及其数字地址和端口号。

  2. 排查网络连接问题

    查看系统的网络连接状态,找出异常连接或状态:

    netstat -anp
    

    这个命令结合了 -a(所有连接)、-n(数字形式)、-p(进程信息)选项,显示所有网络连接和监听端口的详细信息及进程。

  3. 检查路由设置

    查看当前的路由表信息:

    netstat -r
    

    这个命令帮助检查和验证系统的路由配置。

  4. 监控网络接口的活动

    实时监控网络接口的流量和错误信息:

    netstat -i
    

    这个命令提供网络接口的详细统计信息,有助于监控网络接口的性能和健康状态。

七、netstat 与其他工具的比较

在现代 Linux 系统中,netstat 有时被 ssip 命令所替代。这些工具提供了更丰富和高效的网络信息。以下是它们的对比:

  • ss(Socket Statictics):比 netstat 更快,提供了更详细的套接字信息。示例命令:

    ss -tuln
    
  • ip:用于显示和管理网络接口、路由和地址等。示例命令:

    ip addr show
    

八、总结

netstat 是一个功能强大的网络诊断工具,用于显示网络连接、监听端口、路由表和接口统计信息。掌握 netstat 命令及其选项,可以有效地监控和管理系统的网络状态,帮助排查网络故障和优化网络性能。尽管有些新工具提供了更多功能和更高的效率,netstat 仍然是一个重要的网络诊断工具,尤其是在许多系统和场景中广泛使用。

目录
相关文章
|
14天前
|
Linux 网络安全 Python
linux后台运行命令screen的使用
linux后台运行命令screen的使用
50 2
linux后台运行命令screen的使用
|
14天前
|
Ubuntu Linux
查看Linux系统架构的命令,查看linux系统是哪种架构:AMD、ARM、x86、x86_64、pcc 或 查看Ubuntu的版本号
查看Linux系统架构的命令,查看linux系统是哪种架构:AMD、ARM、x86、x86_64、pcc 或 查看Ubuntu的版本号
124 3
|
19天前
|
存储 监控 安全
在Linux中,⼀个EXT3的文件分区,当使用touch test.file命令创建⼀个新文件时报错,报错的信息是提示磁盘已满,但是采用df -h命令查看磁盘大小时,只使用了,60%的磁盘空间,为什么会出现这个情况?
在Linux中,⼀个EXT3的文件分区,当使用touch test.file命令创建⼀个新文件时报错,报错的信息是提示磁盘已满,但是采用df -h命令查看磁盘大小时,只使用了,60%的磁盘空间,为什么会出现这个情况?
|
9天前
|
机器学习/深度学习 安全 网络协议
Linux防火墙iptables命令管理入门
本文介绍了关于Linux防火墙iptables命令管理入门的教程,涵盖了iptables的基本概念、语法格式、常用参数、基础查询操作以及链和规则管理等内容。
166 73
|
2天前
|
Linux Shell
Linux 中 Tail 命令的 9 个实用示例
Linux 中 Tail 命令的 9 个实用示例
21 6
Linux 中 Tail 命令的 9 个实用示例
|
7天前
|
Linux 应用服务中间件 nginx
|
3天前
|
机器学习/深度学习 安全 网络协议
Web安全-Linux网络命令
Web安全-Linux网络命令
8 1
|
8天前
|
Ubuntu Linux Shell
Linux系统命令 安装和文件相关命令
本文档详细介绍了Linux系统中的常用命令,包括软件安装卸载命令如`dpkg`和`apt-get`,压缩与解压命令如`gzip`、`bzip2`和`xz`,以及`tar`命令用于打包和解包。此外还介绍了文件分割命令`split`,文件操作命令如`cat`、`head`、`tail`、`more`、`less`等,管道命令和`wc`、`grep`、`find`、`cut`、`sort`、`uniq`、`diff`等实用工具。最后,文档还讲解了文件属性相关的命令如`chmod`、`chown`、`chgrp`以及创建硬链接和软链接的`ln`命令。
|
8天前
|
Linux Shell 网络安全
Linux 用户管理命令
本文详细介绍了Linux系统中的各类常用命令,包括用户管理(如`adduser`, `usermod`, `passwd`等)、系统操作(如关机、重启、注销)、磁盘管理(如`df`, `mkfs`, `mount`)及网络管理(如`ifconfig`, `ping`, `ssh`)等。通过具体示例展示了每个命令的基本用法和应用场景,帮助用户更好地理解和掌握Linux系统的管理和操作技巧。
|
8天前
|
存储 Ubuntu Linux
linux中的find 命令详细用法
本文介绍了如何将 `find` 命令与 `exec` 结合使用,通过具体示例展示了多种应用场景,如显示文件属性、重命名文件、收集文件大小、删除特定文件、执行工具、更改文件所有权和权限、收集 MD5 值等。文章还探讨了 `{} \;` 和 `{} +` 的区别,并演示了如何结合 `grep` 命令进行内容搜索。最后,介绍了如何在一个 `find` 命令中使用多个 `exec` 命令。这为 Linux 用户提供了强大的文件管理和自动化工具。