目的:为了在 OpenWrt 中提供各种守护进程和app之间的进程间通信,openWrt开发了一个名为ubus的项目。它由守护进程、库和一些额外的helper组成。
它的核心是ubusd守护进程,它为其他守护进程提供用来注册自己和发送消息的接口,这个接口是使用 Unix 套接字实现的,它使用TLV(类型-长度-值)消息。每个守护进程在特定的命名空间下注册一组路径。每个路径都可以提供具有任意数量参数的多个过程。程序可以用消息回复。
命令行中使用ubus工具:ubus命令行工具能够与ubusd服务器交互(与所有注册的服务进行交互),它对于调查/调试注册的namespace以及编写 shell 脚本很有用。为了方便调用和返回值,它使用用户友好的 JSON 格式(译者注:这其实是一种JSON-RPC的方式,无状态,轻量级,方便不同语言和平台绑定)。下面是对其命令的解释。
root@OpenWrt:~# ubus
用法:ubus [<options>] <command> [arguments...]
选项:
-s <socket>:设置要连接的unix域套接字
-t <timeout>:设置命令完成的超时时间(以秒为单位)
-S:使用简化的输出(用于脚本)
-v:更详细的输出
-m <type>:(用于监视器):包含特定的消息类型
(可以多次使用)
-M <r|t> (for monitor): 只捕获接收或传输的流量
命令:
list [<path>] 列出对象
call <path> <method> [<message>] 调用一个对象方法
listen [<path>...] 监听事件
send <type> [<message>] 发送事件
wait_for <object> [<object>...] 等待多个对象出现在 ubus 上
监控 监控 ubus 流量
ubus list//列出当前在总线上运行的服务
ubus -v list network.interface.lan//列出特定服务器的方法及其参数名,加个参数-v
ubus call network.interface.wan status//查看wan口状态信息
ubus call network.device status//查询所有网卡状态
ubus call network.device status '{ "name": "eth0" }'//查询eth0网卡状态
ubus call uci get '{ "config": "firewall", "type": "zone" }'//获得防火墙所有zone规则
ubus call uci get '{ "config": "firewall", "section": "@rule[0]" }'//获得防火墙rule规则的第0条
uhttpd-mod-ubus是uhttpd插件,允许使用HTTP协议控制ubus。(通过 HTTP 访问 ubus(不细说))
版权归原作者 摆烂选手一枚 所有, 如有侵权,请联系我们删除。