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 函数:按指定分隔符(如 /)拆分字符串,结果存入数组。
相关推荐
2301_780789663 分钟前
零信任架构中,身份感知防火墙(IAFW)的部署要点与最佳实践
linux·运维·服务器·人工智能·tcp/ip·架构
2401_8685347819 分钟前
2025下半年网络规划设计师真题(选择题、案例分析)
运维·服务器·网络
小狮子&36 分钟前
ubuntu2604无法共享文件夹问题解决
linux·运维·服务器
biter down37 分钟前
3:VMware Workstation 安装 Ubuntu 22.04 超详细教程
linux·运维·ubuntu
思茂信息40 分钟前
CST软件基于液态金属开关的方向图可重构天线
服务器·算法·重构·cst·仿真软件·电磁仿真
曾阿伦44 分钟前
netcat / ncat / socat 用法详解与示例
linux·http·信息与通信
zhping10111 小时前
Ubuntu 登录密码忘记
运维·服务器·ubuntu
Benszen1 小时前
Secret详解
linux·运维·服务器
烈焰晴天1 小时前
Codex 桌面端如何链接Figma MCP 服务器拿到 Figma设计稿精准尺寸等结构化数据 来精准还原UI
服务器·ui·figma
Dlrb12111 小时前
Linux网络编程-网络基础概念(IP, UDP协议)
linux·服务器·网络·网络基础·端口号·ip协议·udp协议