すべてのプロダクト
Search
ドキュメントセンター

Container Registry:V3.7より前のHelmを使用してチャートをプッシュおよびプルする

最終更新日:Jun 26, 2024

Helm 3チャートをプッシュおよびプルする前に、Open Container Initiative (OCI) イメージリポジトリを作成してチャートを保存および管理する必要があります。 OCIイメージリポジトリは、ローカルファイルシステム、ネットワークサーバ、またはクラウドストレージデバイスとすることができる。 V3.7より前のHelmバージョンを使用してチャートをプッシュおよびプルする操作は、Helm cm-pushプラグインを使用してチャートをプッシュおよびプルする操作とは異なります。 このトピックでは、V3.7より前のバージョンのHelmを使用してグラフをプッシュおよびプルする方法について説明します。

手順1: Container Registry Enterprise Editionインスタンスの設定

  1. 名前空間を作成します。

    1. Container Registryコンソールにログインします。

    2. 左側のナビゲーションウィンドウで、[インスタンス] をクリックします。

    3. [インスタンス] ページで、管理するEnterprise Editionインスタンスをクリックします。

    4. Container Registry Enterprise Editionインスタンスの管理ページの左側のナビゲーションウィンドウで、リポジトリ > 名前空間.

    5. 名前空間ページをクリックします。名前空間の作成.

    6. 名前空間の作成では、ダイアログボックスで、名前空間,リポジトリの自動作成、およびデフォルトのリポジトリタイプをクリックし、確認.をクリックします。

  2. イメージリポジトリを作成します。

    1. Enterprise Editionインスタンスの管理ページの左側のナビゲーションウィンドウで、リポジトリ > リポジトリ.

    2. リポジトリページをクリックします。リポジトリの作成.をクリックします。

    3. [リポジトリ情報] ステップで、[名前空間][リポジトリ名][リポジトリの種類][タグ][高速化イメージ][概要] 、および [説明] パラメーターを設定します。 次に、[次へ] をクリックします。

    4. コードソースでは、ステップを設定し、コードソース,ビルド設定、およびビルドルールをクリックし、リポジトリの作成. 次の表に、主要なパラメーターを示します。

      パラメーター

      説明

      コードソース

      コードソース。

      ビルド設定

      • コードが変更されたときにイメージを自動的にビルドする: コードがブランチからコミットされると、ビルドルールが自動的にトリガーされます。

      • 中国本土外に配置されたサーバーを使用したビルド: イメージは中国本土外のサーバー上にビルドされ、指定されたリージョンのリポジトリにプッシュされます。 プロジェクトで使用されるDockerfileを中国本土以外のサイトからダウンロードする必要があるが、国境を越えたネットワーク接続が不安定な場合は、中国本土以外に配置されたサーバーでビルドを有効にできます。

      • キャッシュなしのビルド: イメージがビルドされるたびに、システムはソースコードリポジトリからベースイメージをプルします。 これは、構築期間を増加させ得る。 [キャッシュなしのビルド] を無効にすると、イメージの構築を高速化できます。

      [リポジトリ] ページで、作成したイメージリポジトリをクリックします。 リポジトリ管理ページの左側のナビゲーションウィンドウに [ビルド] が表示されている場合、イメージリポジトリはソースコードリポジトリにバインドされます。

  3. アクセス資格情報を設定します。

    パスワードまたはトークンをイメージリポジトリのアクセス資格情報として設定できます。 この例では、パスワードがアクセス資格情報として設定されています。

    1. Enterprise Editionインスタンスの管理ページの左側のナビゲーションウィンドウで、対応 > アクセス資格.

    2. アクセス資格ページをクリックします。パスワードの設定.

    3. [パスワードの設定] ダイアログボックスで、[パスワード] および [パスワードの確認] パラメーターを設定します。 [確認] をクリックします。

  4. アクセス制御リスト (ACL) を設定します。

    インターネットアクセスを有効にするか、仮想プライベートクラウド (VPC) を追加してVPCアクセスを有効にします。 これにより、チャートをイメージリポジトリにプッシュできます。 この例では、インターネットアクセスが有効になっています。 VPCアクセスを有効にする方法については、「VPC ACLの設定」をご参照ください。

    1. Enterprise Editionインスタンスの管理ページの左側のナビゲーションウィンドウで、リポジトリ > アクセス制御.

    2. アクセス制御ページをクリックし、インターネットタブをクリックします。

    3. インターネットタブ、オンにするインターネット経由のアクセスを有効にするをクリックし、インターネットホワイトリストの追加.

    4. インターネットホワイトリストの追加ダイアログボックスで、イメージリポジトリへのアクセスを許可するCIDRブロックと説明を指定し、確認.

  5. (オプション) Pull from Anonymous Usersをオンにします。

    [匿名ユーザーからプル] をオンにすると、パブリックイメージリポジトリから匿名ユーザーとしてグラフをプルできます。

    1. Container Registryコンソールにログインします。

    2. 上部のナビゲーションバーで、リージョンを選択します。

    3. 左側のナビゲーションウィンドウで、[インスタンス] をクリックします。

    4. [インスタンス] ページで、管理するEnterprise Editionインスタンスをクリックします。

    5. インスタンス設定の右側にあるセクション概要ページ、オンにする匿名ユーザーからプル.

    6. ヒントダイアログボックスで、確認.

ステップ2: チャートのプッシュとプル

  1. 公式サイトから必要なバージョンのHelmをダウンロードしてください。

    説明

    クライアントのバージョンがV3であることを確認してください。 helm3 version -cコマンドを実行して、バージョンを確認できます。 この例では、クライアントのバージョンはV3.0.2です。

  2. 次のコマンドを実行して、Helm 3の実験機能を有効にします。

    export HELM_EXPERIMENTAL_OCI=1
  3. 次のコマンドを実行して、Enterprise Editionインスタンスにログインします。

    Alibaba Cloudアカウントを使用して、コマンドのユーザー名を置き換えます。

    説明

    パブリックチャートリポジトリからチャートをプッシュおよびプルする場合、Container RegistryコンソールのContainer Registry Enterprise Editionインスタンスの [概要] ページで [匿名ユーザーからプル] をオンにできます。 これにより、匿名ユーザーとしてイメージリポジトリからグラフを取得できます。

    helm3 registry login --username=<Registry logon name> <Name of the Enterprise Edition instance>.<Region in which the Enterprise Edition instance resides>.cr.aliyuncs.com

    例:

    helm3 registry login --username=123@188077086902**** m**-registry.cn-hangzhou.cr.aliyuncs.com

    コマンド出力で、ログインパスワードを入力します。 ログインパスワードは、ステップ1で設定したパスワードです。

  4. 次のコマンドを実行してHelloWorldチャートを作成します。

    helm3 create helloworld
  5. チャートを押して引っ張ります。

    • チャートをイメージリポジトリにプッシュします。

      1. 次のコマンドを実行して、グラフディレクトリをEnterprise Editionインスタンスのイメージリポジトリのタグとして保存します。

        helm3 chart save helloworld <Name of the Enterprise Edition instance>.<Region in which the Enterprise Edition instance resides>.cr.aliyuncs.com/<Namespace name>/<Name of the image repository>:<Image tag>

        例:

        helm3 chart save helloworld m**-registry.cn-hangzhou.cr.aliyuncs.com/m**/test:latest
      2. 次のコマンドを実行して、タグをEnterprise Editionインスタンスのイメージリポジトリにプッシュします。

        helm3 chart push <Name of the Enterprise Edition instance>.<Region in which the Enterprise Edition instance resides>.cr.aliyuncs.com/<Namespace name>/<Name of the image repository>:<Image tag>

        例:

        helm3 chart push m**-registry.cn-hangzhou.cr.aliyuncs.com/m**/test:latest
    • イメージリポジトリからチャートを引き出します。

      1. 次のコマンドを実行して、Enterprise Editionインスタンスのイメージリポジトリから指定されたタグを取得します。

        helm3 chart save helloworld <Name of the Enterprise Edition instance>.<Region in which the Enterprise Edition instance resides>.cr.aliyuncs.com/<Namespace name>/<Name of the image repository>:<Image tag>

        例:

        helm3 chart save helloworld m**-registry.cn-hangzhou.cr.aliyuncs.com/m**/test:latest
      2. 次のコマンドを実行して、グラフタグをローカルディレクトリにエクスポートします。 次に、ローカルのグラフディレクトリを表示できます。

        helm3 chart export <Name of the Enterprise Edition instance>.<Region in which the Enterprise Edition instance resides>.cr.aliyuncs.com/<Namespace name>/<Name of the image repository>:<Image tag> -d .

        例:

        helm3 chart export m**-registry.cn-hangzhou.cr.aliyuncs.com/m**/test:latest -d .
      3. 次のコマンドを実行して、HelloWorldチャートをインストールします。

         helm install helloworld ./helloworld