summaryrefslogtreecommitdiffstats
path: root/source/ap/cgmanager/config/rc.cgproxy
blob: bd96902cbe691b6e906c9408cd971e2bc0dc7cde (about) (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
#!/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."
      if ! /usr/bin/pkill -TERM cgproxy ; then
        sleep 5
        echo "Sending cgproxy the KILL signal."
        /usr/bin/pkill -KILL cgproxy
        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