DEV Community

Cover image for Kubernetes Port Forward Command: A Comprehensive Guide
Labby for LabEx

Posted on • Originally published at labex.io

Kubernetes Port Forward Command: A Comprehensive Guide

Introduction

In this lab, you will learn how to use the Kubernetes port-forward command to forward a local port to a port on a pod. You will start with simple examples and gradually progress to more complex scenarios.

Forwarding a Local Port to a Pod

In this step, you will learn how to forward a local port to a port on a pod.

  1. Start by creating a deployment with one replica and an Nginx container:
 kubectl create deployment nginx --image=nginx --replicas=1 
Enter fullscreen mode Exit fullscreen mode
  1. Wait for the pod to become ready:
 kubectl wait --for=condition=Ready pod -l app=nginx 
Enter fullscreen mode Exit fullscreen mode
  1. Use the kubectl port-forward command to forward a local port to the pod:
 kubectl port-forward < pod_name > 19000:80 
Enter fullscreen mode Exit fullscreen mode

Replace <pod_name> with the name of the pod created in step 1, and you can get the <pod_name> with the kubectl get pod -l app=nginx command.

  1. Open a web browser and go to http://localhost:19000 to view the Nginx welcome page.

Forwarding Multiple Local Ports to a Pod

In this step, you will learn how to forward multiple local ports to a pod.

  1. Use the kubectl port-forward command to forward multiple local ports to the pod:
 kubectl port-forward 19443:443 < pod_name > 19080:80 
Enter fullscreen mode Exit fullscreen mode

Replace <pod_name> with the name of the pod created in step 1, and you can get the <pod_name> with the kubectl get pod -l app=nginx command.

  1. Open another terminal and use the ss command at the Linux command line to see if ports 19080 and 19443 are on the host.

Forwarding a Local Port to a Pod with Multiple Containers

In this step, you will learn how to forward a local port to a specific container in a pod with multiple containers.

  1. Create a pod with two containers: Nginx and BusyBox:
 cat << EOF | kubectl apply -f - apiVersion: v1 kind: Pod metadata: name: nginx-busybox spec: containers: - name: nginx image: nginx - name: busybox image: busybox command: - sleep - "3600"  EOF 
Enter fullscreen mode Exit fullscreen mode
  1. Wait for the pod to become ready:
 kubectl wait --for=condition=Ready pod nginx 
Enter fullscreen mode Exit fullscreen mode
  1. Use the kubectl port-forward command to forward a local port to the Nginx container:
 kubectl port-forward nginx-busybox 19001:80 
Enter fullscreen mode Exit fullscreen mode
  1. Open a web browser and go to http://localhost:19001 to view the Nginx welcome page.

Using Port-Forward with Kubernetes Services

In this step, you will learn how to use the kubectl port-forward command with Kubernetes services.

  1. Create a service for the Nginx deployment:
 kubectl expose deployment nginx --port=80 --type=ClusterIP 
Enter fullscreen mode Exit fullscreen mode
  1. Use the kubectl port-forward command to forward a local port to the service:
 kubectl port-forward service/nginx 20000:80 
Enter fullscreen mode Exit fullscreen mode
  1. Open a web browser and go to http://localhost:20000 to view the Nginx welcome page.

Summary

Congratulations, you have successfully completed the Kubernetes port-forward command lab! In this lab, you learned how to forward a local port to a pod, forward multiple local ports to a pod, forward a pod port to a local port, forward a local port to a specific container in a pod with multiple containers, and use the kubectl port-forward command with Kubernetes services. These skills are essential for debugging issues in a Kubernetes cluster.


Want to learn more?

Join our Discord or tweet us @WeAreLabEx ! πŸ˜„

Top comments (1)

Collapse
 
der_gopher profile image
Alex Pliutau

Great write-up, we also have a bunch of articles on Kubernetes, check it out here - packagemain.tech