You are viewing documentation for version 1.13.x.
The most current version is 1.20.x. This documentation is available for 1.20.x.
Regaining Access to a Bottlerocket Node
How to Regain Access to a Bottlerocket Node After Disabling the Control and Admin Containers
Introduction
The standard way to access a shell on a Bottlerocket node is to use either the admin container or the control container. In some cases where both the admin and control containers are disabled, it is still possible to regain access to a Bottlerocket node.
Solution Description
In general, the solution is to mount the API client and API socket into a container on the Bottlerocket node and use the API client to re-enable the admin container, control container, or both.
Steps to Regain Access on Kubernetes
Create a pod that mounts the API client and API socket with the correct SELinux labels.
Some notes on the Pod spec below:
- The API socket has a specific SELinux label applied to it (
system_u:object_r:api_socket_t:s0
) that restricts access to theapi_socket_t
type ands0
sensitivity level. To learn more about the SELinux labels in Bottlerocket, see the Security Guidance documentation. - In order to access the API socket, the Pod must have compatible SELinux options applied to it.
- Use the
control_t
type (has access toapi_socket_t
) ands0
sensitivity level to allow the container to access the API socket. - The entrypoint for the container is
sleep infinity
so that the container stays running for you toexec
into.
- The API socket has a specific SELinux label applied to it (
apiVersion: v1
kind: Pod
metadata:
name: regain-access
spec:
containers:
- name: regain-access
image: fedora
command: ["sleep", "infinity"]
volumeMounts:
- mountPath: /usr/bin/apiclient
name: apiclient
readOnly: true
- mountPath: /run/api.sock
name: apiserver-socket
securityContext:
seLinuxOptions:
level: s0
role: system_r
type: control_t
user: system_u
volumes:
- name: apiclient
hostPath:
path: /usr/bin/apiclient
type: File
- name: apiserver-socket
hostPath:
path: /run/api.sock
type: Socket
exec
into the container.
kubectl exec -it regain-access -- bash
- Use
apiclient
to enable the admin container, control container, or both.
Admin container:
apiclient set host-containers.admin.enabled=true
Control container:
apiclient set host-containers.control.enabled=true
- Exit the shell and delete the
regain-access
pod. The Bottlerocket node should be accessible again.
Steps to Regain Access on ECS
Bottlerocket does not yet support ecs exec
, so this solution to regain access does not yet work on ECS.