Demo Workload Deployment¶
In this chapter, we will present how workloads can be deployed as a Kubernetes pod with gradually increasing security levels:
- Regular Kubernetes pod.
- Pod isolated by Kata Containers.
- Pod isolated by Kata Containers and protected by Intel TDX.
- Pod isolated by Kata Containers, protected with Intel TDX, and Quote verified using a KBS with an attestation service.
For now, we use nginx as a workload example. Further workloads might be added later.
Disclaimer
The provided deployment files are only for demonstration purposes, which can be used in a development environment. You are responsible to properly set up your production environment.
nginx Deployment in Pods of Increasing Security Levels¶
The following subsections describe how to deploy nginx in pods with the gradually increasing security levels listed in the introduction. Finally, we will provide instructions on how to clean up all pods.
Regular Kubernetes Pod¶
To start nginx in a regular Kubernetes pod and to verify the cluster setup, perform the following steps:
-
Save the provided pod configuration as
nginx.yaml
:apiVersion: v1 kind: Pod metadata: name: nginx spec: containers: - name: nginx image: nginx:1.27.0 ports: - containerPort: 80
-
Start nginx:
kubectl apply -f nginx.yaml
-
Check the pod status:
kubectl get pods
Expected output:
NAME READY STATUS RESTARTS AGE nginx 1/1 Running (...)
Pod isolated by Kata Containers¶
To isolate nginx using a Kata Container pod and to be sure that the Kata Containers runtime is working, perform the following steps:
-
Save the provided pod configuration as
nginx-vm.yaml
:apiVersion: v1 kind: Pod metadata: name: nginx-vm spec: runtimeClassName: kata-qemu containers: - name: nginx image: nginx:1.27.0 ports: - containerPort: 80
Compared to the last security level, the only difference in the pod configuration is the pod name and the usage of
kata-qemu
as runtime class. -
Start nginx:
kubectl apply -f nginx-vm.yaml
-
Check the pod status:
kubectl get pods
Expected output:
NAME READY STATUS RESTARTS AGE nginx-vm 1/1 Running (...)
Pod Isolated by Kata Containers and Protected by Intel TDX¶
To isolate nginx using a Kata Container and to protect it using Intel TDX, perform the following steps:
-
Save the provided pod configuration as
nginx-td.yaml
for this setup:apiVersion: v1 kind: Pod metadata: name: nginx-td spec: runtimeClassName: kata-qemu-tdx containers: - name: nginx image: nginx:1.27.0 ports: - containerPort: 80
Compared to the last security level, the only difference in the pod configuration is the pod name and the usage of
kata-qemu-tdx
as runtime class. -
Start nginx:
kubectl apply -f nginx-td.yaml
-
Check the pod status:
kubectl get pods
Expected output for success:
NAME READY STATUS RESTARTS AGE nginx-td 1/1 Running (...)
In case the pods are not in
Running
state, refer to the Troubleshooting section.
Pod Isolated by Kata Containers, Protected with Intel TDX, and Quote Verified using a KBS with an attestation service¶
Finally, we explore how to isolate nginx using Kata Containers, how to protect nginx using Intel TDX, and how to verify the nginx deployment using attestation - for which we use the attestation service integration into the Confidential Containers KBS.
To deploy and verify a protected nginx, follow the steps below:
-
Set the KBS address to be used in pod's yaml file:
export KBS_ADDRESS=http://$(kubectl get nodes -o jsonpath='{.items[0].status.addresses[0].address}'):$(kubectl get svc kbs -n coco-tenant -o jsonpath='{.spec.ports[0].nodePort}')
-
Create pod's yaml file
nginx-td-attestation.yaml
for this setup:cat <<EOF > nginx-td-attestation.yaml apiVersion: v1 kind: Pod metadata: name: nginx-td-attestation annotations: io.katacontainers.config.hypervisor.kernel_params: "agent.guest_components_rest_api=all agent.aa_kbc_params=cc_kbc::${KBS_ADDRESS}" spec: runtimeClassName: kata-qemu-tdx initContainers: - name: init-attestation image: storytel/alpine-bash-curl:latest command: ["/bin/sh","-c"] args: - | echo starting; (curl http://127.0.0.1:8006/aa/token\?token_type\=kbs | grep -iv "get token failed" | grep -iv "error" | grep -i token && echo "ATTESTATION COMPLETED SUCCESSFULLY") || (echo "ATTESTATION FAILED" && exit 1); containers: - name: nginx image: nginx:1.27.0 ports: - containerPort: 80 EOF
Compared to the last security level, the differences in the pod configuration are:
- The name of the pod.
- Additional annotation to enable the attestation component in Kata Containers.
- Additional
init
container to trigger the attestation and ensure that nginx container is started only if the attestation is successful.
For details about the used parameters and available parameters, see the following documentation:
-
Start nginx:
kubectl apply -f nginx-td-attestation.yaml
-
Check the pod status:
kubectl get pods
-
If the output reports the pod in the
Running
state, it means that Intel TDX attestation completed successfully:NAME READY STATUS RESTARTS AGE nginx-td-attestation 1/1 Running (...)
-
If the pod is not in
Running
state for a few minutes, you can review the attestation logs to identify the issue:kubectl logs pod/nginx-td-attestation -c init-attestation
-
Expected output for success:
starting (...) {"token":"<TOKEN>","tee_keypair":"<TEE_KEYPAIR>"} ATTESTATION COMPLETED SUCCESSFULLY
In case of attestation failure, refer to the troubleshooting section.
-
Cleanup All Pods¶
Warning
If necessary, backup your work before proceeding with the cleanup.
To remove the deployed components from the Kubernetes cluster, execute the following commands to remove the pods:
kubectl delete -f nginx.yaml
kubectl delete -f nginx-vm.yaml
kubectl delete -f nginx-td.yaml
kubectl delete -f nginx-td-attestation.yaml