ansible-role-k3s/templates/k3s-killall.sh.j2

70 lines
1.7 KiB
Plaintext
Raw Normal View History

2020-02-25 18:29:39 +01:00
#!/bin/sh
2020-02-25 18:29:39 +01:00
[ $(id -u) -eq 0 ] || exec sudo $0 $@
for bin in {{ k3s_runtime_config['data-dir'] | default(k3s_data_dir) }}/data/**/bin/; do
[ -d $bin ] && export PATH=$PATH:$bin:$bin/aux
2020-02-25 18:29:39 +01:00
done
set -x
for service in {{ k3s_systemd_unit_dir }}/k3s*.service; do
[ -s $service ] && systemctl stop $(basename $service)
2020-02-25 18:29:39 +01:00
done
for service in /etc/init.d/k3s*; do
[ -x $service ] && $service stop
2020-02-25 18:29:39 +01:00
done
pschildren() {
ps -e -o ppid= -o pid= | \
sed -e 's/^\s*//g; s/\s\s*/\t/g;' | \
grep -w "^$1" | \
cut -f2
}
pstree() {
for pid in $@; do
echo $pid
for child in $(pschildren $pid); do
pstree $child
done
done
}
killtree() {
kill -9 $(
{ set +x; } 2>/dev/null;
pstree $@;
set -x;
) 2>/dev/null
}
getshims() {
ps -e -o pid= -o args= | sed -e 's/^ *//; s/\s\s*/\t/;' | grep -w 'k3s/data/[^/]*/bin/containerd-shim' | cut -f1
2020-02-25 18:29:39 +01:00
}
killtree $({ set +x; } 2>/dev/null; getshims; set -x)
do_unmount_and_remove() {
awk -v path="$1" '$2 ~ ("^" path) { print $2 }' /proc/self/mounts | sort -r | xargs -r -t -n 1 sh -c 'umount "$0" && rm -rf "$0"'
2020-02-25 18:29:39 +01:00
}
do_unmount_and_remove '/run/k3s'
do_unmount_and_remove '{{ k3s_runtime_config['data-dir'] | default(k3s_data_dir) }}'
do_unmount_and_remove '/var/lib/kubelet/pods'
do_unmount_and_remove '/run/netns/cni-'
# Remove CNI namespaces
ip netns show 2>/dev/null | grep cni- | xargs -r -t -n 1 ip netns delete
2020-02-25 18:29:39 +01:00
# Delete network interface(s) that match 'master cni0'
ip link show 2>/dev/null | grep 'master cni0' | while read ignore iface ignore; do
iface=${iface%%@*}
[ -z "$iface" ] || ip link delete $iface
done
ip link delete cni0
ip link delete flannel.1
rm -rf /var/lib/cni/
iptables-save | grep -v KUBE- | grep -v CNI- | iptables-restore