connecting-to-applications-port-forward


weight: 94 title:通过端口转发访问集群中的应用程序 date: ‘2022-05-21T00:00:00+08:00’ type: book

本页向您展示如何使用 kubectl port-forward 命令连接到运行在Kubernetes集群中的Redis服务器。这种类型的连接对于数据库调试很有帮助。

创建一个Pod来运行Redis服务器

  1. 创建一个Pod

    kubectl create -f https://k8s.io/docs/tasks/access-application-cluster/redis-master.yaml
    

    命令运行成功后将有以下输出验证该Pod是否已经创建:

    pod "redis-master" created
    
  2. 检查Pod是否正在运行且处于就绪状态:

    kubectl get pods
    

    Pod就绪,输出显示Running的状态:

     NAME           READY     STATUS    RESTARTS   AGE
     redis-master   2/2       Running   0          41s
    
  3. 验证Redis服务器是否已在Pod中运行,并监听6379端口:

    {% raw %}
    kubectl get pods redis-master --template='{{(index (index .spec.containers 0).ports 0).containerPort}}{{"\n"}}'
    {% endraw %}
    

    端口输出如下:

    6379
    

将本地端口转发到Pod中的端口

  1. 将本地工作站上的6379端口转发到redis-master pod6379端口:

    kubectl port-forward redis-master 6379:6379
    

    输出类似于:

     I0710 14:43:38.274550    3655 portforward.go:225] Forwarding from 127.0.0.1:6379 -> 6379
     I0710 14:43:38.274797    3655 portforward.go:225] Forwarding from [::1]:6379 -> 6379
    
  2. 启动Redis命令行界面

    redis-cli
    
  3. Redis命令行提示符下,输入 ping 命令:

    127.0.0.1:6379>ping
    

    Ping请求成功返回PONG

讨论

创建连接,将本地的6379端口转发到运行在Pod中的Redis服务器的6379端口。有了这个连接您就可以在本地工作站中调试运行在Pod中的数据库。

上一页
下一页