我正在配置运行OpenWRT的路由器,但我很难理解如何使用uci命令(统一配置接口)检查现有的配置文件。我想在shell脚本中自动化这个配置。
例如,在/etc/config/firewall上的防火墙配置是195长的,所以很难用cat来检查。
有各种各样的规则,把第一条和:
root@OpenWrt:/etc/config# grep -B1 -A6 'Allow-DHCP-Renew' /etc/config/firewall
config rule
option name Allow-DHCP-Renew
option src wan
option proto udp
option dest_port 68
option target ACCEPT
option family ipv4
root@OpenWrt:/etc/config# 我可以检查这个第一条规则(@rule[0])的各个字段,例如name字段:
root@OpenWrt:/etc/config# uci get firewall.@rule[0].name
Allow-DHCP-Renew
root@OpenWrt:/etc/config# 但是我不能将整个规则看作输出,我尝试过使用uci get firewall.@rule[0].*,但它不是正确的语法。
uci (man uci)没有手册,所以我不知道如何使用该命令的信息。
这个“团体获取”是可能的吗?
发布于 2019-09-07 10:04:15
嗯..。刚刚发现我需要使用uci show而不是uci get,参见下面的示例:
root@OpenWrt:/etc/config# uci show firewall.@rule[0]
firewall.cfg0592bd=rule
firewall.cfg0592bd.name='Allow-DHCP-Renew'
firewall.cfg0592bd.src='wan'
firewall.cfg0592bd.proto='udp'
firewall.cfg0592bd.dest_port='68'
firewall.cfg0592bd.target='ACCEPT'
firewall.cfg0592bd.family='ipv4'
root@OpenWrt:/etc/config#https://unix.stackexchange.com/questions/539477
复制相似问题