ip a 命令解析与 IP 地址提取

基础命令:ip a

ip aip addr 的简写,用于查看系统中所有网络接口的详细配置信息。输出内容包含接口名称、MAC 地址、IP 地址、网络状态等。典型输出分为多个网络接口段(如 loeth0eth1),关键字段说明如下:

  • 1: lo::回环接口(用于本地测试),数字 1 是接口编号。
  • 2: eth0: / 3: eth1::物理网卡接口(对应虚拟机的两块网卡)。
  • <LOOPBACK,UP,LOWER_UP>:接口状态(UP 表示已启用)。
  • link/ether 08:00:27:b3:a2:9c:网卡的 MAC 地址。
  • inet 127.0.0.1/8:IPv4 地址(/8 是子网掩码的简写,对应 255.0.0.0)。
过滤含 IP 的行:ip a | grep inet

通过管道符 |ip a 的输出传给 grep inet,筛选出所有包含 inet 关键字的行(IP 地址行会包含 inet)。输出示例如下:

复制代码
inet 127.0.0.1/8 scope host lo
inet 10.0.2.15/24 brd 10.0.2.255 scope global dynamic noprefixroute eth0
inet 192.168.56.100/24 brd 192.168.56.255 scope global noprefixroute eth1
提取 IP 地址段:ip a | grep inet | awk '{print $2}'

grep 过滤后的行基础上,用 awk 提取每行的第 2 个字段(即 IP 地址/子网掩码段)。输出示例如下:

复制代码
127.0.0.1/8
10.0.2.15/24
192.168.56.100/24
排除回环地址:ip a | grep inet | awk '{print $2}' | grep -v 127.0.0.1

通过 grep -v 127.0.0.1 排除回环地址,仅保留真实网卡 IP。输出示例如下:

复制代码
10.0.2.15/24
192.168.56.100/24
进阶:提取纯 IP 地址

若需去掉子网掩码部分,可使用 awksplit 函数:

bash 复制代码
ip a | grep inet | grep -v 127.0.0.1 | awk '{split($2,ip,"/"); print ip[1]}'

输出示例:

复制代码
10.0.2.15
192.168.56.100
关键原理
  • 管道符 |:将前一个命令的输出作为后一个命令的输入。
  • grep:过滤文本行(-v 参数用于反向匹配)。
  • awk:按字段处理文本(默认以空格/制表符分隔,$2 表示第二个字段)。
  • split 函数:按指定分隔符(如 /)拆分字符串,结果存入数组。
相关推荐
代码AI弗森42 分钟前
一文理清楚“算力申请 / 成本测算 / 并发评估”
java·服务器·数据库
蜡台1 小时前
Python包管理工具pip完全指南-----2
linux·windows·python
^—app5668662 小时前
游戏运存小启动不起来临时解决方法
运维·服务器
Ujimatsu2 小时前
虚拟机安装Debian 13.x及其常用软件(2026.4)
linux·运维·ubuntu
千百元2 小时前
zookeeper启不来了
linux·zookeeper·debian
志栋智能3 小时前
超自动化安全:构建智能安全运营的核心引擎
大数据·运维·服务器·数据库·安全·自动化·产品运营
合天网安实验室3 小时前
记录一个免杀的php webshell demo
渗透测试·php·webshell·免杀
AnalogElectronic4 小时前
linux 测试网络和端口是否连通的命令详解
linux·网络·php
Edward111111114 小时前
4月28日防火墙问题
linux·运维·服务器
想学后端的前端工程师5 小时前
【补充内外网突然不通的情况】
运维·服务器