You are viewing documentation for Kubernetes version: v1.30
Kubernetes v1.30 documentation is no longer actively maintained. The version you are currently viewing is a static snapshot. For up-to-date information, see the latest version.
Use Port Forwarding to Access Applications in a Cluster
This page shows how to use kubectl port-forward to connect to a MongoDB
server running in a Kubernetes cluster. This type of connection can be useful
for database debugging.
Before you begin
- You need to have a Kubernetes cluster, and the kubectl command-line tool must be configured to communicate with your cluster. It is recommended to run this tutorial on a cluster with at least two nodes that are not acting as control plane hosts. If you do not already have a cluster, you can create one by using minikube or you can use one of these Kubernetes playgrounds: Your Kubernetes server must be at or later than version v1.10. To check the version, enter- kubectl version.
- Install MongoDB Shell.
Creating MongoDB deployment and service
- 
Create a Deployment that runs MongoDB: kubectl apply -f https://k8s.io/examples/application/mongodb/mongo-deployment.yamlThe output of a successful command verifies that the deployment was created: deployment.apps/mongo createdView the pod status to check that it is ready: kubectl get podsThe output displays the pod created: NAME READY STATUS RESTARTS AGE mongo-75f59d57f4-4nd6q 1/1 Running 0 2m4sView the Deployment's status: kubectl get deploymentThe output displays that the Deployment was created: NAME READY UP-TO-DATE AVAILABLE AGE mongo 1/1 1 1 2m21sThe Deployment automatically manages a ReplicaSet. View the ReplicaSet status using: kubectl get replicasetThe output displays that the ReplicaSet was created: NAME DESIRED CURRENT READY AGE mongo-75f59d57f4 1 1 1 3m12s
- 
Create a Service to expose MongoDB on the network: kubectl apply -f https://k8s.io/examples/application/mongodb/mongo-service.yamlThe output of a successful command verifies that the Service was created: service/mongo createdCheck the Service created: kubectl get service mongoThe output displays the service created: NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE mongo ClusterIP 10.96.41.183 <none> 27017/TCP 11s
- 
Verify that the MongoDB server is running in the Pod, and listening on port 27017: # Change mongo-75f59d57f4-4nd6q to the name of the Pod kubectl get pod mongo-75f59d57f4-4nd6q --template='{{(index (index .spec.containers 0).ports 0).containerPort}}{{"\n"}}'The output displays the port for MongoDB in that Pod: 2701727017 is the official TCP port for MongoDB. 
Forward a local port to a port on the Pod
- 
kubectl port-forwardallows using resource name, such as a pod name, to select a matching pod to port forward to.# Change mongo-75f59d57f4-4nd6q to the name of the Pod kubectl port-forward mongo-75f59d57f4-4nd6q 28015:27017which is the same as kubectl port-forward pods/mongo-75f59d57f4-4nd6q 28015:27017or kubectl port-forward deployment/mongo 28015:27017or kubectl port-forward replicaset/mongo-75f59d57f4 28015:27017or kubectl port-forward service/mongo 28015:27017Any of the above commands works. The output is similar to this: Forwarding from 127.0.0.1:28015 -> 27017 Forwarding from [::1]:28015 -> 27017Note:kubectl port-forwarddoes not return. To continue with the exercises, you will need to open another terminal.
- 
Start the MongoDB command line interface: mongosh --port 28015
- 
At the MongoDB command line prompt, enter the pingcommand:db.runCommand( { ping: 1 } )A successful ping request returns: { ok: 1 }
Optionally let kubectl choose the local port
If you don't need a specific local port, you can let kubectl choose and allocate
the local port and thus relieve you from having to manage local port conflicts, with
the slightly simpler syntax:
kubectl port-forward deployment/mongo :27017
The kubectl tool finds a local port number that is not in use (avoiding low ports numbers,
because these might be used by other applications). The output is similar to:
Forwarding from 127.0.0.1:63753 -> 27017
Forwarding from [::1]:63753 -> 27017
Discussion
Connections made to local port 28015 are forwarded to port 27017 of the Pod that is running the MongoDB server. With this connection in place, you can use your local workstation to debug the database that is running in the Pod.
Note:
kubectl port-forward is implemented for TCP ports only.
The support for UDP protocol is tracked in
issue 47862.What's next
Learn more about kubectl port-forward.