kubectl源码分析之config delete-cluster

Istio高级配置实战

 欢迎关注我的公众号:

 目前刚开始写一个月,一共写了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完全手册

 

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

//创建delete-cluster命令
func NewCmdConfigDeleteCluster(out io.Writer, configAccess clientcmd.ConfigAccess) *cobra.Command {
	cmd := &cobra.Command{//创建cobra命令
		Use:                   "delete-cluster NAME",
		DisableFlagsInUseLine: true,
		Short:                 i18n.T("Delete the specified cluster from the kubeconfig"),
		Long:                  "Delete the specified cluster from the kubeconfig",
		Example:               deleteClusterExample,
		Run: func(cmd *cobra.Command, args []string) {
			cmdutil.CheckErr(runDeleteCluster(out, configAccess, cmd))//运行
		},
	}

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

	args := cmd.Flags().Args()//获取参数
	if len(args) != 1 {//参数不为1个报错
		cmd.Help()
		return nil
	}

	configFile := configAccess.GetDefaultFilename()//获取config文件名称
	if configAccess.IsExplicitFile() {//如果config文件使用--kubeconfig指定的
		configFile = configAccess.GetExplicitFile()// 获取指定的config文件名称
	}

	name := args[0]//获取cluster名称
	_, ok := config.Clusters[name]//判断cluster是否存在
	if !ok {// 如果不存在则报错
		return fmt.Errorf("cannot delete cluster %s, not in %s", name, configFile)
	}

	delete(config.Clusters, name)//从config中删除cluster

	if err := clientcmd.ModifyConfig(configAccess, *config, true); err != nil {//把配置写回文件
		return err
	}

	fmt.Fprintf(out, "deleted cluster %s from %s\n", name, configFile)//打印结果

	return nil
}

### `kubectl config set-cluster` 命令设置实例 以下命令用于添加一个新的集群配置到 kubeconfig 中,指定集群的名称、API 服务器地址和证书颁发机构(CA)文件路径: ```bash kubectl config set-cluster my-cluster \ --server=https://my-k8s-api-server.example.com:6443 \ --certificate-authority=/path/to/ca.crt ``` 此命令将名为 `my-cluster` 的集群信息添加到 kubeconfig 中,指定 API 服务器地址为 `https://my-k8s-api-server.example.com:6443`,并使用 `/path/to/ca.crt` 作为证书颁发机构文件。 ### `kubectl config set-credentials` 命令设置实例 以下命令使用基本认证(用户名和密码)添加用户凭证: ```bash kubectl config set-credentials my-user \ --username=admin \ --password=password123 ``` 该命令为名为 `my-user` 的用户设置了用户名 `admin` 和密码 `password123`。 也可以使用客户端证书认证的方式设置用户凭证: ```bash kubectl config set-credentials my-user \ --client-certificate=/path/to/client.crt \ --client-key=/path/to/client.key ``` 此命令为 `my-user` 用户指定了客户端证书文件 `/path/to/client.crt` 和客户端私钥文件 `/path/to/client.key`。 ### `kubectl config set-context` 命令设置实例 以下命令设置一个新的上下文,关联之前设置的集群和用户,并指定命名空间: ```bash kubectl config set-context my-context \ --cluster=my-cluster \ --user=my-user \ --namespace=my-namespace ``` 该命令创建了一个名为 `my-context` 的上下文,将其关联到 `my-cluster` 集群和 `my-user` 用户,并指定默认命名空间为 `my-namespace`。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

hxpjava1

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

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

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

打赏作者

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

抵扣说明:

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

余额充值