每个系统管理员都应该知道的 6 个 Linux 网络命令

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 作为系统管理员,我们每天都会跟各种各样的Linux命令打交道,其中网络相关的命令涉及的十分频繁,本文笔者就给大家分享一下Linux中6个常用的网络命令,强烈建议全部看完,我相信大多数你都是用过的。

作为系统管理员,我们每天都会跟各种各样的Linux命令打交道,其中网络相关的命令涉及的十分频繁,本文笔者就给大家分享一下Linux中6个常用的网络命令,强烈建议全部看完,我相信大多数你都是用过的。

1、ip

ip命令是每个管理员在日常工作中最基础的命令之一,从设置新系统和分配 IP 到对现有系统进行故障排除,都会去使用它。ip命令可以显示地址信息、路由,以及显示网络中的各种设备、接口和隧道。

语法如下:

ip <OPTIONS> <OBJECT> <COMMAND>

OBJECT 是最重要的部分,支持以下内容:

  • 地址:IPv4 或 IPv6地址
  • 隧道:基于 IP 的隧道
  • route:路由表条目
  • rule:路由策略数据库中的规则
  • vrf:管理虚拟路由和转发设备
  • xfrm:管理 IPSec 策略

显示分配给服务器上接口的 IP 地址:

[root@wljslmz ~]# ip address show 

将 IP 分配给接口,例如enps03:

[root@wljslmz ~]# ip address add 192.168.1.254/24 dev enps03

删除接口上的 IP:

[root@wljslmz ~]# ip address del 192.168.1.254/24 dev enps03

通过使接口eth0联机来更改接口的状态:

[root@wljslmz ~]# ip link set eth0 up

通过使接口eth0脱机来更改接口的状态:

[root@wljslmz ~]# ip link set eth0 down

通过更改eth0的 MTU 来更改接口的状态:

[root@wljslmz ~]# ip link set eth0 mtu 9000

通过为eth0启用混杂模式来更改接口的状态:

[root@wljslmz ~]# ip link set eth0 promisc on

通过可以在设备eth0上访问的本地网关 192.168.1.254 添加默认路由(适用于所有地址) :

[root@wljslmz ~]# ip route add default via 192.168.1.254 dev eth0

通过网关 192.168.1.254 添加到 192.168.1.0/24 的路由:

[root@wljslmz ~]# ip route add 192.168.1.0/24 via 192.168.1.254

添加到 192.168.1.0/24 的路由,可以在设备eth0上访问:

[root@wljslmz ~]# ip route add 192.168.1.0/24 dev eth0

通过网关 192.168.1.254 删除 192.168.1.0/24 的路由:

[root@wljslmz ~]# ip route delete 192.168.1.0/24 via 192.168.1.254

显示为 IP 10.10.1.4 采用的路由:

[root@wljslmz ~]# ip route get 10.10.1.4

2、mtr

mtr,英文全称Matt's traceroute,用作网络诊断和故障排除工具,结合了ping和traceroute命令的功能。

mtr命令可以显示从计算机到指定主机的路由,提供了大量关于每一跳的统计信息,例如响应时间和百分比。使用mtr命令,可以获得有关鲁豫的更多信息,并能够沿途查看有问题的设备。如果您看到响应时间突然增加或数据包丢失,那么很明显,某处存在错误链接。

命令的语法如下:

mtr <options> hostname/IP

让我们看一些常见的用例。

基本mtr命令显示统计信息,包括每个主机名的时间和损失百分比:

[root@wljslmz ~]# mtr wljslmz.cn

显示数字 IP 地址(如果使用-g,您将获得 IP 地址(数字)而不是主机名):

[root@wljslmz ~]# mtr -g wljslmz.cn

显示数字 IP 地址和主机名:

[root@wljslmz ~]# mtr -b wljslmz.cn

设置要发送的 ping 数:

[root@wljslmz ~]# mtr -c 10 wljslmz.cn

获取mtr命令结果报告:

[root@wljslmz ~]# mtr -r -c 10 wljslmz.cn > mtr-command-wljslmz-output

或者:

[root@wljslmz ~]# mtr -rw -c 10 wljslmz.cn > mtr-command-wljslmz-output

强制使用 TCP 而不是 ICMP:

[root@wljslmz ~]# mtr –tcp wljslmz.cn

强制使用 UDP 而不是 ICMP:

[root@wljslmz ~]# mtr –udp wljslmz.cn

设置最大跳数:

[root@wljslmz ~]# mtr -m 35 216.58.223.78

定义数据包大小:

[root@wljslmz ~]# mtr -r -s 50 wljslmz.cn

打印到 CSV 输出:

[root@wljslmz ~]# mtr –csv wljslmz.cn

打印到 XML 输出:

[root@wljslmz ~]# mtr –xml wljslmz.cn

3、tcpdump

tcpdump命令用于捕获和显示数据包。

您可以使用以下命令进行安装tcpdump:

[root@wljslmz ~]# dnf install -y tcpdump

在开始任何捕获之前,您需要知道 tcpdump可以使用哪些接口:

[root@wljslmz ~]# tcpdump -D

  1 eth0
  2 nflog
  3 nfqueue
  4 usbmon1
  5 any
  6 lo (Loopback)

如果要捕获eth0上的流量,可以使用tcpdump -i eth0示例输出启动它:

[root@wljslmz ~]# tcpdump -i eth0
[root@wljslmz ~]# tcpdump -i eth0 -c 10

捕获进出一台主机的流量

您可以过滤掉来自特定主机的流量。例如,要查找来自和去往 8.8.8.8 的流量,请使用以下命令:

[root@wljslmz ~]# tcpdump -i eth0 -c 10 host 8.8.8.8

对于来自 8.8.8.8 的流量,请使用:

[root@wljslmz ~]# tcpdump -i eth0 src host 8.8.8.8

对于去往 8.8.8.8 的出站流量,请使用:

[root@wljslmz ~]# tcpdump -i eth0 dst host 8.8.8.8

捕获进出网络的流量

还可以使用以下命令捕获进出特定网络的流量:

[root@wljslmz ~]# tcpdump -i eth0 net 10.1.0.0 mask 255.255.255.0

或者:

[root@wljslmz ~]# tcpdump -i eth0 net 10.1.0.0/24

还可以根据源或目标进行过滤。

基于来源(流量来自):

[root@wljslmz ~]# tcpdump -i eth0 src net 10.1.0.0/24

基于目的地(去往的流量):

[root@wljslmz ~]# tcpdump -i eth0 dst net 10.1.0.0/24

捕获进出端口号的流量

仅捕获 DNS 端口 53 流量:

[root@wljslmz ~]# tcpdump -i eth0 port 53

对于特定的主机,

[root@wljslmz ~]# tcpdump -i eth0 host 8.8.8.8 and port 53

要仅捕获 HTTPS 流量,

[root@wljslmz ~]# tcpdump -i eth0 -c 10 host www.wljslmz.cn and port 443

要捕获除端口 80 和 25 之外的所有端口,

[root@wljslmz ~]# tcpdump -i eth0 port not 53 and not 25

4、netstat

netstat用于打印网络连接、路由表、接口统计信息、伪装连接和多播成员资格的工具。该实用程序是 net-tool 包的一部分,有点像ifconfig,在新的 iproute2 包中,该ss工具用于实现相同的目标。

如果netstat在您的系统上找不到,请使用以下命令安装它:

[root@wljslmz ~]# dnf install net-tools

大多数用法netstat是不带任何参数:

[root@wljslmz ~]# netstat

对于高级用法,netstat使用选项扩展命令:

netstat <options>

或者一一列出选项:

netstat <option 1> <option 2> <option 3>

要列出所有端口和连接,无论其状态或协议如何,请使用:

[root@wljslmz ~]# netstat -a

通过运行列出所有 TCP 端口:

[root@wljslmz ~]# netstat -at

列出所有 UDP 端口:

[root@wljslmz ~]# netstat -au

要返回所有协议的仅侦听端口列表,请使用:

[root@wljslmz ~]# netstat -l

列出所有侦听 TCP 端口:

[root@wljslmz ~]# netstat -lt

通过运行仅返回侦听 UDP 端口:

[root@wljslmz ~]# netstat -lu

要列出 UNIX 侦听端口,请使用:

[root@wljslmz ~]# netstat -lx

无论协议如何,都显示所有端口的统计信息:

[root@wljslmz ~]# netstat -s

仅列出 TCP 端口的统计信息:

[root@wljslmz ~]# netstat -st

要查看列出的 PID/程序名称的 TCP 连接,请使用:

[root@wljslmz ~]# netstat -tp

要查找使用特定端口号的进程,请运行:

[root@wljslmz ~]# netstat -an | grep ‘:<port number>’

5、nslookup

使用该nslookup实用程序以交互方式查询 Internet 名称服务器,使用它来执行 DNS 查询并接收域名或 IP 地址,或任何其他特定的 DNS 记录。

查找域的 A 记录:

[root@wljslmz ~]# nslookup wljslmz.cn

检查域的 NS 记录:

[root@wljslmz ~]# nslookup -type=ns wljslmz.cn

要查找负责电子邮件交换的 MX 记录:

[root@wljslmz ~]# nslookup -query=mx wljslmz.cn

要查找域的所有可用 DNS 记录:

[root@wljslmz ~]# nslookup -type=any wljslmz.cn

要检查特定 DNS 服务器的使用(在这种情况下,使用特定名称服务器 ns1.nswljslmz.cn 进行查询):

[root@wljslmz ~]# nslookup wljslmz.cn ns1.nswljslmz.cn

检查 DNS A 记录以查看域的 IP 是一种常见做法,但有时您需要验证 IP 地址是否与特定域相关,为此,需要反向 DNS 查找。

[root@wljslmz ~]# nslookup 10.20.30.40

6、ping

ping 是一种工具,它通过发送 Internet 控制消息协议 (ICMP) 回显请求消息来验证与另一台 TCP/IP 计算机的 IP 级连接,将显示收到的相应 Echo Reply 消息以及往返时间,ping 是用于对连接性、可达性和名称解析进行故障排除的主要 TCP/IP 命令。

简单ping的命令只接受一个参数:您要验证的主机名或主机 IP 地址,一个简单的ping例子如下:

[root@wljslmz ~]# ping wljslmz.cn
PING wljslmz.cn (216.58.206.174) 56(84) bytes of data.
64 bytes from sof02s27-in-f14.1e100.net (216.58.206.174): icmp_seq=1 ttl=56 time=10.7 ms
64 bytes from sof02s27-in-f14.1e100.net (216.58.206.174): icmp_seq=2 ttl=56 time=10.2 ms
64 bytes from sof02s27-in-f14.1e100.net (216.58.206.174): icmp_seq=3 ttl=56 time=10.4 ms
64 bytes from sof02s27-in-f14.1e100.net (216.58.206.174): icmp_seq=4 ttl=56 time=10.4 ms
64 bytes from sof02s27-in-f14.1e100.net (216.58.206.174): icmp_seq=5 ttl=56 time=17.3 ms
^C
--- wljslmz.cn ping statistics ---
5 packets transmitted, 5 received, 0% packet loss, time 4005ms
rtt min/avg/max/mdev = 10.219/11.844/17.381/2.773 ms

按CTRL+C来停止刷屏,否则,它将ping一直持续到您停止为止。在每个ping命令之后,它将显示包含以下信息的摘要报告:

  • Min:从您端 ping 通的主机获得响应所需的最短时间。
  • Avg:从您端 ping 的主机获得响应所需的平均时间。
  • Max:从您端 ping 通的主机获得响应所需的最长时间。

此外,您还会看到 TTL,它代表生存时间。Ping 使用数字 TTL 值尝试通过路由路径到达给定的主机计算机。这也称为跃点限制。

通常,当您运行一个简单的ping命令而不传递任何其他参数时,Linux 将ping无限期地托管该主机,如果要ping主机十次,请使用以下命令:

[root@wljslmz ~]# ping -c 10 wljslmz.cn

使用选项-q仅查看ping统计摘要:

[root@wljslmz ~]# ping -c 10 wljslmz.cn

在具有多个接口的系统上,您可以指定ping要使用的命令的接口,如果系统同时具有eth0和eth1并且我想ping使用eth0:

[root@wljslmz ~]# ping -I eth0 wljslmz.cn

或者使用接口上的地址,假设接口为10.233.201.45作为IP:

[root@wljslmz ~]# ping -I 10.233.201.45 wljslmz.cn

您还可以ping将 IP 版本指定为 v4 或 v6:

[root@wljslmz ~]# ping -4 wljslmz.cn
[root@wljslmz ~]# ping -6 wljslmz.cn
目录
相关文章
|
3天前
|
Linux
Linux 常用文件查看命令
`cat` 命令用于连接文件并打印到标准输出,适用于快速查看和合并文本文件内容。常用示例包括:`cat file1.txt` 查看单个文件,`cat file1.txt file2.txt` 合并多个文件,`cat &gt; filename` 创建新文件,`cat &gt;&gt; filename` 追加内容。`more` 和 `less` 命令用于分页查看文件,`tail` 命令则用于查看文件末尾内容,支持实时追踪日志更新,如 `tail -f file.log`。
21 5
Linux 常用文件查看命令
|
1月前
|
Linux
Linux系统之whereis命令的基本使用
Linux系统之whereis命令的基本使用
77 24
Linux系统之whereis命令的基本使用
|
9天前
|
Linux
Linux od命令
本文详细介绍了Linux中的 `od`命令,包括其基本语法、常用选项和示例。通过这些内容,你可以灵活地使用 `od`命令查看文件内容,提高分析和调试效率。确保理解每一个选项和示例的实现细节,应用到实际工作中时能有效地处理各种文件查看需求。
43 19
|
20天前
|
缓存 Ubuntu Linux
Linux中yum、rpm、apt-get、wget的区别,yum、rpm、apt-get常用命令,CentOS、Ubuntu中安装wget
通过本文,我们详细了解了 `yum`、`rpm`、`apt-get`和 `wget`的区别、常用命令以及在CentOS和Ubuntu中安装 `wget`的方法。`yum`和 `apt-get`是高层次的包管理器,分别用于RPM系和Debian系发行版,能够自动解决依赖问题;而 `rpm`是低层次的包管理工具,适合处理单个包;`wget`则是一个功能强大的下载工具,适用于各种下载任务。在实际使用中,根据系统类型和任务需求选择合适的工具,可以大大提高工作效率和系统管理的便利性。
111 25
|
3月前
|
NoSQL 关系型数据库 MySQL
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
218 56
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
|
18天前
|
缓存 Linux
Linux查看内存命令
1. free free命令是最常用的查看内存使用情况的命令。它显示系统的总内存、已使用内存、空闲内存和交换内存的总量。 free -h • -h 选项:以易读的格式(如GB、MB)显示内存大小。 输出示例: total used free shared buff/cache available Mem: 15Gi 4.7Gi 4.1Gi 288Mi 6.6Gi 9.9Gi Swap: 2.0Gi 0B 2.0Gi • to
31 2
|
2月前
|
Linux 网络性能优化 网络安全
Linux(openwrt)下iptables+tc工具实现网络流量限速控制(QoS)
通过以上步骤,您可以在Linux(OpenWrt)系统中使用iptables和tc工具实现网络流量限速控制(QoS)。这种方法灵活且功能强大,可以帮助管理员有效管理网络带宽,确保关键业务的网络性能。希望本文能够为您提供有价值的参考。
152 28
|
2月前
|
网络协议 Unix Linux
深入解析:Linux网络配置工具ifconfig与ip命令的全面对比
虽然 `ifconfig`作为一个经典的网络配置工具,简单易用,但其功能已经不能满足现代网络配置的需求。相比之下,`ip`命令不仅功能全面,而且提供了一致且简洁的语法,适用于各种网络配置场景。因此,在实际使用中,推荐逐步过渡到 `ip`命令,以更好地适应现代网络管理需求。
61 11
|
2月前
|
Ubuntu Linux 开发者
Ubuntu20.04搭建嵌入式linux网络加载内核、设备树和根文件系统
使用上述U-Boot命令配置并启动嵌入式设备。如果配置正确,设备将通过TFTP加载内核和设备树,并通过NFS挂载根文件系统。
137 15
|
3月前
|
Linux Shell
Linux 10 个“who”命令示例
Linux 10 个“who”命令示例
136 14
Linux 10 个“who”命令示例