Module 3 - Explore your app
Difficulty: Beginner Estimated Time: 10 minutes
In this scenario you will learn how to troubleshoot Kubernetes applications using the kubectl get, describe, logs and exec commands.
Step 1 - Check application configuration
Let’s verify that the application we deployed in the previous scenario is running. We’ll use the kubectl get
command and look for existing Pods:
Next, to view what containers are inside that Pod and what images are used to build those containers we run the describe pods
command:
We see here details about the Pod’s container: IP address, the ports used and a list of events related to the lifecycle of the Pod.
The output of the describe
command is extensive and covers some concepts that we didn’t explain yet, but don’t worry, they will become familiar by the end of this bootcamp.
Note: the describe command can be used to get detailed information about most of the Kubernetes primitives: node, pods, deployments. The describe output is designed to be human readable, not to be scripted against.
Step 2 - Show the app in the terminal
Recall that Pods are running in an isolated, private network - so we need to proxy access to them so we can debug and interact with them. To do this, we’ll use the kubectl proxy
command to run a proxy in a second terminal window. Run the command below in a new terminal window to run the proxy:
Now again, we’ll get the Pod name and query that pod directly through the proxy. To get the Pod name and store it in the POD_NAME ennvironment variable:
To see the output of our application, run a curl
request.
The url is the route to the API of the Pod.
Step 3 - View the container logs
Anything that the application would normally send to STDOUT
becomes logs for the container within the Pod. We can retrieve these logs using the kubectl logs
command:
*Note: We don’t need to specify the container name, because we only have one container inside the pod.
Step 4 - Executing command on the container
We can execute commands directly on the container once the Pod is up and running. For this, we use the exec
command and use the name of the Pod as a parameter. Let’s list the environment variables:
Again, worth mentioning that the name of the container itself can be omitted since we only have a single container in the Pod.
Next let’s start a bash session in the Pod’s container:
We have now an open console on the container where we run our NodeJS application. The source code of the app is in the server.js file:
You can check that the application is up by running a curl command:
Note: here we used localhost because we executed the command inside the NodeJS Pod. If you cannot connect to localhost:8080, check to make sure you have run the kubectl exec command and are launching the command from within the Pod
To close your container connection type exit
.
Feedback
Was this page helpful?
Glad to hear it! Please tell us how we can improve.
Sorry to hear that. Please tell us how we can improve.