2016-06-30 20:26:57 +00:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
# /etc/rc.d/rc.cgproxy - start/stop the cgroup proxy manager
|
|
|
|
|
|
|
|
if [ -f /etc/default/cgproxy ]; then
|
|
|
|
# get cgproxy options if specified
|
|
|
|
. /etc/default/cgproxy
|
|
|
|
fi
|
|
|
|
|
|
|
|
start_cgproxy() {
|
|
|
|
# cgproxy should only run on container unless on older kernel
|
|
|
|
if [ -e /proc/self/ns/pid ] && [ "$NESTED" != "yes" ]; then
|
|
|
|
echo "Error: cgproxy should only run inside containers"
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
echo "Starting cgproxy: /usr/sbin/cgproxy --daemon"
|
|
|
|
/usr/sbin/cgproxy --daemon
|
|
|
|
}
|
|
|
|
|
|
|
|
stop_cgproxy() {
|
|
|
|
if ps -C cgproxy | grep -q cgproxy 2>/dev/null ; then
|
|
|
|
echo "Stopping cgproxy."
|
|
|
|
if ! /bin/kill $(cat /run/cgproxy.pid 2>/dev/null) 2>/dev/null ; then
|
|
|
|
sleep 1
|
|
|
|
echo "Sending cgproxy the TERM signal."
|
2018-05-28 19:12:29 +00:00
|
|
|
if ! /usr/bin/pkill --exact -TERM /usr/sbin/cgproxy ; then
|
2016-06-30 20:26:57 +00:00
|
|
|
sleep 5
|
|
|
|
echo "Sending cgproxy the KILL signal."
|
2018-05-28 19:12:29 +00:00
|
|
|
/usr/bin/pkill --exact -KILL /usr/sbin/cgproxy
|
2016-06-30 20:26:57 +00:00
|
|
|
sleep 5
|
|
|
|
if ps -C cgproxy | grep -q cgproxy 2>/dev/null ; then
|
|
|
|
echo "Error: couldn't stop cgproxy."
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
rm -f /run/cgproxy.pid
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
restart_cgproxy() {
|
|
|
|
stop_cgproxy
|
|
|
|
sleep 1
|
|
|
|
start_cgproxy
|
|
|
|
}
|
|
|
|
|
|
|
|
case "$1" in
|
|
|
|
'start')
|
|
|
|
start_cgproxy
|
|
|
|
;;
|
|
|
|
'stop')
|
|
|
|
stop_cgproxy
|
|
|
|
;;
|
|
|
|
'restart')
|
|
|
|
restart_cgproxy
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
echo "usage $0 start|stop|restart"
|
|
|
|
esac
|