每个系统管理员都应该知道的 6 个 Linux 网络命令
sinye56 2024-11-13 12:31 26 浏览 0 评论
作为系统管理员,我们每天都会跟各种各样的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
相关推荐
- 程序员:JDK的安装与配置(完整版)_jdk的安装方法
-
对于Java程序员来说,jdk是必不陌生的一个词。但怎么安装配置jdk,对新手来说确实头疼的一件事情。我这里以jdk10为例,详细的说明讲解了jdk的安装和配置,如果有不明白的小伙伴可以评论区留言哦下...
- Linux中安装jdk并配置环境变量_linux jdk安装教程及环境变量配置
-
一、通过连接工具登录到Linux(我这里使用的Centos7.6版本)服务器连接工具有很多我就不一一介绍了今天使用比较常用的XShell工具登录成功如下:二、上传jdk安装包到Linux服务器jdk...
- 麒麟系统安装JAVA JDK教程_麒麟系统配置jdk
-
检查检查系统是否自带java在麒麟系统桌面空白处,右键“在终端打开”,打开shell对话框输入:java–version查看是否自带java及版本如图所示,系统自带OpenJDK,要先卸载自带JDK...
- 学习笔记-Linux JDK - 安装&配置
-
前提条件#检查是否存在JDKrpm-qa|grepjava#删除现存JDKyum-yremovejava*安装OracleJDK不分系统#进入安装文件目...
- Linux新手入门系列:Linux下jdk安装配置
-
本系列文章是把作者刚接触和学习Linux时候的实操记录分享出来,内容主要包括Linux入门的一些理论概念知识、Web程序、mysql数据库的简单安装部署,希望能够帮到一些初学者,少走一些弯路。注意:L...
- 测试员必备:Linux下安装JDK 1.8你必须知道的那些事
-
1.简介在Oracle收购Sun后,Java的一系列产品就被整合到Oracle官网中,打开官网乍眼一看也不知道去哪里下载,还得一个一个的摸索尝试,而且网上大多数都是一些Oracle收购Sun前,或者就...
- Linux 下安装JDK17_linux 安装jdk1.8 yum
-
一、安装环境操作系统:JDK版本:17二、安装步骤第一步:下载安装包下载Linux环境下的jdk1.8,请去官网(https://www.oracle.com/java/technologies/do...
- 在Ubuntu系统中安装JDK 17并配置环境变量教程
-
在Ubuntu系统上安装JDK17并配置环境变量是Java开发环境搭建的重要步骤。JDK17是Oracle提供的长期支持版本,广泛用于开发Java应用程序。以下是详细的步骤,帮助你在Ubuntu系...
- 如何在 Linux 上安装 Java_linux安装java的步骤
-
在桌面上拥抱Java应用程序,然后在所有桌面上运行它们。--SethKenlon(作者)无论你运行的是哪种操作系统,通常都有几种安装应用程序的方法。有时你可能会在应用程序商店中找到一个应用程序...
- Windows和Linux环境下的JDK安装教程
-
JavaDevelopmentKit(简称JDK),是Java开发的核心工具包,提供了Java应用程序的编译、运行和开发所需的各类工具和类库。它包括了JRE(JavaRuntimeEnviro...
- linux安装jdk_linux安装jdk软连接
-
JDK是啥就不用多介绍了哈,外行的人也不会进来看我的博文。依然记得读大学那会,第一次实验课就是在机房安装jdk,编写HelloWorld程序。时光飞逝啊,一下过了十多年了,挣了不少钱,买了跑车,娶了富...
- linux安装jdk,全局配置,不同用户不同jdk
-
jdk1.8安装包链接:https://pan.baidu.com/s/14qBrh6ZpLK04QS8ogCepwg提取码:09zs上传文件解压tar-zxvfjdk-8u152-linux-...
- 运维大神教你在linux下安装jdk8_linux安装jdk1.7
-
1.到官网下载适合自己机器的版本。楼主下载的是jdk-8u66-linux-i586.tar.gzhttp://www.oracle.com/technetwork/java/javase/downl...
- window和linux安装JDK1.8_linux 安装jdk1.8.tar
-
Windows安装JDK1.8的步骤:步骤1:下载JDK打开浏览器,找到JDK下载页面https://d.injdk.cn/download/oraclejdk/8在页面中找到并点击“下载...
- 最全的linux下安装JavaJDK的教程(图文详解)不会安装你来打我?
-
默认已经有了linux服务器,且有root账号首先检查一下是否已经安装过java的jdk任意位置输入命令:whichjava像我这个已经安装过了,就会提示在哪个位置,你的肯定是找不到。一般我们在...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- oracle忘记用户名密码 (59)
- oracle11gr2安装教程 (55)
- mybatis调用oracle存储过程 (67)
- oracle spool的用法 (57)
- oracle asm 磁盘管理 (67)
- 前端 设计模式 (64)
- 前端面试vue (56)
- linux格式化 (55)
- linux图形界面 (62)
- linux文件压缩 (75)
- Linux设置权限 (53)
- linux服务器配置 (62)
- mysql安装linux (71)
- linux启动命令 (59)
- 查看linux磁盘 (72)
- linux用户组 (74)
- linux多线程 (70)
- linux设备驱动 (53)
- linux自启动 (59)
- linux网络命令 (55)
- linux传文件 (60)
- linux打包文件 (58)
- linux查看数据库 (61)
- linux获取ip (64)
- linux进程通信 (63)