从零开始perp交叉编译及配置
Posted shuai_dudu
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了从零开始perp交叉编译及配置相关的知识,希望对你有一定的参考价值。
文章目录
概述
perp是一款非常优秀、资源占用低的开源的多进程管理框架,多用在嵌入式系统环境下。由于网上除了官网的资源外,其他可参考的资源较少,我在这里记录一下我之前使用的经验,并分享给大家。
perp相比与restartd,perp的功能、可监视的进程数量都更多。
资源占用:
ROM:556K (最大占用,可裁剪)
参考资料
http://b0llix.net/perp/site.cgi?page=about
交叉编译
过程
从官网下载源码包
1、tar -zxvf perp-2.07.tar.gz
2、vi conf.mk
修改CC,STRIP为交叉编译工具
修改安装路径,例如/home/ss/perp_install
3、make distclean;make ;make install
报错
报:mk_outvec、mk_rlimit、mksysstr相关错误
原因:编译出的上述工具是在编译时用到的,即在编译主机上使用,而交叉编译将它们编译成目标机架构了。
解决:修改lasagna/Makefile,用本机的GCC编译它们
outvec/mk_outvec : outvec/mk_outvec.c
gcc $(CFLAGS) -o $@ outvec/mk_outvec.c
....
rlimit/mk_rlimit : rlimit/mk_rlimit.c
gcc $(CFLAGS) -o $@ rlimit/mk_rlimit.c
....
sysstr/mksysstr : sysstr/mksysstr.c
gcc $(CFLAGS) -o $@ sysstr/mksysstr.c
配置
make install得到了一些bin文件,如下:
ss@ss-vm:~/koal_sdk/third_part$ ls perp_install/usr/sbin/ -l
总用量 664
-rwxr-xr-x 1 ss ss 27928 11月 26 15:34 perpboot
-rwxr-xr-x 1 ss ss 26020 11月 26 15:34 perpctl
-rwxr-xr-x 1 ss ss 60500 11月 26 15:34 perpd
-rwxr-xr-x 1 ss ss 19404 11月 26 15:34 perphup
-rwxr-xr-x 1 ss ss 31924 11月 26 15:34 perpls
-rwxr-xr-x 1 ss ss 24676 11月 26 15:34 perpok
-rwxr-xr-x 1 ss ss 5273 11月 26 15:34 perp-setup
-rwxr-xr-x 1 ss ss 29620 11月 26 15:34 perpstat
-rwxr-xr-x 1 ss ss 24452 11月 26 15:34 runargs
-rwxr-xr-x 1 ss ss 19240 11月 26 15:34 runargv0
-rwxr-xr-x 1 ss ss 23748 11月 26 15:34 runchoom
-rwxr-xr-x 1 ss ss 19596 11月 26 15:34 rundetach
-rwxr-xr-x 1 ss ss 25264 11月 26 15:34 rundeux
-rwxr-xr-x 1 ss ss 29548 11月 26 15:34 runenv
-rwxr-xr-x 1 ss ss 24544 11月 26 15:34 runfile
-rwxr-xr-x 1 ss ss 30484 11月 26 15:34 runlimit
-rwxr-xr-x 1 ss ss 23036 11月 26 15:34 runlock
-rwxr-xr-x 1 ss ss 20532 11月 26 15:34 runpause
-rwxr-xr-x 1 ss ss 19324 11月 26 15:34 runsession
-rwxr-xr-x 1 ss ss 44172 11月 26 15:34 runtool
-rwxr-xr-x 1 ss ss 27024 11月 26 15:34 runtrap
-rwxr-xr-x 1 ss ss 22380 11月 26 15:34 runuid
-rwxr-xr-x 1 ss ss 14880 11月 26 15:34 sissylog
-rwxr-xr-x 1 ss ss 38508 11月 26 15:34 tinylog
-rwxr-xr-x 1 ss ss 1375 11月 26 15:34 tinylog_run
其中,常用的到只有perpctl、 perpls 、 perpd
1、创建待监视进程的运行规则
1、创建/etc/perp
2、在/etc/perp/下创建目标目录,例如:
/etc/perp
└── perp_demo
├── rc.log
├── rc.main
该目录存放待监视进程的start、stop、restart及log记录等规则。
rc.main
示例:
#!/bin/sh
exec 2>&1
TARGET=$1
SVNAME=$2
## start target:
start()
echo "*** $SVNAME: starting perp_demo..."
exec \\
app_demo
## reset target:
reset()
case $3 in
'exit' )
echo "*** $SVNAME: exited status $4" ;;
'signal' )
echo "*** $SVNAME: killed on signal $5" ;;
* )
echo "*** $SVNAME: stopped ($3)" ;;
esac
exit 0
## branch to target:
eval $TARGET "$@"
### EOF
rc.log
示例:
#!/bin/sh
if test $1 = 'start' ; then
exec tinylog_run $2
fi
exit 0
### EOF
将记录进程的log到/var/log/进程名/current文件内。
2、设置环境变量
export PERP_BASE=/etc/perp
目的:perpls等工具,会根据env中的PERP_BASE找相应的配置文件,如果环境变量没有的话,将报:
perpls fatal: failure connecting to perpd control socket ./.control/perpd.sock: file does not exist (ENOENT)
3、启动perpd服务器
perp /etc/perp
4、配置完成,验证结果
一切正常的话,perpls就可以看到监视进程的运行状态了
perpd
作用
perpd是一个守护进程,用于接收,例如perpls/perpctl下发的指令,并按规则处理这些指令。
perpd运行时将扫描指定目录下的rc.log、rc.main文件,扫描到时,将切换到rc.main所在目录,并执行:
./rc.main start/stop/reset svname [ args... ]
其中rc.log记录运行时的log,该文件可选。
rc.main包含启动、停止进程的规则,该文件必须存在。
使用
perpd /etc/perp
perpls
作用:显示监视的进程信息
# perpls
[+ +++ ---] perp_demo uptime: 58242s/-s pids: 262/-
解释:
[+ +++ —]:运行面板,包含3部分,其后跟监视服务的名字,uptime:启动时间
面板第一部分:
+:正常启动并运行
-:该进程不被perpd监视或已停止且不被拉起
第二部分:
.:进程停止,如下所示:
# perpls
[+ +++ ---] perp_demo uptime: 58242s/-s pids: 262/-
# perpctl d perp_demo
perp_demo: ok
# perpd[261]: monitoring 0 client connections
*** perp_demo: killed on signal SIGTERM
# perpls
perpd[261]: monitoring 1 client connection
[+ ... ---] perp_demo uptime: -s/-s pids: -/-
r: 表示进程起来后,短暂时间内会down掉,即表示进程被频繁拉起和退出,进程异常
p: 表示进程暂停
o: 标识进程只被执行一次
第三部分:
不用考虑
perpctl
作用:控制所监视的进程的状态
以下仅对常用法进行说明。
perpctl d
perpctl d 进程名:即d(down)掉进程,示例如下:
# perpls
[+ +++ ---] perp_demo uptime: 58242s/-s pids: 262/-
# perpctl d perp_demo
perp_demo: ok
# perpd[261]: monitoring 0 client connections
*** perp_demo: killed on signal SIGTERM
# perpls
perpd[261]: monitoring 1 client connection
[+ ... ---] perp_demo uptime: -s/-s pids: -/-
perpctl u
perpctl u 进程名:即u(up)起进程,示例如下:
# perpls
perpd[261]: monitoring 1 client connection
[+ ... ---] perp_demo uptime: -s/-s pids: -/-
# perpctl u perp_demo
perp_demo: ok
# *** perp_demo: starting perp_demo...
ss test
# perpls
[+ +++ ---] perp_demo uptime: 5s/-s pids: 286/-
perpctl o
o(once),如果进程没有起来,则拉起,并标识它只被拉起一次,之后kill掉进程,它不会被拉起。
# perpls
[+ +++ ---] perp_demo uptime: 5s/-s pids: 286/-
# perpctl o perp_demo
perp_demo: ok
# perpls
[+ +o+ ---] perp_demo uptime: 193s/-s pids: 286/-
以上是关于从零开始perp交叉编译及配置的主要内容,如果未能解决你的问题,请参考以下文章