kubectl源码分析之config get-clusters

 欢迎关注我的公众号:

 目前刚开始写一个月,一共写了18篇原创文章,文章目录如下:

istio多集群探秘,部署了50次多集群后我得出的结论

istio多集群链路追踪,附实操视频

istio防故障利器,你知道几个,istio新手不要读,太难!

istio业务权限控制,原来可以这么玩

istio实现非侵入压缩,微服务之间如何实现压缩

不懂envoyfilter也敢说精通istio系列-http-rbac-不要只会用AuthorizationPolicy配置权限

不懂envoyfilter也敢说精通istio系列-02-http-corsFilter-不要只会vs

不懂envoyfilter也敢说精通istio系列-03-http-csrf filter-再也不用再代码里写csrf逻辑了

不懂envoyfilter也敢说精通istio系列http-jwt_authn-不要只会RequestAuthorization

不懂envoyfilter也敢说精通istio系列-05-fault-filter-故障注入不止是vs

不懂envoyfilter也敢说精通istio系列-06-http-match-配置路由不只是vs

不懂envoyfilter也敢说精通istio系列-07-负载均衡配置不止是dr

不懂envoyfilter也敢说精通istio系列-08-连接池和断路器

不懂envoyfilter也敢说精通istio系列-09-http-route filter

不懂envoyfilter也敢说精通istio系列-network filter-redis proxy

不懂envoyfilter也敢说精通istio系列-network filter-HttpConnectionManager

不懂envoyfilter也敢说精通istio系列-ratelimit-istio ratelimit完全手册

 

———————————————

//创建get-clusters命令
func NewCmdConfigGetClusters(out io.Writer, configAccess clientcmd.ConfigAccess) *cobra.Command {
	cmd := &cobra.Command{//创建cobra命令
		Use:     "get-clusters",
		Short:   i18n.T("Display clusters defined in the kubeconfig"),
		Long:    "Display clusters defined in the kubeconfig.",
		Example: getClustersExample,
		Run: func(cmd *cobra.Command, args []string) {
			cmdutil.CheckErr(runGetClusters(out, configAccess))//运行
		},
	}

	return cmd
}

//运行
func runGetClusters(out io.Writer, configAccess clientcmd.ConfigAccess) error {
	config, err := configAccess.GetStartingConfig()//加载config
	if err != nil {
		return err
	}

	fmt.Fprintf(out, "NAME\n")//打印head
	for name := range config.Clusters {//遍历clusters,打印name
		fmt.Fprintf(out, "%s\n", name)
	}

	return nil
}

### `.kube/config` 文件存在但 `kubectl config get-contexts` 无输出的解决方案 当 `.kube/config` 文件存在但 `kubectl config get-contexts` 没有输出时,通常意味着配置文件格式错误、路径未正确设置或环境变量干扰。以下为排查和解决方法: #### 验证 `.kube/config` 文件路径 默认情况下,`kubectl` 会从 `$HOME/.kube/config` 路径加载配置文件。若当前用户目录下没有 `.kube` 目录或该目录下的 `config` 文件缺失,则无法读取上下文信息。需确保配置文件位于预期路径,并具有正确的权限设置: ```bash mkdir -p $HOME/.kube cp /etc/kubernetes/admin.conf $HOME/.kube/config chown $(id -u):$(id -g) $HOME/.kube/config ``` 上述操作可确保 `.kube/config` 文件存在并归属当前用户[^2]。 #### 检查 KUBECONFIG 环境变量 如果设置了 `KUBECONFIG` 环境变量,`kubectl` 将优先使用该变量指定的配置文件路径。可通过以下命令查看当前环境变量设置: ```bash echo $KUBECONFIG ``` 若输出非空且指向了不存在或无效的配置文件,则可能导致 `kubectl` 忽略默认路径下的有效配置。应清除或更新该变量: ```bash unset KUBECONFIG ``` 或指定正确的路径: ```bash export KUBECONFIG=/path/to/valid/kubeconfig ``` 此方式可避免因环境变量干扰导致的配置加载失败[^2]。 #### 验证 `.kube/config` 文件内容 `.kube/config` 是一个 YAML 格式的文件,用于定义集群、用户、上下文等信息。若文件结构不完整或语法错误(如缩进不一致、字段拼写错误),`kubectl` 将无法解析其中的上下文信息。可通过以下命令验证其格式: ```bash kubectl config view --raw > /tmp/config.tmp && kubelet --kubeconfig=/tmp/config.tmp version ``` 若提示错误,则表明配置文件存在问题。应参考标准模板修复配置内容,确保包含完整的 `clusters`、`users` 和 `contexts` 字段,并设置 `current-context` 指向有效的上下文名称[^1]。 #### 手动添加上下文信息 若确认配置文件存在但缺少上下文定义,可手动添加新的上下文条目。例如,使用以下命令将新集群和用户组合加入现有配置: ```bash kubectl config set-cluster my-cluster --server=https://my-cluster-api:6443 --certificate-authority=/path/to/ca.crt kubectl config set-credentials my-user --client-certificate=/path/to/client.crt --client-key=/path/to/client.key kubectl config set-context my-context --cluster=my-cluster --user=my-user kubectl config use-context my-context ``` 上述命令依次设置集群、用户、上下文并切换至新增上下文,从而确保 `kubectl` 可识别并使用新配置[^3]。 #### 清理缓存并重启服务 在某些情况下,`kubectl` 或 `kubelet` 服务可能因缓存问题未能及时加载新配置。建议重启相关服务以刷新配置: ```bash systemctl restart kubelet ``` 同时,清除本地 `kubectl` 缓存(如有)并重新执行命令以确认上下文是否生效: ```bash kubectl config get-contexts ``` 此举有助于排除由服务状态异常引发的配置加载失败问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hxpjava1

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值