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 函数:按指定分隔符(如 /)拆分字符串,结果存入数组。
相关推荐
D4c-lovetrain5 分钟前
linux实战之多配置部署(ansible、nginx、keepalived、dhcp、dns多元化操作)
linux·运维·服务器
147API7 分钟前
Claude 4.6 API 接入全流程避坑:OpenAI 迁移、长上下文超时、429 限流一次讲清
运维·服务器·网络·claude·api大模型
CDN3609 分钟前
高防服务器无法远程连接?端口、防火墙与安全组排查
运维·服务器·安全
我爱学习好爱好爱10 分钟前
Ansible force_handlers delegate委托 playbook语法格式 template模块
linux·运维·ansible
cch891815 分钟前
Laravel vs 主流PHP框架:终极对决
开发语言·php·laravel
CDN36019 分钟前
高防服务器被攻击后 IP 被封?黑洞解封与清洗策略设置
运维·服务器·tcp/ip
cpp_learners21 分钟前
Linux ARM架构 使用 linuxdeployqt 打包QT程序
linux·arm开发·qt
2401_8274999924 分钟前
python项目实战07-DeepSeek调用测试(本地部署)
linux·运维·服务器
longxibo25 分钟前
【Ubuntu datasophon1.2.1 二开之九:验证离线数据入湖】
大数据·linux·运维·ubuntu
似水এ᭄往昔29 分钟前
【Linux】--命令行参数和环境变量
linux·运维·服务器