nightingale1/control

252 lines
3.5 KiB
Plaintext
Raw Normal View History

2020-09-26 21:45:23 +08:00
#!/bin/bash
2020-09-26 16:53:10 +08:00
# release version
2021-06-02 00:45:35 +08:00
version=4.0.2
2020-09-26 16:53:10 +08:00
CWD=$(cd $(dirname $0)/; pwd)
cd $CWD
usage()
{
2020-11-28 10:24:26 +08:00
echo $"Usage: $0 {start|stop|restart|status|build|build_local|pack} <module>"
2020-09-26 16:53:10 +08:00
exit 0
}
start_all()
{
2021-04-13 11:38:40 +08:00
test -x n9e-server && start server
test -x n9e-agentd && start agentd
2021-01-22 11:45:05 +08:00
test -x n9e-prober && start prober
2020-09-26 16:53:10 +08:00
}
start()
{
mod=$1
if [ "x${mod}" = "x" ]; then
usage
return
fi
if [ "x${mod}" = "xall" ]; then
start_all
return
fi
binfile=n9e-${mod}
if [ ! -f $binfile ]; then
echo "file[$binfile] not found"
exit 1
fi
if [ $(ps aux|grep -v grep|grep -v control|grep "$binfile" -c) -gt 0 ]; then
echo "${mod} already started"
return
fi
mkdir -p logs/$mod
nohup $CWD/$binfile &> logs/${mod}/stdout.log &
for((i=1;i<=15;i++)); do
if [ $(ps aux|grep -v grep|grep -v control|grep "$binfile" -c) -gt 0 ]; then
echo "${mod} started"
return
fi
sleep 0.2
done
echo "cannot start ${mod}"
exit 1
}
stop_all()
{
2021-04-13 11:38:40 +08:00
test -x n9e-server && stop server
2021-01-22 11:45:05 +08:00
test -x n9e-prober && stop prober
2021-04-13 11:38:40 +08:00
test -x n9e-agentd && stop agentd
2020-09-26 21:58:37 +08:00
}
2020-09-26 16:53:10 +08:00
stop()
{
mod=$1
if [ "x${mod}" = "x" ]; then
usage
return
fi
if [ "x${mod}" = "xall" ]; then
stop_all
return
fi
binfile=n9e-${mod}
if [ $(ps aux|grep -v grep|grep -v control|grep "$binfile" -c) -eq 0 ]; then
echo "${mod} already stopped"
return
fi
ps aux|grep -v grep|grep -v control|grep "$binfile"|awk '{print $2}'|xargs kill
for((i=1;i<=15;i++)); do
if [ $(ps aux|grep -v grep|grep -v control|grep "$binfile" -c) -eq 0 ]; then
echo "${mod} stopped"
return
fi
sleep 0.2
done
echo "cannot stop $mod"
exit 1
}
restart()
{
mod=$1
if [ "x${mod}" = "x" ]; then
usage
return
fi
if [ "x${mod}" = "xall" ]; then
stop_all
start_all
return
fi
stop $mod
start $mod
status
}
status()
{
ps aux|grep -v grep|grep "n9e"
}
build_one()
{
mod=$1
2020-11-28 10:24:26 +08:00
echo -n "building ${mod} ... "
2020-09-26 16:53:10 +08:00
go build -ldflags "-X main.version=${version}" -o n9e-${mod} src/modules/${mod}/${mod}.go
2020-11-28 10:24:26 +08:00
echo "done"
}
build_local_one()
{
mod=$1
echo -n "building ${mod} ... "
go build -mod=vendor -ldflags "-X main.version=${version}" -o n9e-${mod} src/modules/${mod}/${mod}.go
echo "done"
2020-09-26 16:53:10 +08:00
}
build()
{
export GO111MODULE=on
mod=$1
if [ "x${mod}" = "x" ]; then
2021-04-13 11:38:40 +08:00
build_one server
build_one agentd
2021-01-22 11:45:05 +08:00
build_one prober
2020-09-26 16:53:10 +08:00
return
fi
build_one $mod
}
2020-11-28 10:24:26 +08:00
build_local()
{
export GO111MODULE=on
mod=$1
if [ "x${mod}" = "x" ]; then
2021-04-13 11:38:40 +08:00
build_local_one server
build_local_one agentd
2021-01-22 11:45:05 +08:00
build_local_one prober
2020-11-28 10:24:26 +08:00
return
fi
build_local_one $mod
}
2020-09-26 16:53:10 +08:00
reload()
{
mod=$1
if [ "x${mod}" = "x" ]; then
echo "arg: <mod> is necessary"
return
fi
build_one $mod
restart $mod
}
pack()
{
2020-10-09 23:02:02 +08:00
clock=$(date +%s)
2021-01-13 12:45:26 +08:00
mkdir -p ~/n9e.bak.$clock
if ls etc/*.local.yml &>/dev/null; then
mv etc/*.local.yml ~/n9e.bak.$clock
fi
2020-10-22 17:50:32 +08:00
tar zcvf n9e-${version}.tar.gz script control sql etc n9e-*
2021-01-13 12:45:26 +08:00
if ls ~/n9e.bak.$clock/*.local.yml &>/dev/null; then
mv ~/n9e.bak.$clock/*.local.yml etc/
fi
rm -rf ~/n9e.bak.$clock
2020-09-26 16:53:10 +08:00
}
exec()
{
params=${@:2}
if [ ${#2} -gt 0 ]; then
for mod in $params
do
mod=${mod#n9e-}
$1 $mod
if [ "x${mod}" = "xall" ]; then
break
fi
done
else
2021-04-13 11:38:40 +08:00
echo "todo $1 at "$(date "+%Y-%m-%d %H:%M:%S")
$1
2021-04-13 11:38:40 +08:00
echo "done $1 at "$(date "+%Y-%m-%d %H:%M:%S")
fi
}
2020-09-26 16:53:10 +08:00
case "$1" in
start)
exec start ${@:2}
2020-09-26 16:53:10 +08:00
;;
stop)
exec stop ${@:2}
2020-09-26 16:53:10 +08:00
;;
restart)
exec restart ${@:2}
2020-09-26 16:53:10 +08:00
;;
status)
status
;;
build)
exec build ${@:2}
2020-09-26 16:53:10 +08:00
;;
2020-11-28 10:24:26 +08:00
build_local)
exec build_local ${@:2}
2020-11-28 10:24:26 +08:00
;;
2020-09-26 16:53:10 +08:00
reload)
exec reload ${@:2}
2020-09-26 16:53:10 +08:00
;;
pack)
exec pack ${@:2}
2020-09-26 16:53:10 +08:00
;;
*)
usage
esac