54 |
} |
} |
55 |
|
|
56 |
lxc_status() { |
lxc_status() { |
57 |
( find /var/lib/lxc/ -name "config" | cut -d/ -f5 | sort -u | xargs -i lxc-info -n {} | sed "s/'//g" | while read name is status ; do |
( find /var/lib/lxc/ -name "config" | cut -d/ -f5 | sort -u | while read name ; do |
58 |
|
status=`lxc-info -n $name 2>/dev/null | grep state: | cut -d: -f2` |
59 |
boot="-" |
boot="-" |
60 |
test -s /var/lib/lxc/$name/on_boot && boot="boot" |
test -s /var/lib/lxc/$name/on_boot && boot="boot" |
61 |
echo "$name $status $boot $(lxc_rootfs $name) $(lxc_ip $name) $(lxc_hostname $name)" |
echo "$name $status $boot $(lxc_rootfs $name) $(lxc_ip $name) $(lxc_hostname $name)" |
146 |
lxc_watchdog() { |
lxc_watchdog() { |
147 |
name=$1 |
name=$1 |
148 |
rootfs=$(lxc_rootfs $1) |
rootfs=$(lxc_rootfs $1) |
149 |
|
run=$rootfs/var/run |
150 |
|
test -L $run && run=$rootfs/`readlink $run` # recent Debian have symlink to /run |
151 |
|
cd $run || echo "can't cd watchdog into $run" |
152 |
|
|
153 |
while true; do |
while true; do |
|
vps_utmp=${rootfs}/var/run/utmp |
|
154 |
tasks=`wc -l < /cgroup/${name}/tasks` |
tasks=`wc -l < /cgroup/${name}/tasks` |
155 |
stop_on=1 # init |
stop_on=1 # init |
156 |
sulogins=`lxc-ps --name $name | grep sulogin | wc -l` |
sulogins=`lxc-ps --name $name | grep sulogin | wc -l` |
161 |
test -z "$tasks" && exit 1 |
test -z "$tasks" && exit 1 |
162 |
if [ "$tasks" -eq $stop_on ]; then |
if [ "$tasks" -eq $stop_on ]; then |
163 |
|
|
164 |
runlevel="$(runlevel ${vps_utmp})" |
runlevel="$(runlevel utmp)" |
165 |
lxc_log "$name runlevel $runlevel" |
lxc_log "$name runlevel $runlevel" |
166 |
|
|
167 |
case $runlevel in |
case $runlevel in |
168 |
N*) |
N*) |
169 |
# nothing for new boot state |
# nothing for new boot state |
170 |
;; |
;; |
171 |
??0) |
??0|unknown) |
172 |
lxc_log "$name halt" |
lxc_log "$name halt" |
173 |
lxc-stop -n "${name}" |
lxc-stop -n "${name}" |
174 |
lxc-wait -n ${name} -s STOPPED |
lxc-wait -n ${name} -s STOPPED |
191 |
fi |
fi |
192 |
|
|
193 |
# time of 5 minutes on it JUST IN CASE... |
# time of 5 minutes on it JUST IN CASE... |
194 |
inotifywait -qqt 300 ${vps_utmp} |
inotifywait -qqt 300 utmp |
195 |
done |
done |
196 |
|
|
197 |
lxc_log "$name watchdog exited" |
lxc_log "$name watchdog exited" |