使用专用 KubeConfig 访问子集群
Before moving forward, please follow this guide to make sure
that redirecting requests by clusternet-hub are supported in your parent cluster.
您需要按照以下 2 个步骤 来构建专用 kubeconfig 来使用 kubectl 访问子集群。
步骤一: 修改服务器地址
在/apis/proxies.clusternet.io/v1alpha1/sockets/<CLUSTER-ID>/proxy/https/<SERVER-URL>
或者/apis/proxies.clusternet.io/v1alpha1/sockets/<CLUSTER-ID>/proxy/direct 在parent cluster的末尾
附加服务器地址
CLUSTER-ID是您的子集群的 UUID,由clusternet-agent自动填充,例如 dc91021d-2361-4f6d-a404-7c33b9e01118。您可以从 ClusterRegistrationRequest,ManagedCluster等资源对象中获取此 UUID。这个 UUID 也以键值为 clusters.clusternet.io/cluster-id 的标签存在。SERVER-URL是你的子集群的 apiserver 地址,它可以是localhost、127.0.0.1等等,前提是clusternet-agent可以访问。
您可以按照以下命令帮助修改上述更改。
Note
Clusternet 支持 http 和 https 方案。
如果你想使用方案http来演示它是如何工作的,即/apis/proxies.clusternet.io/v1alpha1/sockets/<CLUSTER-ID>/proxy/http/<SERVER-URL>,
您可以简单地在您的子集群中运行本地代理,例如,
请将 10.212.0.7 替换为您的真实本地IP地址。
然后也按照上面的 url 修改。
步骤 2:从子集群配置凭证
然后使用来自子集群的凭据更新用户条目。
Note
Clusternet-hub 根本不关心这些凭据,直接将它们传递给子集群。如果您使用令牌
这里的令牌可以是 bootstrap tokens, ServiceAccount tokens ,等等。
请按照以下修改。
请将 BASE64-DECODED-PLEASE-CHANGE-ME 替换为对子集群有效的令牌。 请注意此处替换的令牌应经过 base64 解码。
Important Note
如果不允许匿名身份验证,请将 username: system:anonymous 替换为 token: PARENT-CLUSTER-TOKEN。
在这里,可以使用以下命令检索 PARENT-CLUSTER-TOKEN,
如果您使用 TLS 证书
请按照以下修改。
请替换 CLIENT-CERTIFICATE-DATE-BASE64-ENCODED-PLEASE-CHANGE-ME
以及带有来自子集群的证书和私钥的“CLIENT-KEY-DATE-PLEASE-BASE64-ENCODED-CHANGE-ME”。 请注意这里替换的标记应该是base64编码的。
Important Note
如果不允许匿名身份验证,请将 username: system:anonymous 替换为 token: PARENT-CLUSTER-TOKEN。
在这里,可以使用以下命令检索 PARENT-CLUSTER-TOKEN,
Feedback
Was this page helpful?
Glad to hear it! Please tell us how we can improve.
Sorry to hear that. Please tell us how we can improve.