Mengelola diagram Helm

Halaman ini menjelaskan cara mengelola diagram Helm 3 yang disimpan sebagai image container OCI, termasuk mengirim (mengupload), mengambil (mendownload), mencantumkan, memberi tag, dan menghapus diagram.

Sebelum memulai

  1. Jika repositori target tidak ada, buat repositori baru. Pilih Docker sebagai format repositori.
  2. Pastikan Anda memiliki izin yang diperlukan untuk repositori.
  3. (Opsional) Konfigurasi setelan default untuk perintah Google Cloud CLI.
  4. Instal Helm 3.8.0 atau yang lebih baru. Pada versi Helm sebelumnya, dukungan untuk diagram dalam format OCI adalah fitur eksperimental.

    Jalankan helm version untuk memverifikasi versi Anda.

  5. Konfigurasi Helm untuk melakukan autentikasi dengan Artifact Registry.

Membuat atau mendapatkan diagram

Dokumentasi ini berfokus pada pengelolaan image diagram Anda dan mengasumsikan bahwa Anda memiliki diagram yang ada atau memahami cara membuat diagram. Untuk mempelajari lebih lanjut cara membuat diagram atau mendapatkan diagram yang tersedia secara publik di Artifact Hub, lihat informasi berikut dalam dokumentasi Helm.

Mengemas diagram

Sebelum dapat mengirim diagram ke Artifact Registry, Anda harus mengemasnya sebagai arsip diagram.

  1. Ubah ke direktori yang berisi diagram Anda.

  2. Kemasi diagram.

    helm package CHART-PATH
    

    Ganti CHART-PATH dengan jalur ke direktori yang berisi file Chart.yaml Anda.

Helm menggunakan nama dan versi diagram untuk nama file arsip. Misalnya, jika Anda memiliki diagram dengan nama my-chart dan nomor versi 0.1.0, nama paketnya adalah my-chart-0.1.0.tgz.

Sekarang Anda dapat mengirim diagram ke Artifact Registry.

Mengirim diagram

Setelah mengemas diagram, Anda dapat mengirimnya ke Artifact Registry.

Untuk mengirim diagram, jalankan perintah berikut:

helm push my-chart-0.1.0.tgz oci://LOCATION-docker.pkg.dev/PROJECT/REPOSITORY

Ganti nilai berikut:

Helm menggunakan informasi dari Chart.yaml untuk nama dan tag image container OCI. Pertimbangkan contoh perintah berikut:

helm push my-chart-0.1.0.tgz oci://us-west1-docker.pkg.dev/my-project/my-repo

Helm mengupload arsip diagram sebagai image my-chart dengan tag 0.1.0.

Untuk memverifikasi bahwa operasi pengiriman berhasil, cantumkan image dalam repositori.

gcloud artifacts docker images list LOCATION-docker.pkg.dev/PROJECT/REPOSITORY

Mengambil diagram

Untuk mengambil diagram:

  1. Jalankan perintah berikut untuk mengambil arsip diagram:

    helm pull oci://LOCATION-docker.pkg.dev/PROJECT/REPOSITORY/IMAGE \
        --version VERSION
    

    Jika ingin mengambil arsip diagram dan mengekstrak kontennya, tambahkan flag --untar.

    helm pull oci://LOCATION-docker.pkg.dev/PROJECT/REPOSITORY/IMAGE \
        --version VERSION \
        --untar
    

    Ganti nilai berikut:

  • LOCATION adalah lokasi regional atau multi-regional location repositori.
  • PROJECT adalah Google Cloud project ID Anda. Jika project ID Anda berisi titik dua (:), lihat Project dengan cakupan domain.
  • REPOSITORY adalah nama repositori tempat image disimpan.
  • IMAGE adalah nama image dalam repositori.
  • VERSION adalah versi semantik diagram. Flag ini wajib diisi. Helm tidak mendukung pengambilan diagram menggunakan tag.

Menginstal diagram

Instal diagram yang disimpan di Artifact Registry dengan perintah helm install install.

helm install RELEASE \
    oci://LOCATION-docker.pkg.dev/PROJECT/REPOSITORY/IMAGE \
    --version VERSION

Contoh berikut menginstal rilis bernama release1 menggunakan versi 0.1.0 diagram us-west1-docker.pkg.dev/nyap-test/helm-repo/my-chart:

helm install release1 oci://us-west1-docker.pkg.dev/nyap-test/helm-repo/my-chart --version 0.1.0

Mencantumkan diagram

Anda dapat mencantumkan diagram menggunakan the Google Cloud console atau command line. Jika Anda menyimpan image dan diagram container di repositori Docker yang sama, kedua jenis artefak akan muncul dalam daftar.

Konsol

Untuk melihat image dalam repositori:

  1. Buka halaman Repositori di Google Cloud konsol.

    Buka halaman Repositori

  2. Klik repositori yang berisi image container.

  3. Klik image untuk melihat versinya.

gcloud

Untuk mencantumkan semua image dalam project, repositori, dan lokasi default saat nilai default dikonfigurasi:

gcloud artifacts docker images list

Untuk mencantumkan image dalam repositori di lokasi tertentu, jalankan perintah:

gcloud artifacts docker images list LOCATION-docker.pkg.dev/PROJECT/REPOSITORY

Untuk mencantumkan semua ringkasan dan tag untuk image tertentu, jalankan perintah:

gcloud artifacts docker images list LOCATION-docker.pkg.dev/PROJECT/REPOSITORY/IMAGE \
--include-tags

Ganti nilai berikut:

  • LOCATION adalah lokasi regional atau multi-regional location repositori.
  • PROJECT adalah Google Cloud project ID Anda. Jika project ID Anda berisi titik dua (:), lihat Project dengan cakupan domain.
  • REPOSITORY adalah nama repositori tempat image disimpan.
  • IMAGE adalah nama image dalam repositori.
  • --include-tags menampilkan semua versi image, termasuk ringkasan dan tag. Jika flag ini dihilangkan, daftar yang ditampilkan hanya akan menyertakan image container tingkat atas.

Misalnya, pertimbangkan image dengan karakteristik berikut:

  • Lokasi repositori: us-west1
  • Nama repositori: my-repo
  • Project ID: my-project
  • Nama image: my-image

Nama repositori lengkapnya adalah:

us-west1-docker.pkg.dev/my-project/my-repo

Nama image lengkapnya adalah:

us-west1-docker.pkg.dev/my-project/my-repo/my-image

Untuk mengetahui detail tentang format nama image, lihat Nama repositori dan image.

Mencantumkan file

Anda dapat mencantumkan file dalam repositori, file dalam semua versi image container tertentu, atau file dalam versi image tertentu.

Untuk semua perintah berikut, Anda dapat menetapkan jumlah maksimum file yang akan ditampilkan dengan menambahkan flag --limit ke perintah.

Untuk mencantumkan semua file dalam project, repositori, dan lokasi saat nilai default dikonfigurasi:

gcloud artifacts files list

Untuk mencantumkan file dalam project, repositori, dan lokasi tertentu, jalankan perintah:

gcloud artifacts files list \
    --project=PROJECT \
    --repository=REPOSITORY \
    --location=LOCATION

Untuk mencantumkan file untuk semua versi image container tertentu:

gcloud artifacts files list \
    --project=PROJECT \
    --repository=REPOSITORY \
    --location=LOCATION \
    --package=PACKAGE

Untuk mencantumkan file untuk versi image container tertentu:

gcloud artifacts files list \
    --project=PROJECT \
    --repository=REPOSITORY \
    --location=LOCATION \
    --package=PACKAGE \
    --version=VERSION
Untuk mencantumkan file untuk tag tertentu:

gcloud artifacts files list \
    --project=PROJECT \
    --repository=REPOSITORY \
    --location=LOCATION \
    --package=PACKAGE \
    --tag=TAG

Ganti nilai berikut:

  • LOCATION: lokasi regional atau multi-regional repositori.
  • PROJECT: ID proyek Anda Google Cloud . Jika project ID Anda berisi titik dua (:), lihat Project dengan cakupan domain.
  • REPOSITORY: nama repositori tempat image disimpan.
  • PACKAGE: nama image.
  • VERSION: ringkasan image, string yang dimulai dengan sha256:.
  • TAG: tag yang terkait dengan image container.

Menghapus image

Di repositori Artifact Registry, Anda dapat menghapus seluruh image container atau menghapus versi image tertentu yang terkait dengan tag atau ringkasan. Setelah menghapus image, Anda tidak dapat mengurungkan tindakan tersebut.

Untuk menghapus image yang disimpan di Artifact Registry:

Konsol

  1. Buka halaman Repositori di Google Cloud konsol.

    Buka halaman Repositori

  2. Klik nama image untuk melihat versi image tersebut.

  3. Pilih versi yang ingin Anda hapus.

  4. Klik DELETE.

  5. Pada dialog konfirmasi, klik DELETE.

gcloud

Untuk menghapus image dan semua tag-nya, jalankan perintah:

gcloud artifacts docker images delete LOCATION-docker.pkg.dev/PROJECT/REPOSITORY/IMAGE --delete-tags

Untuk menghapus versi image tertentu, gunakan salah satu perintah berikut.

gcloud artifacts docker images delete LOCATION-docker.pkg.dev/PROJECT/REPOSITORY/IMAGE:TAG [--delete-tags]

atau

gcloud artifacts docker images delete LOCATION-docker.pkg.dev/PROJECT/REPOSITORY/IMAGE@IMAGE-DIGEST [--delete-tags]

Di mana

  • LOCATION adalah lokasi regional atau multi-regional location repositori.
  • PROJECT adalah Google Cloud project ID Anda. Jika project ID Anda berisi titik dua (:), lihat Project dengan cakupan domain.
  • REPOSITORY adalah nama repositori tempat image disimpan.
  • IMAGE adalah nama image dalam repositori.
  • TAG adalah tag untuk versi yang ingin Anda hapus. Jika beberapa tag dikaitkan dengan versi image yang sama, Anda harus menyertakan --delete-tags untuk menghapus versi image tanpa menghapus tag terlebih dahulu.
  • IMAGE-DIGEST adalah nilai hash sha256 untuk versi yang ingin Anda hapus. Jika tag dikaitkan dengan ringkasan image, Anda harus menyertakan --delete-tags untuk menghapus versi image tanpa menghapus tag terlebih dahulu.
  • --delete-tags menghapus semua tag yang diterapkan ke versi image. Flag ini memungkinkan Anda menghapus versi image secara paksa jika:
    • Anda menentukan tag, tetapi ada tag lain yang terkait dengan versi image.
    • Anda menentukan ringkasan image yang memiliki setidaknya satu tag.

Langkah berikutnya