CodeMed Asked: 2018-08-11 16:37:22 +0800 CST2018-08-11 16:37:22 +0800 CST 2018-08-11 16:37:22 +0800 CST grep 的 IP 范围? 772 在本地 IP 地址为 10.0.0.159 的 RHEL 7 机器上,以下命令打印出 IP 10.0.0.159: $ echo "$(ifconfig eth0 | grep -Eo 'inet (addr:)?([0-9]*\.){3}[0-9]*' | \ grep -Eo '([0-9]*\.){3}[0-9]*' | grep -v '127.0.0.1')""(rw,sync)" 为了打印出“10.0.0.0/8”,命令必须更改为什么? grep terminal 2 个回答 Voted Best Answer slm 2018-08-11T17:08:15+08:002018-08-11T17:08:15+08:00 注意: ifconfig是一个已弃用的 cmd。你应该使用 cmds。在 iproute2 包中。下面我展示了如何使用ip替换工具来完成你想要的。 ifconfig我建议不要这样做,而是使用该ip命令。 IP CIDR 此表单以 CIDR 表示法显示 IP 地址: $ ip addr list eth0 | awk '/inet.*brd/ {print $2}' 10.0.2.15/24 -or- $ ip a l eth0 | awk '/inet.*brd/ {print $2}' 10.0.2.15/24 网络 CIDR 此表单以 CIDR 表示法显示网络地址: $ ip route show | awk '/eth0.*scope/ {print $1}' 10.0.2.0/24 ipcalc 您还可以使用ipcalc命令来操作上述地址以计算其他格式。例如: $ ipcalc -n $(ip a l eth0 | awk '/inet.*brd/ {print $2}') NETWORK=10.0.2.0 $ ipcalc -p $(ip a l eth0 | awk '/inet.*brd/ {print $2}') PREFIX=24 有了ipcalc它,您可以更简单地形成您想要的任何变体,而不必做很多sed&awk来解析通常过于复杂的文本。 msb 2018-08-11T17:53:12+08:002018-08-11T17:53:12+08:00 要更改命令行以执行您想要的操作,首先您需要了解它在做什么。这里有一个分析: echo "$(<something>)""(rw,sync)" 将运行something并将其作为输入到您的echo. 其他所有内容都是要echo编辑的普通文本。 ifconfig eth0 获取网络信息。 grep -Eo 'inet (addr:)?([0-9]*\.){3}[0-9]*' 隔离系统中的多个 IP。-E告诉 grep 使用正则表达式,这就是为什么您可以使用[0-9]*例如将所有数字匹配在一起的原因。-o告诉 grep 仅输出与正则表达式匹配的部分,而不是像默认情况下那样输出与 grep 条件匹配的整行。因此,例如,如果输入行是inet addr:10.0.0.159 Bcast:10.0.0.255 Mask:255.255.255.0,它只会输出inet addr:10.0.0.159省略BcastandMask部分。 grep -Eo '([0-9]*\.){3}[0-9]*' 这与上面完全相同,除了没有 label inet addr,这意味着您要专门隔离 IP 并删除标签。最后, grep -v '127.0.0.1' 正在从您的输出列表中删除该 IP,因为您不关心环回 IP。 如您所见,您的命令正在获取信息的输出ifconfig和过滤信息,只隔离您想要的信息。它不进行任何计算或信息处理。但是您希望它打印的是子网和掩码,它们是未明确显示的信息ifconfig。换句话说,你不能只是过滤掉不同的东西来得到你想要的东西。您将不得不使用Mask行尾的字段进行一些处理和一些计算。总之,您不能“更改命令以打印出您想要的内容”。您必须创建一个完全不同的命令。 slm 的答案使用了类似的技术(过滤掉信息以仅保留您想要的内容),但是将输入更改为将具有您需要的信息的命令。:-) 如果您没有一个命令可以准确地输出您想要的内容,并且对其进行一些处理是您唯一的选择,那么这里有一组丑陋的ifs,您可以在将来用作示例或基础。它使用 slm 的第一个解决方案,并假设您的掩码始终为 8、16 或 24。 ip a l eth1 | awk '/inet.*brd/ {split($2,add,"/");split(add[1],ip,".");if(add[2]<=24){ip[4]=0} if(add[2]<=16){ip[3]=0} if(add[2]<=8){ip[2]=0} print ip[1]"."ip[2]"."ip[3]"."ip[4]"/"add[2];}' 此命令在ress (10.0.0.159) 和 mask (8)ip之间拆分输出。add然后它将 IP 拆分为 4 个数字。然后它根据掩码将数字设置为零。但它不是按位的,这意味着它只会处理掩码 8、16 和 24,因为这是我硬编码的。;) 我希望你能更多地了解你手头的工具。^_^
注意:
ifconfig
是一个已弃用的 cmd。你应该使用 cmds。在 iproute2 包中。下面我展示了如何使用ip
替换工具来完成你想要的。ifconfig
我建议不要这样做,而是使用该ip
命令。IP CIDR
此表单以 CIDR 表示法显示 IP 地址:
网络 CIDR
此表单以 CIDR 表示法显示网络地址:
ipcalc
您还可以使用
ipcalc
命令来操作上述地址以计算其他格式。例如:有了
ipcalc
它,您可以更简单地形成您想要的任何变体,而不必做很多sed
&awk
来解析通常过于复杂的文本。要更改命令行以执行您想要的操作,首先您需要了解它在做什么。这里有一个分析:
将运行
something
并将其作为输入到您的echo
. 其他所有内容都是要echo
编辑的普通文本。获取网络信息。
隔离系统中的多个 IP。
-E
告诉 grep 使用正则表达式,这就是为什么您可以使用[0-9]*
例如将所有数字匹配在一起的原因。-o
告诉 grep 仅输出与正则表达式匹配的部分,而不是像默认情况下那样输出与 grep 条件匹配的整行。因此,例如,如果输入行是inet addr:10.0.0.159 Bcast:10.0.0.255 Mask:255.255.255.0
,它只会输出inet addr:10.0.0.159
省略Bcast
andMask
部分。这与上面完全相同,除了没有 label
inet addr
,这意味着您要专门隔离 IP 并删除标签。最后,正在从您的输出列表中删除该 IP,因为您不关心环回 IP。
如您所见,您的命令正在获取信息的输出
ifconfig
和过滤信息,只隔离您想要的信息。它不进行任何计算或信息处理。但是您希望它打印的是子网和掩码,它们是未明确显示的信息ifconfig
。换句话说,你不能只是过滤掉不同的东西来得到你想要的东西。您将不得不使用Mask
行尾的字段进行一些处理和一些计算。总之,您不能“更改命令以打印出您想要的内容”。您必须创建一个完全不同的命令。slm 的答案使用了类似的技术(过滤掉信息以仅保留您想要的内容),但是将输入更改为将具有您需要的信息的命令。:-) 如果您没有一个命令可以准确地输出您想要的内容,并且对其进行一些处理是您唯一的选择,那么这里有一组丑陋的
if
s,您可以在将来用作示例或基础。它使用 slm 的第一个解决方案,并假设您的掩码始终为 8、16 或 24。此命令在ress (10.0.0.159) 和 mask (8)
ip
之间拆分输出。add
然后它将 IP 拆分为 4 个数字。然后它根据掩码将数字设置为零。但它不是按位的,这意味着它只会处理掩码 8、16 和 24,因为这是我硬编码的。;)我希望你能更多地了解你手头的工具。^_^