154 lines
3.3 KiB
Markdown
154 lines
3.3 KiB
Markdown
---
|
|
assignees:
|
|
- caesarxuchao
|
|
- mikedanese
|
|
title: Getting a Shell to a Running Container
|
|
redirect_from:
|
|
- "/docs/user-guide/getting-into-containers/"
|
|
- "/docs/user-guide/getting-into-containers.html"
|
|
- "/docs/tasks/kubectl/get-shell-running-container/"
|
|
- "/docs/tasks/kubectl/get-shell-running-container.html"
|
|
---
|
|
|
|
{% capture overview %}
|
|
|
|
This page shows how to use `kubectl exec` to get a shell to a
|
|
running Container.
|
|
|
|
{% endcapture %}
|
|
|
|
|
|
{% capture prerequisites %}
|
|
|
|
{% include task-tutorial-prereqs.md %}
|
|
|
|
{% endcapture %}
|
|
|
|
|
|
{% capture steps %}
|
|
|
|
## Getting a shell to a Container
|
|
|
|
In this exercise, you create a Pod that has one Container. The Container
|
|
runs the nginx image. Here is the configuration file for the Pod:
|
|
|
|
{% include code.html language="yaml" file="shell-demo.yaml" ghlink="/docs/tasks/debug-application-cluster/shell-demo.yaml" %}
|
|
|
|
Create the Pod:
|
|
|
|
```shell
|
|
kubectl create -f https://k8s.io/docs/tasks/debug-application-cluster/shell-demo.yaml
|
|
```
|
|
|
|
Verify that the Container is running:
|
|
|
|
```shell
|
|
kubectl get pod shell-demo
|
|
```
|
|
|
|
Get a shell to the running Container:
|
|
|
|
```shell
|
|
kubectl exec -it shell-demo -- /bin/bash
|
|
```
|
|
|
|
In your shell, list the running processes:
|
|
|
|
```shell
|
|
root@shell-demo:/# ps aux
|
|
```
|
|
|
|
In your shell, list the nginx processes:
|
|
|
|
```shell
|
|
root@shell-demo:/# ps aux | grep nginx
|
|
```
|
|
|
|
In your shell, experiment with other commands. Here are
|
|
some examples:
|
|
|
|
```shell
|
|
root@shell-demo:/# ls /
|
|
root@shell-demo:/# cat /proc/mounts
|
|
root@shell-demo:/# cat /proc/1/maps
|
|
root@shell-demo:/# apt-get update
|
|
root@shell-demo:/# apt-get install tcpdump
|
|
root@shell-demo:/# tcpdump
|
|
root@shell-demo:/# apt-get install lsof
|
|
root@shell-demo:/# lsof
|
|
```
|
|
|
|
## Writing the root page for nginx
|
|
|
|
Look again at the configuration file for your Pod. The Pod
|
|
has an `emptyDir` volume, and the Container mounts the volume
|
|
at `/usr/share/nginx/html`.
|
|
|
|
In your shell, create an `index.html` file in the `/usr/share/nginx/html`
|
|
directory:
|
|
|
|
```shell
|
|
root@shell-demo:/# echo Hello shell demo > /usr/share/nginx/html/index.html
|
|
```
|
|
|
|
In your shell, send a GET request to the nginx server:
|
|
|
|
```shell
|
|
root@shell-demo:/# apt-get update
|
|
root@shell-demo:/# apt-get install curl
|
|
root@shell-demo:/# curl localhost
|
|
```
|
|
|
|
The output shows the text that you wrote to the `index.html` file:
|
|
|
|
```shell
|
|
Hello shell demo
|
|
```
|
|
|
|
When you are finished with your shell, enter `exit`.
|
|
|
|
## Running individual commands in a Container
|
|
|
|
In an ordinary command window, not your shell, list the environment
|
|
variables in the running Container:
|
|
|
|
```shell
|
|
kubectl exec shell-demo env
|
|
```
|
|
|
|
Experiment running other commands. Here are some examples:
|
|
|
|
```shell
|
|
kubectl exec shell-demo ps aux
|
|
kubectl exec shell-demo ls /
|
|
kubectl exec shell-demo cat /proc/1/mounts
|
|
```
|
|
|
|
{% endcapture %}
|
|
|
|
{% capture discussion %}
|
|
|
|
## Opening a shell when a Pod has more than one Container
|
|
|
|
If a Pod has more than one Container, use `--container` or `-c` to
|
|
specify a Container in the `kubectl exec` command. For example,
|
|
suppose you have a Pod named my-pod, and the Pod has two containers
|
|
named main-app and helper-app. The following command would open a
|
|
shell to the main-app Container.
|
|
|
|
```shell
|
|
kubectl exec -it my-pod --container main-app -- /bin/bash
|
|
```
|
|
|
|
{% endcapture %}
|
|
|
|
|
|
{% capture whatsnext %}
|
|
|
|
* [kubectl exec](/docs/user-guide/kubectl/v1.6/#exec)
|
|
|
|
{% endcapture %}
|
|
|
|
|
|
{% include templates/task.md %}
|