CentOS 7.3没有ifconfig命令要如何查看IP?

在管理和维护基于 CentOS 7.3 的服务器时,查看其 IP 地址是一项最基本且至关重要的操作,无论是进行远程连接、配置防火墙规则,还是排查网络故障,准确获取服务器的 IP 地址信息都是第一步,CentOS 7.3 作为一个稳定且广泛使用的企业级 Linux 发行版,提供了多种查看 IP 地址的方法,以适应不同用户的使用习惯和场景需求,本文将详细介绍几种主流且实用的方法,并对它们的输出信息进行解读,帮助您全面掌握在 CentOS 7.3 系统中查询网络配置的技巧。

CentOS 7.3没有ifconfig命令要如何查看IP?

使用 ip 命令:现代且推荐的方法

ip 命令是 iproute2 软件包的一部分,它取代了老旧的 net-tools(包含 ifconfig 命令),是现代 Linux 系统中用于显示和管理路由、网络设备、策略路由和隧道的主流工具,在 CentOS 7 及更高版本中,ip 命令是默认安装且首选的方法。

要查看所有网络接口的 IP 地址信息,可以在终端中执行以下命令:

ip addr

或者使用其更简短的别名形式:

ip a

执行命令后,您会看到类似以下的输出:

1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN qlen 1
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host
       valid_lft forever preferred_lft forever
2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:0c:29:4a:5b:6c brd ff:ff:ff:ff:ff:ff
    inet 192.168.1.100/24 brd 192.168.1.255 scope global dynamic ens33
       valid_lft 86394sec preferred_lft 86394sec
    inet6 fe80::20c:29ff:fe4a:5b6c/64 scope link
       valid_lft forever preferred_lft forever

输出信息解读:

  • 1: lo2: ens33:这是网络接口的编号和名称。lo 是环回接口(loopback),用于本机内部通信;ens33 是一个典型的以太网接口名称。
  • link/ether 00:0c:29:4a:5b:6c:这是接口的 MAC 地址(物理地址)。
  • inet 192.168.1.100/24:这是您要查找的 IPv4 地址。168.1.100 是具体的 IP,/24 表示子网掩码为 255.255.255.0。
  • brd 192.168.1.255:这是该网络的广播地址。
  • scope global dynamicglobal 表示此地址是全局有效的,可以从外部访问;dynamic 表示该地址是通过 DHCP 服务器动态获取的。
  • inet6 ...:这是 IPv6 地址信息。

使用 ifconfig 命令:传统经典的方法

对于许多从早期 Linux 版本过渡过来的管理员来说,ifconfig 命令依然非常熟悉,它属于 net-tools 软件包,需要注意的是,在最小化安装的 CentOS 7.3 系统中,net-tools 可能并未预装。

如果系统提示 command not found,您需要先安装它:

sudo yum install net-tools

安装完成后,直接输入 ifconfig 即可:

ifconfig

其输出示例如下:

CentOS 7.3没有ifconfig命令要如何查看IP?

ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 192.168.1.100  netmask 255.255.255.0  broadcast 192.168.1.255
        inet6 fe80::20c:29ff:fe4a:5b6c  prefixlen 64  scopeid 0x20<link>
        ether 00:0c:29:4a:5b:6c  txqueuelen 1000  (Ethernet)
        RX packets 12345  bytes 1234567 (1.1 MiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 6789  bytes 987654 (964.8 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10<host>
        loop  txqueuelen 1  (Local Loopback)
        RX packets 10  bytes 800 (800.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 10  bytes 800 (800.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

输出信息解读:

  • inet 192.168.1.100:IPv4 地址。
  • netmask 255.255.255.0:子网掩码。
  • broadcast 192.168.1.255:广播地址。
  • ether 00:0c:29:4a:5b:6c:MAC 地址。

ifconfig 的输出格式相对直观,但提供的信息(如 IPv6 的详细状态和作用域)不如 ip 命令丰富。

查看网络配置文件:深入系统层面

除了使用命令行工具动态查看,您还可以直接检查系统的网络配置文件来了解 IP 地址设置,这对于理解静态 IP 配置或排查启动时的网络问题非常有帮助。

CentOS 7.3 的网络配置脚本存放在 /etc/sysconfig/network-scripts/ 目录下,文件名通常为 ifcfg-<接口名>ifcfg-ens33

使用 catvi 命令查看该文件:

cat /etc/sysconfig/network-scripts/ifcfg-ens33

一个典型的 DHCP 配置文件内容如下:

TYPE=Ethernet
BOOTPROTO=dhcp
DEFROUTE=yes
PEERDNS=yes
PEERROUTES=yes
IPV4_FAILURE_FATAL=no
IPV6INIT=yes
IPV6_AUTOCONF=yes
IPV6_DEFROUTE=yes
IPV6_PEERDNS=yes
IPV6_PEERROUTES=yes
IPV6_FAILURE_FATAL=no
NAME=ens33
UUID=a1b2c3d4-e5f6-7890-1234-567890abcdef
ONBOOT=yes

如果服务器配置了静态 IP,文件内容则会包含 IPADDRNETMASKGATEWAYDNS1 等明确的参数,通过查看此文件,您可以确认 IP 地址是动态获取还是手动配置的。

方法对比与小编总结

为了更清晰地选择合适的方法,下表对上述几种方式进行了对比:

方法 命令 优点 缺点/注意事项
ip 命令 ip addrip a 信息最全面,现代标准,默认安装 输出格式对新手可能稍显复杂
ifconfig 命令 ifconfig 传统经典,输出简洁直观 可能需要手动安装 net-tools,功能已被 ip 取代
配置文件 cat /etc/sysconfig/network-scripts/ifcfg-<interface> 查看持久化配置,适合排查静态 IP 问题 无法反映动态获取的实时 IP,需要知道接口名

在 CentOS 7.3 中查看 IP 地址,首选 ip addr 命令,因为它功能强大且是未来的标准,如果您习惯于传统方式,ifconfig 依然可用,而当需要深入了解网络配置的根源时,检查配置文件则是不可或缺的步骤,掌握这几种方法,将使您在管理 CentOS 服务器时更加得心应手。

CentOS 7.3没有ifconfig命令要如何查看IP?


相关问答 FAQs

为什么我使用 ip addr 看不到我的公网 IP 地址,只看到一个内网 IP(如 192.168.x.x)?

解答: 这是一个非常常见的情况,通常意味着您的服务器位于一个路由器或网络地址转换(NAT)设备之后。ip addr 命令显示的是服务器自身网络接口上配置的 IP 地址,即局域网(内网)IP,公网 IP 是分配给您路由器的,由路由器负责将外部请求转发到内网的服务器上,要查看服务器的公网 IP,您可以使用以下命令之一,它们会向外部服务器请求并返回您的公网地址:
curl ifconfig.me
或者
curl ipinfo.io/ip

如何让 ip addrifconfig 的输出更简洁,只显示 IP 地址本身?

解答: 当您需要在脚本中使用 IP 地址时,完整的输出信息会带来不便,您可以使用 grepawk 等文本处理工具来过滤和提取信息。

对于 ip addr,可以使用以下组合命令:
ip addr show ens33 | grep 'inet ' | awk '{print $2}' | cut -d/ -f1
这个命令链的含义是:显示 ens33 接口的信息,筛选出包含 ‘inet ‘ 的行,提取第二列(即 168.1.100/24),然后以 为分隔符,取第一部分,最终得到纯 IP 地址。

对于 ifconfig,命令稍有不同:
ifconfig ens33 | grep 'inet ' | awk '{print $2}'
因为 ifconfig 的输出中,IP 地址和子网掩码是分开的,所以直接用 awk 提取第二列即可,请将命令中的 ens33 替换为您实际的网卡名称。

【版权声明】:本站所有内容均来自网络,若无意侵犯到您的权利,请及时与我们联系将尽快删除相关内容!

(0)
热舞的头像热舞
上一篇 2025-10-04 23:14
下一篇 2025-10-04 23:18

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

QQ-14239236

在线咨询: QQ交谈

邮件:asy@cxas.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信