Podtnl 是一个不通过暴露 Kubernetes Service 服务也可以在线访问 Pod 的一个功能强大的 CLI 工具。
Podtnl 使用了两个主要的概念:端口转发和隧道。Podtnl 使用非常简单,特别是在应用开发阶段非常有用,完全不用担心有没有创建 Ingress、LoadBalancer 等资源。

Podtnl 安装
直接下载 GitHub 仓库上 Release 的二进制文件,开箱即用。
1 | $ wget https://github.com/narendranathreddythota/podtnl/releases/download/1.0/podtnl |
如果你使用 macOS,你还可以使用 Homebrew 进行安装。
1 | $ brew tap narendranathreddythota/podtnl |
Podtnl 使用
要使用 Podtnl ,你需要先提供一个隧道。目前 Podtnl 只支持 Ngrok 作为隧道提供商,所以需要提前安装配置好 Ngrok。你可以通过地址 https://dashboard.ngrok.com/get-started/setup 进行配置。
当 Podtnl 和 Ngrok 都配置好过后,即可使用 Podtnl。 Podtnl 可以使用的一些命令如下所示:
1 | Available Flage |
比如:当前 Kubernetes 集群中在 kube-ops 命名空间下面有如下一个 Pod,容器暴露 8080 端口:
1 | $ kubectl get pods -n kube-ops |
我们就可以按照如下所示的命令来直接暴露该 Pod:
1 | $ podtnl -provider ngrok -podname devops-name-devops-demo-7cf5fcc5c6-j76h5 -podport 8080 -namespace kube-ops |
然后我们可以使用上面生成的地址 https://c13f78fe.ngrok.io 来直接访问该 Pod。默认会使用 Basic Auth 认证方式,使用上面生成的 Username 和 Password 即可认证。
如果 Pod 是 TCP 服务需要直接暴露,则需添加 protocol 参数指定即可。
1 | $ podtnl -provider ngrok -podname orderer1-7cb4b7565-nv95k -podport 7050 -protocol tcp |
更多好用的玩法,你可以去 「Podtnl 官网」进行探索哟!
本文转载自:「k8s 技术圈」,原文:https://tinyurl.com/y6urwkgt,版权归原作者所有。欢迎投稿,投稿邮箱:
editor@hi-linux.com。