使用端口转发来访问集群中的应用

    • 你必须拥有一个 Kubernetes 的集群,同时你的 Kubernetes 集群必须带有 kubectl 命令行工具。 如果你还没有集群,你可以通过 构建一 个你自己的集群,或者你可以使用下面任意一个 Kubernetes 工具构建:

      要获知版本信息,请输入 kubectl version.

    • 安装 redis-cli

    1. 创建一个 Redis deployment:

      查看输出是否成功,以验证是否成功创建 deployment:

      1. deployment.apps/redis-master created

      查看 pod 状态,检查其是否准备就绪:

      1. kubectl get pods

      输出显示创建的 pod:

      1. redis-master-765d459796-258hz 1/1 Running 0 50s

      查看 deployment 状态:

      1. kubectl get deployment

      输出显示创建的 deployment:

      1. NAME DESIRED CURRENT UP-TO-DATE AVAILABLE AGE
      2. redis-master 1 1 1 1 55s

      输出显示创建的 replicaset:

    2. 创建一个 Redis 服务:

      1. kubectl apply -f https://k8s.io/examples/application/guestbook/redis-master-service.yaml

      查看输出是否成功,以验证是否成功创建 service:

      1. service/redis-master created

      检查 service 是否创建:

      1. kubectl get svc | grep redis

      输出显示创建的 service:

      1. NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
      2. redis-master ClusterIP 10.0.0.213 <none> 6379/TCP 27s
    3. 验证 Redis 服务是否运行在 pod 中并且监听 6379 端口:

      1. --template='{{(index (index .spec.containers 0).ports 0).containerPort}}{{"\n"}}'

      输出应该显示端口:

      1. 6379
    1. 从 Kubernetes v1.10 开始, 允许使用资源名称 (例如 pod 名称)来选择匹配的 pod 来进行端口转发。

      这相当于

      1. kubectl port-forward pods/redis-master-765d459796-258hz 7000:6379
      1. kubectl port-forward deployment/redis-master 7000:6379

      或者

      1. kubectl port-forward rs/redis-master 7000:6379

      或者

      1. kubectl port-forward svc/redis-master 7000:redis

      以上所有命令都应该有效。输出应该类似于:

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

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

      成功的 ping 请求应该返回 PONG。

    与本地 7000 端口建立的连接将转发到运行 Redis 服务器的 pod 的 6379 端口。 通过此连接,您可以使用本地工作站来调试在 pod 中运行的数据库。

    进一步了解 。