当前位置:网站首页>Cross cluster deployment of helm applications using karmada
Cross cluster deployment of helm applications using karmada
2022-06-28 16:57:00 【Huawei cloud developer Alliance】
Abstract : With the help of Karmada Native API The ability to support ,Karmada Can use Flux Make it easy Helm Cross cluster deployment of applications .
This article is shared from Huawei cloud community 《 Use Karmada Realization Helm Cross cluster deployment of applications 【 Cloud native open source 】》, author : Huawei cloud's native open source team .
background
By using Kubernetes Native API And provide advanced scheduling function ,Karmada It has implemented the... In the multi cluster scenario Kubernetes resources ( Include CRD) Distribution and management of . However, the current multi cluster application is often not a single resource form , Use Helm The use scenario of packaging applications is also very common .
With the help of Karmada Native API The ability to support ,Karmada Can use Flux Make it easy Helm Cross cluster deployment of applications .
Deploy Karmada
To deploy Karmada, You can refer to the community installation documentation (https://github.com/karmada-io/karmada/blob/master/docs/installation/installation.md). If you want to experience it quickly Karmada, We propose to adopt hack/local-up-karmada.sh Construct a Karmada Development environment of .
Deploy Flux
stay Karmada In control surface , You need to install Flux Of CRD, But there is no need to install Flux The controller is based on CRD Created CR object , They are considered resource templates , Not specific resource instances . be based on Karmada Of work API, They will be encapsulated as a work Object to the member cluster , Finally, the members in the cluster Flux The controller is tuned .
kubectl apply -k github.com/fluxcd/flux2/manifests/crds?ref=main --kubeconfig ~/.kube/karmada.configIn a member cluster , You can install the complete... Based on the following command Flux Components .
flux install --kubeconfig ~/.kube/members.config --context member1flux install --kubeconfig ~/.kube/members.config --context member2You can refer to the documentation here (https://fluxcd.io/docs/installation/) For more detailed installation Flux The details of the .
Tips : If you want to manage all your clusters based on HelmRelease Application , You need to install... In all your member clusters Flux.
Helm release distribution
Ready for work , Next, we will use a podinfo As an example, it demonstrates how to complete Helm chart distribution .
1. stay Karmada Define a in the control plane Flux Of HelmRepository CR Object and a HelmRelease CR object . They will be treated as resource templates .
apiVersion: source.toolkit.fluxcd.io/v1beta2kind: HelmRepositorymetadata: name: podinfospec: interval: 1m url: https://stefanprodan.github.io/podinfo ---
apiVersion: helm.toolkit.fluxcd.io/v2beta1kind: HelmReleasemetadata: name: podinfospec: interval: 5m chart: spec: chart: podinfo version: 5.0.3 sourceRef: kind: HelmRepository name: podinfo2. Define a Karmada Of PropagationPolicy Object to distribute their resource instances to the member cluster :
apiVersion: policy.karmada.io/v1alpha1kind: PropagationPolicymetadata: name: helm-repospec: resourceSelectors: - apiVersion: source.toolkit.fluxcd.io/v1beta2 kind: HelmRepository name: podinfo placement: clusterAffinity: clusterNames: - member1 - member2---
apiVersion: policy.karmada.io/v1alpha1kind: PropagationPolicymetadata: name: helm-releasespec: resourceSelectors: - apiVersion: helm.toolkit.fluxcd.io/v2beta1 kind: HelmRelease name: podinfo placement: clusterAffinity: clusterNames: - member1 - member2The above configuration will make Flux The resource object of is distributed to the member cluster member1 and member2 in .
3. Submit the above objects to Karmada-apiserver:
kubectl apply -f ../helm/ --kubeconfig ~/.kube/karmada.configYou will get the following output :
helmrelease.helm.toolkit.fluxcd.io/podinfo createdhelmrepository.source.toolkit.fluxcd.io/podinfo createdpropagationpolicy.policy.karmada.io/helm-release createdpropagationpolicy.policy.karmada.io/helm-repo created4. Switch to the member cluster to verify whether the application is successfully distributed
helm --kubeconfig ~/.kube/members.config --kube-context member1 listYou will get the following output :

be based on Karmada Of PropagationPolicy, You have the flexibility to Helm The application is published to the cluster you expect .
Customize for a specific cluster Helm application
The above example shows how the same Helm Application distribution to Karmada Multiple clusters in . Besides , You can still use it Karmada Of OverridePolicy Customize for a specific cluster Helm application . for example , The above applications include a Pod copy , If you just want to change member1 The applications in the cluster contain Pod replications , You can refer to the following OverridePolicy Strategy .
1. Define a Karmada Of OverridePolicy object .
apiVersion: policy.karmada.io/v1alpha1kind: OverridePolicymetadata: name: example-override namespace: defaultspec: resourceSelectors: - apiVersion: helm.toolkit.fluxcd.io/v2beta1 kind: HelmRelease name: podinfo overrideRules: - targetCluster: clusterNames: - member1 overriders: plaintext: - path: "/spec/values" operator: add value: replicaCount: 22. Submit the above objects to Karmada-apiserver:
kubectl apply -f example-override.yaml --kubeconfig ~/.kube/karmada.configYou will get the following output :
overridepolicy.policy.karmada.io/example-override created3. stay Karmada After applying the above strategy in the control plane , You'll find that member1 Members in the cluster Pod The number of instances has been changed to 2, but member2 Those in the cluster remain the same .
kubectl --kubeconfig ~/.kube/members.config --context member1 get poYou will get the following output :
NAME READY STATUS RESTARTS AGEpodinfo-68979685bc-6wz6s 1/1 Running 0 6m28spodinfo-68979685bc-dz9f6 1/1 Running 0 7m42sReference documents :
https://github.com/karmada-io/karmada/blob/master/docs/working-with-flux.md
attach :Karmada Community technology exchange address
add to Karmada Community assistant wechat k8s2222 Enter the community communication group , and Maintainer Zero distance .
Project address :https://github.com/karmada-io/karmada
Slack Address :https://slack.cncf.io/
Click to follow , The first time to learn about Huawei's new cloud technology ~
边栏推荐
- 如何登录到你的 WordPress 管理仪表板
- FS2K人脸素描属性识别
- 浅谈 SAP 软件里的价格折扣设计原理
- 免费、强大、高颜值的笔记软件评测: OneNote、Heptabase、氢图、FlowUs
- Written interview algorithm classic - longest palindrome substring
- [force button] 35 Search insert location
- On the design principle of price discount in SAP software
- PostgreSQL exception handling
- Super detailed steps for MySQL master-slave switching
- BOM in JS
猜你喜欢

【TcaplusDB】祝大家端午安康!

MATLB|电力系统优化运行与市场化

免费、强大、高颜值的笔记软件评测: OneNote、Heptabase、氢图、FlowUs

FS2K人脸素描属性识别

Fs2k face sketch attribute recognition

7-用户输入和while循环

Azure Kinect Microsoft camera unity development summary

浅谈 SAP 软件里的价格折扣设计原理

This simple little function saves 213 hours for our production research team in half a year

这个简单的小功能,半年为我们产研团队省下213个小时
随机推荐
How to query the last data according to multiple indexes to achieve the effect of SQL order by desc limit 1?
Langqing and Langchao, an ecological model from OEM to value symbiosis
PotPlayer播放百度云盘视频
如何将你的 WordPress 网站置于维护模式
WPF 视频硬解码渲染播放(无空域)(支持4K、8K、高帧率视频)
天翼云Web应用防火墙(边缘云版)通过首批可信认证
大促场景下,如何做好网关高可用防护
What you have to know under the digital collection boom
GCC efficient graph revolution for joint node representationlearning and clustering
[tcapulusdb knowledge base] Introduction to tcapulusdb restrictions
MATLB|可视化学习(plot和bar)
The new paradigm of AI landing is "hidden" in the next major upgrade of software infrastructure
The first place on the list - brake by wire "new cycle", the market competitiveness of local suppliers is TOP10
中国SSD行业企业势力全景图
抓取手机端变体组合思路设想
使用Karmada实现Helm应用的跨集群部署
[golang] how to install iris
2019 CSP J2 entry group csp-s2 improvement group round 2 video and question solution
中金证券经理给的开户链接安全吗?找谁可以开户啊?
这个简单的小功能,半年为我们产研团队省下213个小时