Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Cleans up containers and shims on microk8s stop and snap removal #4755

Merged
merged 1 commit into from
Nov 29, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 3 additions & 3 deletions .github/workflows/build-snap.yml
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ jobs:
set -x
sudo apt-get install python3-setuptools
sudo pip3 install --upgrade pip
sudo pip3 install -U pytest sh
sudo pip3 install -U pytest sh psutil
sudo apt-get -y install open-iscsi
sudo systemctl enable iscsid
- name: Fetch snap
Expand All @@ -73,7 +73,7 @@ jobs:
set -x
sudo apt-get install python3-setuptools
sudo pip3 install --upgrade pip
sudo pip3 install -U pytest sh
sudo pip3 install -U pytest sh psutil
sudo apt-get -y install open-iscsi
sudo systemctl enable iscsid
- name: Fetch snap
Expand Down Expand Up @@ -136,7 +136,7 @@ jobs:
set -x
sudo apt-get install python3-setuptools
sudo pip3 install --upgrade pip
sudo pip3 install -U pytest sh
sudo pip3 install -U pytest sh psutil
sudo apt-get -y install open-iscsi
sudo systemctl enable iscsid
- name: Fetch snap
Expand Down
2 changes: 1 addition & 1 deletion microk8s-resources/actions/common/utils.sh
Original file line number Diff line number Diff line change
Expand Up @@ -988,7 +988,7 @@ remove_all_containers() {

for container in $("${SNAP}/microk8s-ctr.wrapper" containers ls | $SNAP/bin/sed -n '1!p' | $SNAP/usr/bin/gawk '{print $1}')
do
"${SNAP}/microk8s-ctr.wrapper" container delete --force $container &>/dev/null || true
"${SNAP}/microk8s-ctr.wrapper" container delete $container &>/dev/null || true
done
}

Expand Down
8 changes: 2 additions & 6 deletions microk8s-resources/default-hooks/remove.d/90-containers
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,5 @@

. "${SNAP}/actions/common/utils.sh"

if is_strict
then
remove_all_containers
else
kill_all_container_shims
fi
remove_all_containers
kill_all_container_shims
12 changes: 3 additions & 9 deletions microk8s-resources/wrappers/apiservice-kicker
Original file line number Diff line number Diff line change
Expand Up @@ -65,15 +65,9 @@ do
echo "cert change detected. Reconfiguring the kube-apiserver"
rm -rf .srl
snapctl stop microk8s.daemon-kubelite
if is_strict
then
remove_all_containers
snapctl restart microk8s.daemon-containerd
else
snapctl stop microk8s.daemon-containerd
kill_all_container_shims
snapctl start microk8s.daemon-containerd
fi
remove_all_containers
kill_all_container_shims
snapctl restart microk8s.daemon-containerd
snapctl start microk8s.daemon-kubelite
start_all_containers
restart_attempt=$[$restart_attempt+1]
Expand Down
16 changes: 6 additions & 10 deletions microk8s-resources/wrappers/microk8s-stop.wrapper
Original file line number Diff line number Diff line change
Expand Up @@ -40,26 +40,22 @@ while true; do
esac
done

stopcmd="run_with_sudo snap stop ${SNAP_NAME} --disable"
prefix_cmd="run_with_sudo snap"
if is_strict
then
stopcmd="snapctl stop microk8s.daemon-kubelite --disable"
prefix_cmd="snapctl"
fi

$stopcmd
$prefix_cmd stop microk8s.daemon-kubelite --disable
stop_status=$?

if ! [ $stop_status -eq 0 ]
then
echo 'Failed to stop microk8s services. Check snapd logs with "journalctl -u snapd.service"'
exit 1
else
if is_strict
then
remove_all_containers
snapctl stop microk8s --disable
else
kill_all_container_shims
fi
remove_all_containers
kill_all_container_shims
$prefix_cmd stop microk8s --disable
run_with_sudo touch ${SNAP_DATA}/var/lock/stopped.lock
fi
9 changes: 9 additions & 0 deletions snap/hooks/remove
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,15 @@ use_snap_env

snapctl stop ${SNAP_NAME}.daemon-kubelite 2>&1 || true

# Temporarily start containerd so we can stop and kill all the microk8s containers.
snapctl start ${SNAP_NAME}.daemon-containerd 2>&1 || true
# wait for containerd to start.
sleep 5

# Remove any lingering containers and shims.
remove_all_containers
kill_all_container_shims

# Try to symlink /var/lib/kubelet so that most kubelet device plugins work out of the box.
if test -L /var/lib/kubelet; then
unlink /var/lib/kubelet || true
Expand Down
1 change: 1 addition & 0 deletions tests/requirements.txt
Original file line number Diff line number Diff line change
Expand Up @@ -7,5 +7,6 @@ pyyaml
sh
jsonschema==4.0.0
pdbpp
psutil
netifaces
requests
16 changes: 16 additions & 0 deletions tests/test-simple.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@
import requests
import os.path

import utils


class TestSimple(object):
def test_microk8s_nodes_ready(self):
Expand Down Expand Up @@ -132,3 +134,17 @@ def test_microk8s_services_running(self):

# Verify that all node services are running
assert running_node_services == set(node_services), "Not all node services are running"

def test_microk8s_stop_start(self):
coredns_procs = utils._get_process("coredns")
assert len(coredns_procs) > 0, "Expected to find a coredns process running."

utils.run_until_success("/snap/bin/microk8s.stop", timeout_insec=180)

new_coredns_procs = utils._get_process("coredns")
assert len(new_coredns_procs) == 0, "coredns found still running after microk8s stop."

utils.run_until_success("/snap/bin/microk8s.start", timeout_insec=180)

new_coredns_procs = utils._get_process("coredns")
assert len(new_coredns_procs) > 0, "Expected to find a new coredns process running."
3 changes: 3 additions & 0 deletions tests/test-upgrade.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
is_container,
is_ipv6_configured,
kubectl,
_get_process,
)

upgrade_from = os.environ.get("UPGRADE_MICROK8S_FROM", "beta")
Expand Down Expand Up @@ -157,3 +158,5 @@ def test_upgrade(self):
if not is_container():
# On lxc umount docker overlay is not permitted.
check_call("sudo snap remove microk8s".split())
coredns_procs = _get_process("coredns")
assert len(coredns_procs) == 0, "Expected to have 0 coredns processes running."
5 changes: 5 additions & 0 deletions tests/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
import time
import yaml
import platform
import psutil
from subprocess import check_output, CalledProcessError, check_call


Expand Down Expand Up @@ -270,3 +271,7 @@ def is_ipv6_configured():
return b"inet6" in output
except CalledProcessError:
return False


def _get_process(name):
return [p for p in psutil.process_iter() if name == p.name()]
Loading