RPC daemon—rpcd,OpenWrt进程管理服务
为每个软件编写一个守护程序,并独立运行它们并没有效率。这就是为什么rpcd被开发出来的原因。这是一个很小的守护程序,支持使用普通API的插件,动态注册,将自己的应用程序加入rpcd守护管理服务。
以下示例,实现功能:
- 将程序/usr/bin/main加入procd进行管理,上电自动启动
- 当main异常退出,自动重新启动。
- 同时监测配置文件/etc/config/mqtt是否发生变化,如果发生变化,则自动重启该进程。
将以下脚本,加入/etc/init.d中:
#!/bin/sh /etc/rc.common
# /etc/init.d
# Copyright (C) 2008 OpenWrt.org
# 执行的顺序,在/etc/rc.d目录下自动生成S98xxx,K98xxxx,按照顺序执行。
START=98
STOP=98
# 使用procd启动
USE_PROCD=1
DAEMON=main
PROG=/usr/bin/$DAEMON
CONFIG=mqtt
CONFIGFILE=/etc/config/$CONFIG
# 向 procd 注册并启动服务,是将在 services 所管理对象里面增加了一项
start_service() {
echo "start user service!"
# 开始增加一个服务实例, 在procd看来一个应用程序可以多个实例
# ubus call service list 可以查看实例
procd_open_instance
#定义respawn参数,进程意外退出的重启机制及策略
# threshold:异常失败边界值3600;timeout:重启延迟时间5;retry:失败重启次数5
# procd_set_param respawn retry=10
procd_set_param respawn 3600 5 10
# 执行的命令是"/usr/bin/main", 若后面有参数可以直接在后面加上
procd_set_param command $PROG '&'
# 配置文件名,比较其文件内容是否改变
# procd_set_param file $CONFIGFILE
# 绑定的网络设备(探测 ifindex 更改)
# netdevs=
# procd_set_param netdev $netdevs
# 指定对应的pidfile
# procd_set_param pidfile /var/run/${DAEMON}.pid
# 完成进程实例的增加
procd_close_instance
}
# 让 procd 解除注册,并关闭服务, 是将在 services 中的管理对象删除
stop_service() {
echo "stop user service!"
# rm -f /var/run/${DAEMON}.pid
# service_stop "$PROG"
killall $DAEMON
}
# 重启服务,如果定义了该函数,在 reload 时将调用该函数,否则再次调用 start 函数
reload_service(){
echo "reload user service!"
stop
start
}
# 配置文件或网络接口改变之后触发服务重新读取配置
service_triggers(){
echo "triggers user service!"
procd_add_reload_trigger $CONFIG
}
# 用于判断进程是否启动成功
# service_started(){
# }
restart() {
stop
start
}