Helm とは何ですか?クラウドネイティブ アプリケーションのプライベート展開の効率はどのように向上しますか?

Helm とは何ですか?クラウドネイティブ アプリケーションのプライベート展開の効率はどのように向上しますか?

みなさんこんにちは。私はブラザー・スネイルです。 50 個のマイクロサービスを持つプロジェクトがあり、各マイクロサービスにサービス、デプロイメント、イングレス、pvc などの yaml ファイルがあり、合計で約 200 個のファイルがある場合、このプロジェクトを k8s ベースでプライベートに配信する必要があると想像してください。あなたの場合、どのようにしてアプリケーションを迅速に展開しますか?

まず、これについて考えてみましょう。

  • kubectl を通じてデプロイされた 200 個のファイルが適用され、それらを 1 つずつ読み取って実行するためのシェル スクリプトが for ループ内に記述されていますか?しかし、これらの yaml ファイルが更新された場合、どのように同期するのでしょうか?
  • これらのポッドをアップグレードする必要がある場合はどうなりますか?画像タグを一つずつ変更する必要がありますか?
  • データベース アドレス、ファイル システム アドレス、ログ ディレクトリ、リソース サイズなどの YAML ファイル関連のアドレスを更新するにはどうすればよいですか?
  • アンインストールしたい場合はどうすればいいですか?一つずつ削除しますか?

npmやmavenなどのパッケージ管理ツールのように、これらのyamlファイルをパッケージに入れて、キーパラメータを公開し、デプロイ時にこれらのパラメータを指定してワンクリックデプロイを行い、アンインストール時にワンクリックでアンインストールできるツールがあれば、とても便利ではないでしょうか。 Helm はまさにそのようなツールです。

ヘルムとは

Helm は、Kubernetes 上でアプリケーションをパッケージ化、デプロイ、管理できるツールです。最も複雑な Kubernetes アプリケーションの定義、インストール、アップグレードにも役立ちます。 Helm も CNCF の卒業プロジェクトです。

Helm における次の概念:

  • Helm Charts: ここではChartsと呼ばれる事前設定されたYAMLテンプレートは、KubernetesアプリケーションのYAMLと構成を記述するために使用されます。
  • Helmクライアント: Helmと対話し、これらのチャートのバージョンを管理するためのコマンドラインインターフェース
  • Chart Warehouse: チャートを管理するウェアハウス。Maven の Nexus と同じです。たとえば、社内環境でチャートを構築してアップロードし、顧客のコンピュータルームの Chart Warehouse に接続してチャートをダウンロードし、k8s にデプロイすることができます。

私たちは何をすべきでしょうか?

ここではHelmの具体的な機能については紹介しません。詳細は公式サイトでご確認ください。ここでは、Helm の使い方についてのみ説明します。これにより、Helm を理解し、どのようなシナリオで Helm を使用するかを知ることができます。それでは、例を挙げてゲームプレイを説明します。

例の紹介

フロントエンドとバックエンドに分かれた運用保守展開システムがあり、お客様のお部屋に展開する必要があります。 k8s アーキテクチャは次のとおりです。 8 つのファイルが必要であることがわかります (Istio には 2 つの yaml ファイルが必要です)。次の例では、このチャートを段階的に作成します。

1. 例の作成

helm create dp-manage コマンドを使用してチャートを作成します。実行後、以下に示すように、nginxチャートがデフォルトで生成されます。

2. 主要文書の説明

(1) チャート.yaml

現在のチャートのバージョンを定義し、現在のチャートの目的を説明します。 name パラメータは、後続のアップロードとダウンロードに使用されるチャート名を示します。

(2)値.yaml

変数パラメータはこのファイルで定義され、image.repositoryなどのYAMLテンプレートで参照され、以下に示すように.Values + 変数名を通じて参照されます。

(3) _helpers.tpl

フリーメーカーのマクロに似た共通コードブロック定義。yaml で名前によって参照され、dp-manager.selectorLabels などのすべての変更が含まれます。

3. 変更例

デフォルトの Nginx Chart ではニーズを満たすことができないため、冗長なファイルを削除し、以下に示すように、運用および保守デプロイメント システムの yaml ファイルを追加します。

8 つのテンプレート ファイルがあり、そのうち backend-dp.yaml が次のように定義されていることがわかります。

values.yml パラメータと _helpers.tpl の共通コード ブロックを参照することで、最終的に k8s の deploy.yml ファイルが生成されます。他のファイルは一つずつ紹介されません

ビルドとデプロイ

前述のように、チャートを作成した後、チャート ウェアハウスにアップロードし、クライアント ルームでこのウェアハウスに接続してダウンロードする必要があります。したがって、チャート ウェアハウスが必要になります。ここでは Harbor を使用します。 Habor はコンテナ イメージ ウェアハウスとしても、チャート ウェアハウスとしても使用できるため、一石二鳥です。ご利用をお勧めします。

1. 関連倉庫

Helm クライアントをインストールした後、次のコマンドをローカルで実行して、リポジトリに関連付けます。

 helm repo add myrepo https://host/仓库地址\ --username sre \ --password xxxx

追加後、 helm repo list を実行して、追加された myrepo ウェアハウスを見つけます。

2. ビルドとパッケージ化

ウェアハウスが関連付けられた後、 helm package dp-manager コマンドを実行してパッケージ化すると、 dp-manager-1.0.0.tgz パッケージが生成されます。

helm cm-push dp-manager-1.0.0.tgz myrepo を実行して Harbor 倉庫にプッシュします。 Myrepo は私たちの倉庫の名前です。プッシュ後、Harbor にログインして以下のように表示します。

3. プルデプロイメント

チャートがアップロードされたら、顧客ルーム内に Helm クライアントと Kubectl クライアントをインストールします。具体的なインストール方法はオンラインで確認できます。 helm repo add を使用して、Habor 倉庫アドレスを関連付けます。関連付け後、検索コマンドを実行して、運用保守展開システムのチャートを検索します。

 helm search repo myrepo/dp-manager

チャートが見つかったら、それを展開できます。展開方法は2つあります。 1 つは、チャートをローカル コンピューターにダウンロードし、デプロイ前に values.yaml ファイルを変更することです。もう 1 つは、ダウンロードせずに展開するためのパラメータを指定することです。 2 番目の方法を使用します。

 helm install dp-manager myrepo/dp-manager \ --set istioGateway.hosts={dpmanager.test.com} \ --set pv.log.pvEnabled=false \ --set pv.log.type=storageClass \ --set pv.log.pvc.storageName=gfs-storage \ --set pv.log.pvc.storage=20Gi \ --set apollo.cluster=default

このコマンドでは、ドメイン名やストレージ サイズなどのパラメータを指定します。これらのパラメータは values.yaml ファイルを通じて公開されます。また、このコマンドは、運用保守展開システムをデフォルトのコマンド スペースに展開します。名前空間は -n パラメータで指定できます。

コマンドが実行されると、以下に示すように helm list を通じて表示できます。

 helm list

4. 更新

apollo.cluster の値が default から prod に変更されたと仮定して、アップグレードを実行して更新します。

 helm upgrade dp-manager myrepo/dp-manager \ --set istioGateway.hosts={dpmanager.test.com} \ --set pv.log.pvEnabled=false \ --set pv.log.type=storageClass \ --set pv.log.pvc.storageName=gfs-storage \ --set pv.log.pvc.storage=20Gi \ --set apollo.cluster=prod

5. アンインストール

アンインストールは非常に簡単です。次のコマンドを実行するだけです。

 helm uninsall dp-manager

<<:  SSHトンネルを使用してクラウドホストサービスのアクセス制限を突破する

>>:  K8S 実践: 効率的に作業するための非常に実用的な Kubectl エイリアス ツールの推奨

推薦する

edgenat: 元旦 VPS 割引、月払いで 20% オフ、年払いで 30% オフ (10 か月のみ)、米国 cn2、香港 cn2、韓国 cn2

edgenat (ASN139803) は新年のプロモーションを発表しました。韓国の CN2、米国の...

Baidu の外部リンク ツールの統計における外部リンクが不完全なのはなぜですか?

百度は11月25日、百度ウェブマスターツールの外部リンク検索ツールのベータ版をリリースした。武漢SE...

噂を流布したインターネットサイトが多数捜査され、法律に基づいて処罰された。

新華網、北京、3月30日(新華社) - 中国サイバースペース管理局の報道官は本日、噂を流布する多数の...

7年間の努力を経て、QingCloudは汎用クラウドコンピューティングに取り組んでいます

[51CTO.com からのオリジナル記事] 情報と生活のデジタル化に続き、産業のデジタル化の時代が...

ginernet: 50% オフ、10Gbps スペイン VPS、著作権なし、年間 40 ユーロ、2G メモリ/1 コア/25g NVMe/2T データ

ginernet (~) は現在、デフォルトの 10Gbps 帯域幅、KVM 仮想化、NVMe SS...

dominionhosting-512MメモリXEN/2IP/月額4.95ドル

dominionhosting は 10 年以上の歴史を持つホスティング会社です。前身は newwe...

Godaddy VPS サーバー価格の値下げ

VPS、サーバー 15% オフ 割引コード: fbServer15 は 1/5/ まで有効です。すべ...

evlgaming-KVM VPS 5.4% オフ/1g メモリ/月額 6.5 ドル

2010 年に設立された evlgaming はカンザス州に登録された会社であり、サブブランドである...

ビジネス準備: ハイブリッドクラウドの波及効果

柔軟性の向上から効率性の向上、コスト削減の迅速な実現まで、ハイブリッド クラウドの利点を説明する記事...

SEOフォーラムが直面するジレンマ

SEO フォーラムは確かにウェブサイトのランキングを管理するのに良い手段です。現状から判断すると、多...

onetechcloud: 完全に最適化されたライン VPS、64 元/四半期、米国 CN2/ネイティブ/高防御 + 香港 CN2/CMI ライン

onetechcloud は今月、新たな 20% オフのプロモーションを開始しました。米国 VPS ...

ウェブサイトをデザインする際に注意すべきことは何ですか?視線追跡を使用してウェブデザインを改善する

あなたは機械を見ており、機械もあなたを見ています。最近、視線追跡技術の応用事例が数多く登場しています...

time4vps-3.99 ユーロ/1g メモリ/1T ハードディスク/4T トラフィック/ヨーロッパ データ センター

time4vpsはかなり昔に設立された会社だそうですが、もちろん聞いただけです。本日は、400M ポ...

3月の第1週、中国の.COMドメイン名の総数は6,541,667に達し、2位となった。

IDC Review Network (idcps.com) は 3 月 17 日に次のように報告し...