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
。