Developers can use kubectl exec to run commands in a container. This guide demonstrates two use cases.
Kubernetes exposes services through environment variables. It is convenient to check these environment variables using kubectl exec.
We first create a pod and a service,
$ kubectl create -f examples/guestbook/redis-master-controller.yaml
$ kubectl create -f examples/guestbook/redis-master-service.yamlwait until the pod is Running and Ready,
$ kubectl get pod
NAME                 READY     REASON       RESTARTS   AGE
redis-master-ft9ex   1/1       Running      0          12sthen we can check the environment variables of the pod,
$ kubectl exec redis-master-ft9ex env
...
REDIS_MASTER_SERVICE_PORT=6379
REDIS_MASTER_SERVICE_HOST=10.0.0.219
...We can use these environment variables in applications to find the service.
It is convenient to use kubectl exec to check if the volumes are mounted as expected.
We first create a Pod with a volume mounted at /data/redis,
kubectl create -f docs/user-guide/walkthrough/pod-redis.yamlwait until the pod is Running and Ready,
$ kubectl get pods
NAME      READY     REASON    RESTARTS   AGE
storage   1/1       Running   0          1mwe then use kubectl exec to verify that the volume is mounted at /data/redis,
$ kubectl exec storage ls /data
redisAfter all, open a terminal in a pod is the most direct way to introspect the pod. Assuming the pod/storage is still running, run
$ kubectl exec -ti storage -- bash
root@storage:/data#This gets you a terminal.