特性状态: Kubernetes v1.24 [stable]
本文展示了如何使用 SOCKS5 代理访问远程 Kubernetes 集群的 API。 当你要访问的集群不直接在公共 Internet 上公开其 API 时,这很有用。
你必须拥有一个 Kubernetes 的集群,同时你的 Kubernetes 集群必须带有 kubectl 命令行工具。 建议在至少有两个节点的集群上运行本教程,且这些节点不作为控制平面主机。 如果你还没有集群,你可以通过 Minikube 构建一个你自己的集群,或者你可以使用下面任意一个 Kubernetes 工具构建:
您的 Kubernetes 服务器版本必须是 v1.24. 要获知版本信息,请输入 kubectl version
。
你需要 SSH 客户端软件(ssh
工具),并在远程服务器上运行 SSH 服务。 你必须能够登录到远程服务器上的 SSH 服务。
说明: 此示例使用 SSH 隧道传输流量,SSH 客户端和服务器充当 SOCKS 代理。 你可以使用其他任意类型的 SOCKS5 代理代替。
图 1 表示你将在此任务中实现的目标。
图 1. SOCKS5 教程组件
此命令在你的客户端计算机和远程服务器之间启动一个 SOCKS5 代理。 SOCKS5 代理允许你连接到集群的 API 服务器。
# 运行此命令后,SSH 隧道继续在前台运行
ssh -D 1080 -q -N username@kubernetes-remote-server.example
-D 1080
: 在本地端口 1080 上打开一个 SOCKS 代理。
-q
: 静音模式。导致大多数警告和诊断消息被抑制。
-N
: 不执行远程命令。仅用于转发端口。
username@kubernetes-remote-server.example
: 运行 Kubernetes 集群的远程 SSH 服务器。要探索 Kubernetes API,你首先需要指示你的客户端通过我们之前创建的 SOCKS5 代理发送他们的查询。 对于命令行工具,设置 https_proxy
环境变量并将其传递给你运行的命令。
export https_proxy=socks5h://localhost:1080
当你设置 https_proxy
变量时,curl
等工具会通过你配置的代理路由 HTTPS 流量。 为此,该工具必须支持 SOCKS5 代理。
说明: 在 URL https://localhost/api 中,
localhost
不是指你的本地客户端计算机。 它指的是远程服务器上称为 “localhost” 的端点。 curl
工具通过 SOCKS 从 HTTPS URL 发送主机名,远程服务器在本地解析(到属于其环回接口的地址)。
curl -k -v https://localhost/api
要将官方 Kubernetes 客户端 kubectl
与代理一起使用,请在 ~/.kube/config
文件中为相关的 cluster
条目设置 proxy-url
元素。 例如:
apiVersion: v1
clusters:
- cluster:
certificate-authority-data: LRMEMMW2 # 为了便于阅读缩短
server: https://localhost # 上图中的“Kubernetes API”
proxy-url: socks5://localhost:1080 # 上图中的“SSH SOCKS5代理”(内置DNS解析)
name: default
contexts:
- context:
cluster: default
user: default
name: default
current-context: default
kind: Config
preferences: {}
users:
- name: default
user:
client-certificate-data: LS0tLS1CR== # 为了便于阅读缩短
client-key-data: LS0tLS1CRUdJT= # 为了便于阅读缩短
如果隧道能够正常工作,并且你调用 kubectl
时使用此集群的上下文, 则可以通过该代理与你的集群交互。 例如:
kubectl get pods
NAMESPACE NAME READY STATUS RESTARTS AGE
kube-system coredns-85cb69466-klwq8 1/1 Running 0 5m46s
通过在运行它的终端上按“CTRL+C”来停止 ssh 端口转发进程。
在终端中键入 unset https_proxy
以停止通过代理转发 http 流量。
Docker attach 命令Docker 命令大全docker attach :连接到正在运行中的容器。语法docker attach [OPTIONS] CONTAINER要attach上...
Docker export 命令Docker 命令大全docker export :将文件系统作为一个tar归档文件导出到STDOUT。语法docker export [OPTIONS] C...
Docker diff 命令Docker 命令大全docker diff : 检查容器里文件结构的更改。语法docker diff [OPTIONS] CONTAINER实例查看容器my...
jQuery Mobile 实例 jQuery Mobile 页面一个基本的移动网页 多个页面 对话框实例解释jQuery Mobile 页面切换淡入效果 从后向前翻...
Android资源将配置概念概括为设备的任何配置。语言是一个配置选择。Android允许你基于相同资源ID的布局模式选择不同的布局集。An...