写点什么

温柔一刀,优雅且彻底地卸载 Rancher HA

  • 2021-07-30
  • 本文字数:2047 字

    阅读完需:约 7 分钟

温柔一刀,优雅且彻底地卸载Rancher HA

Rancher 从 v2.5 开始,支持将 Rancher HA 安装在任何经过 CNCF 认证的标准 K8s 发行版上,这个集群可以使用上游 Kubernetes,也可以使用 Rancher 的 Kubernetes 发行版之一,也可以是来自 Amazon EKS 等提供商的托管 Kubernetes 集群。无论安装到哪种集群上,Rancher 都推荐使用一个独立的 K8S/K3S 集群作为 Rancher HA 的 Local 集群,这样 Rancher HA 不会和业务集群相互影响。


如果在独立的 Local 集群上卸载 Rancher HA,一般的做法是将 Local 集群删掉,从而达到卸载 Rancher HA 的目的,这样做的好处是比较简单、数据清理得比较彻底。


但有些用户将 Rancher HA 安装到了某些业务或生产集群上,这样的话,就无法通过移除 Local 集群去卸载 Rancher HA。我们需要找到一个办法可以在不影响 Local 集群运行的情况下卸载掉 Rancher HA。


Rancher 提供了一个卸载 Rancher HA 的工具:system-tools。https://rancher.com/docs/rancher/v2.x/en/system-tools/。我们可以借助 system-tools 来将 Rancher HA 生成的 namespace 和其他资源移除。执行 remove 命令会移除以下资源:


  • Rancher 部署的命名空间,默认名称是 cattle-system。

  • Rancher 通过 cattle.io/creator:norman 标签标记的 serviceAccount、 clusterRoles 和 clusterRoleBindings。使用 Rancher v2.1.0 或更新版本创建的所有及资源都会被打上 cattle.io/creator:norman 的标签。

  • Labels、annotations、finalizers。

  • Rancher Deployment。

  • 集群、项目和用户相关的 CRD。

  • management.cattle.io API Group 内创建的所有资源。

  • 使用 Rancher v2.x 创建的所有 CRD。


但 system-tools 年久失修(最后一次更新于 2019 年 4 月 11 日),针对后续 Rancher 版本新增的一些 namespace 等资源并没有被移除,所以导致我们没有一个方法可以完全在 Local 集群上卸载掉 Rancher HA。

卸载 Rancher HA

为了在 Local 集群上彻底卸载掉 Rancher HA,我们可以先筛选出哪些 namesaces 是由 Rancher HA 创建的,然后再通过 system-tools remove --kubeconfig <$KUBECONFIG> --namespace <NAMESPACE> 来删除对应的 namespace 和相关资源。经过测试发现,通过 system-tools 移除 namespace 后,有些 namespace 的状态始终为 Terminating,还需要手动的移除掉.spec.finalizers 和.metadata.finalizers,然后才能彻底的将 namespace 删除。


为此,笔者准备了一个 shell 脚本来完成以上的删除流程:


注意:

  • 本脚本只基于 Rancher v2.5.8 上进行测试,理论上 v2.5.x 系列版本均支持。其他版本(例如:2.4.x)需要修改步骤 4 中对应的 NS 参数来设置要删除的 namespace

  • 本脚本在 Local 集群为 k3s 和 rke 集群上做过验证,如 Local 集群为其他 K8s 集群,需要确认步骤 4 中对应的 NS 参数来设置要删除的 namespace

  • Rancher HA 会创建 c-、p-、user- 开头的 namespace,这些不需要用户关注,当通过 system-tools 移除 cattle-system 会自动将这些 namespace 移除


1.下载脚本

root@ip-172-31-22-79:~# wget https://raw.githubusercontent.com/kingsd041/some_script/master/remove-rancher-ha/remove_r_ha.sh
复制代码


2.在该主机上安装 kubectl、jq、system-tools,并且创建 kubeconfig 文件。


3.编辑脚本,设置 KUBE_CONFIG 目录


KUBE_CONFIG='/root/.kube/config'
复制代码


4.编辑脚本,确认 NS 变量设置的 namespace 是否为将要被删除的 namespace,避免误删 namespace。


NS="cattle-system|*fleet*|rancher-operator-system|cattle-global-nt|cattle-global-data"
复制代码


5.执行脚本,卸载 Rancher HA



root@ip-172-31-22-79:~# ./remove_r_ha.sh
cattle-systemcattle-global-datacattle-global-ntrancher-operator-systemfleet-clusters-systemfleet-localcluster-fleet-local-local-1a3d67d0a899fleet-systemfleet-defaultcluster-fleet-default-c-9zwzq-dd029f17f988Are you sure to remove the above namespace? [y/n] yINFO[0000] Removing Rancher management plane in namespace: [cattle-system]INFO[0000] Getting connection configurationINFO[0000] Removing Cattle deploymentINFO[0000] Removed Cattle deployment succuessfullyINFO[0000] Removing ClusterRoleBindings......
复制代码


大约 5 分钟,脚本执行完成。此时,可以通过 kubectl get ns 来确认 Rancher HA 是否被卸载:



root@ip-172-31-22-79:~# kubectl get nsNAME STATUS AGEkube-public Active 65mdefault Active 65mkube-node-lease Active 65mkube-system Active 65m
复制代码

后记

虽然 Rancher v2.5 开始可以将 Rancher HA 安装在任何经过 CNCF 认证的 K8s 集群上,但还是建议大家在生产环境上将 Rancher HA 安装在一个独立的 Local 集群上,这样可以避免 Rancher HA 和业务集群相互影响。如果你将 Rancher HA 安装到了业务 K8s 集群上,可以使用本文的方式去完美的卸载 Rancher HA,对原集群不会有任何影响。


本文转载自:RancherLabs(ID:RancherLabs)

原文链接:温柔一刀,优雅且彻底地卸载Rancher HA

2021-07-30 07:001965

评论

发布
暂无评论
发现更多内容

阿里云正式开源PolarDB-X数据库,壮大云原生分布式数据库生态

Lily

DeFi去中心化DAPP系统软件开发案例(现成)

10天拿到腾讯Android岗offer,内容太过真实

android 程序员 移动开发

达摩院求解器升级 覆盖黑盒优化难题

Lily

第 21 章 -《Linux 一学就会》- 结构化命令case和for、while循环

学神来啦

docker 安装kafka

大可大大大

金九银十,面试必备!耗时一周整理的牛客网上最火Java面试八股文

Java 程序员 架构 面试 大厂

QCon看点|亚马逊云科技可持续软件工程实践分享

亚马逊云科技 (Amazon Web Services)

软件工程 S3 云端

会计CRM系统软件提高公司管理效率

低代码小观

企业 企业管理 管理会计综合实训平台 CRM 管理系统

腾讯云,五轮面试,六个小时,灵魂拷问,含泪拿下 60W offer

进击的王小二

java面试 大厂面试 java

付费云存储,微信的登云梯还是蜀道难?

海比研究院

云存储

纵观移动云对象存储发展历程,也少不了 Apache APISIX 的能力加持

API7.ai 技术团队

API网关 企业案例 移动云 Apache APISIX

阿里云多个智物新品集体出道,持续加速产业智能化

Lily

收藏!490家专精特新数智企业全名单:听听“小巨人”企业怎么说?

海比研究院

翻车了,字节一道 Fragment面试题

小松漫步

面试 大厂面试 Android;

每秒创建百万文件,百度沧海·文件存储CFS推出新一代Namespace架构

百度大脑

人工智能

2021Android面试笔试总结!html5移动开发即学即用网盘

android 程序员 移动开发

架构设计第一周学习总结

周文

总结思考

数实融合·绽放新机,Techo Day技术回响日邀您“云相聚”

腾讯云数据库

数据库 tdsql

DeFi平台挖矿系统需求开发(现成案例)

2021京东Android面试真题,享学课堂android怎么样

android 程序员 移动开发

阿里云混合云Apsara Stack 2.0发布,加速政企数智创新

架构 操作系统 公有云 科技

Android架构之网络优化

轻口味

android 10月月更

2021大厂安卓知识点总结,字节跳动学习笔记

android 程序员 移动开发

老凡尔赛了!当亚马逊云科技大佬“转行”讲起脱口秀

亚马逊云科技 (Amazon Web Services)

数字化转型 设计师

同为aPaaS平台,华为云开天aPaaS与AppCube有何不同?

海比研究院

aPaaS

2021Android大厂面试题来袭,Android性能优化推荐书

android 程序员 移动开发

2021Android进阶学习资料,动脑学院vip课程百度云

android 程序员 移动开发

2021年Android社招面试题,薪资翻倍

android 程序员 移动开发

Week 1命题作业

小朱

架构实战营

阿里云隐私增强计算产品DataTrust助力产业间实现数据价值高效协同

Lily

温柔一刀,优雅且彻底地卸载Rancher HA_架构_Rancher_InfoQ精选文章