Halaman ini menjelaskan cara mengonfigurasi volume dalam memori khusus yang dapat Anda gunakan untuk membaca dan menulis file menggunakan pemasangan volume Cloud Run. Perhatikan bahwa fitur ini berbeda dengan sistem file dalam memori bawaan yang disediakan oleh Cloud Run.
Saat Anda memasang volume dalam memori di Cloud Run, volume dalam memori akan muncul sebagai file dalam sistem file container. Setelah memasang volume dalam memori, Anda dapat mengaksesnya seolah-olah itu adalah direktori di sistem file lokal, menggunakan operasi dan library sistem file bahasa pemrograman Anda.
Anda dapat menggunakan volume dalam memori untuk melakukan hal berikut:
- Batasi ukuran volume dalam memori. Saat Anda membatasi ukuran volume, penulisan ke volume yang penuh akan gagal, yang lebih baik daripada Cloud Run menghentikan instance karena volume menggunakan terlalu banyak memori.
- Membagikan volume dalam memori di antara berbagai penampung dalam satu instance Cloud Run. Saat Cloud Run melakukan penskalaan ke beberapa instance kumpulan pekerja, setiap kumpulan pekerja akan memiliki volume dalam memori sendiri yang dibagikan oleh semua penampung di kumpulan pekerja tersebut. Volume ini tersedia untuk semua container saat Cloud Run melakukan penskalaan untuk menangani traffic.
Perilaku
Saat membuat volume dalam memori, sebaiknya tentukan batas ukuran. Jika volume mencapai batas ukurannya, penulisan lebih lanjut akan gagal dengan error memori tidak cukup. Instance Anda dapat menangani error ini dan terus berjalan.
Perhatikan bahwa batas ukuran hanyalah batas: batas ini tidak mengalokasikan ruang tambahan untuk volume dalam memori Anda. Sebaliknya, volume dalam memori Anda menggunakan memori yang Anda konfigurasi untuk container Anda. Jika Anda men-deploy beberapa container, memori yang digunakan oleh setiap penulisan ke volume dihitung sebagai penggunaan memori untuk container yang menulis data.
Jika Anda tidak menentukan batas ukuran, batas tersebut akan otomatis ditetapkan menjadi setengah dari total ukuran semua container dalam tugas atau layanan Anda. Misalnya,
ukuran volume emptyDir
= [Memori (Container A) + Memori (Container B) + Memori (Container N)]/2.
Perilaku default ini dapat menyebabkan batas ukuran volume dalam memori lebih tinggi daripada memori yang dialokasikan untuk beberapa container Anda. Hal ini dapat menyebabkan error yang tidak terduga jika satu penampung melebihi memori yang dialokasikan saat mencoba menulis lebih banyak data ke volume, meskipun batas ukuran volume belum tercapai.
Meskipun menetapkan batas ukuran bersifat opsional, sebaiknya tetapkan batas ukuran untuk melindungi penampung Anda agar tidak kehabisan memori dan mengalami error.
Jalur yang tidak diizinkan
Cloud Run tidak mengizinkan Anda memasang volume di /dev
,
/proc
, dan /sys
, atau di subdirektorinya.
Peran yang diperlukan
Untuk mengetahui daftar peran dan izin IAM yang terkait dengan Cloud Run, lihat Peran IAM Cloud Run dan Izin IAM Cloud Run. Jika kumpulan pekerja Cloud Run Anda berinteraksi dengan Google Cloud API, seperti Library Klien Cloud, lihat panduan konfigurasi identitas layanan. Untuk mengetahui informasi selengkapnya tentang cara memberikan peran, lihat izin deployment dan mengelola akses.
Mengonfigurasi volume dalam memori
Setiap perubahan konfigurasi akan menghasilkan revisi baru. Revisi selanjutnya juga akan otomatis mendapatkan setelan konfigurasi ini, kecuali jika Anda melakukan pembaruan eksplisit untuk mengubahnya.
Setelah Anda mengonfigurasi volume dalam memori untuk layanan Cloud Run, volume kosong akan dibuat untuk setiap instance Cloud Run yang dimulai, dan volume tersebut tersedia selama instance tersebut berjalan. Saat instance berhenti berjalan, data dalam volume akan dihapus secara permanen.
Konfigurasi pemasangan volume dalam memori menggunakan konsol Google Cloud , Google Cloud CLI, atau Terraform.
Konsol
Di konsol Google Cloud , buka Cloud Run:
Pilih Worker pools dari menu, lalu klik Deploy container untuk mengonfigurasi worker pool baru. Jika Anda mengonfigurasi pool worker yang sudah ada, klik pool worker, lalu klik Edit dan deploy revisi baru.
Jika Anda mengonfigurasi kumpulan pekerja baru, isi halaman kumpulan pekerja awal, lalu klik Container, Volume, Jaringan, Keamanan untuk meluaskan halaman konfigurasi kumpulan pekerja.
Klik tab Volumes.
- Di bagian Volumes, klik Add volume.
- Di drop-down Volume type, pilih In-memory.
- Di kolom Nama volume, masukkan nama yang ingin Anda gunakan untuk volume.
- Klik Selesai.
- Klik tab Container.
- Klik tab Volume Mounts.
- Klik Mount volume.
- Pilih volume dalam memori dari menu.
- Tentukan jalur tempat Anda ingin memasang volume.
- Klik Mount Volume.
- Di bagian Volumes, klik Add volume.
Klik Buat atau Deploy.
gcloud
Untuk menambahkan volume dan memasangnya:
gcloud beta run worker-pools update WORKER_POOL \ --add-volume=name=VOLUME_NAME,type=in-memory,size-limit=SIZE_LIMIT \ --add-volume-mount volume=VOLUME_NAME,mount-path=MOUNT_PATH
Ganti kode berikut:
- WORKER_POOL: nama kumpulan pekerja Anda.
- VOLUME_NAME: nama apa pun yang Anda inginkan untuk volume Anda. Nilai VOLUME_NAME digunakan untuk memetakan volume ke pemasangan volume.
- MOUNT_PATH: jalur relatif dalam sistem file
penampung tempat Anda ingin memasang volume ini, misalnya,
/mnt/my-volume
. - SIZE_LIMIT: batas memori yang ingin Anda tetapkan ke volume, dalam
MiB atau GiB (ditetapkan sebagai Mi atau Gi)—misalnya,
500Mi
. Batas ini harus kurang dari total memori yang ditentukan untuk container Anda.
Jika Anda menggunakan beberapa container, tentukan volume terlebih dahulu, lalu tentukan pemasangan volume untuk setiap container:
gcloud beta run worker-pools update WORKER_POOL \ --add-volume=name=VOLUME_NAME,type=in-memory,size-limit=SIZE_LIMIT \ --container=CONTAINER_1 \ --add-volume-mount=volume=VOLUME_NAME,mount-path=MOUNT_PATH \ --container=CONTAINER_2 \ --add-volume-mount volume=VOLUME_NAME,mount-path=MOUNT_PATH2
Terraform
Untuk mempelajari cara menerapkan atau menghapus konfigurasi Terraform, lihat Perintah dasar Terraform.
Untuk menentukan satu container, volume, dan pemasangan volume:
resource "google_cloud_run_v2_worker_pool" "default" {
name = "WORKER_POOL"
location = "REGION"
launch_stage = "BETA"
template {
containers {
image = "IMAGE_URL"
volume_mounts {
name = "VOLUME_NAME"
mount_path = "MOUNT_PATH"
}
}
volumes {
name = "VOLUME_NAME"
empty_dir {
medium = "MEMORY"
size_limit = "SIZE_LIMIT"
}
}
}
}
Ganti kode berikut:
- SERVICE_NAME: nama layanan Cloud Run Anda.
- REGION: Google Cloud region—misalnya,
europe-west1
. - IMAGE_URL: referensi ke image container yang
berisi worker pool, seperti
us-docker.pkg.dev/cloudrun/container/worker-pool:latest
. - VOLUME_NAME: nama apa pun yang Anda inginkan untuk volume Anda. Nilai VOLUME_NAME digunakan untuk memetakan volume ke pemasangan volume.
- MOUNT_PATH: jalur relatif dalam sistem file
penampung tempat Anda ingin memasang volume ini—misalnya,
/mnt/my-volume
. - SIZE_LIMIT: batas memori yang ingin Anda tetapkan ke
volume, dalam MiB atau GiB (ditetapkan sebagai Mi atau Gi)—misalnya,
500Mi
. Batas ini harus kurang dari total memori yang ditentukan untuk container Anda.
Untuk menentukan beberapa container, volume, dan pemasangan volume:
resource "google_cloud_run_v2_worker_pool" "default" {
name = "WORKER_POOL"
location = "REGION"
launch_stage = "BETA"
template {
containers {
image = "IMAGE_URL"
volume_mounts {
name = "VOLUME_NAME"
mount_path = "MOUNT_PATH"
}
}
containers {
image = "IMAGE_URL_2"
volume_mounts {
name = "VOLUME_NAME_2"
mount_path = "MOUNT_PATH_2"
}
}
volumes {
name = "VOLUME_NAME"
empty_dir {
medium = "MEMORY"
size_limit = "SIZE_LIMIT"
}
}
volumes {
name = "VOLUME_NAME_2"
empty_dir {
medium = "MEMORY"
size_limit = "SIZE_LIMIT_2"
}
}
}
}
Ganti kode berikut:
- SERVICE_NAME: nama layanan Cloud Run Anda.
- REGION: Google Cloud region—misalnya,
europe-west1
. - IMAGE_URL, IMAGE_URL_2: referensi ke image
container yang berisi kumpulan pekerja, seperti
us-docker.pkg.dev/cloudrun/container/worker-pool:latest
. - VOLUME_NAME, VOLUME_NAME_2: nama apa pun yang Anda inginkan untuk volume Anda. Nilai ini digunakan untuk memetakan volume ke pemasangan volume.
- MOUNT_PATH, MOUNT_PATH_2: jalur relatif dalam
sistem file penampung tempat Anda ingin memasang volume ini—misalnya,
/mnt/my-volume
. - SIZE_LIMIT, SIZE_LIMIT_2: batas memori yang ingin Anda
tetapkan ke volume, dalam MiB atau GiB (ditetapkan sebagai Mi atau Gi)—misalnya,
500Mi
. Batas ini harus kurang dari total memori yang ditentukan untuk container Anda.
Melihat konfigurasi variabel lingkungan untuk kumpulan pekerja
Di konsol Google Cloud , buka Cloud Run:
Klik Worker pools untuk menampilkan daftar worker pool yang di-deploy.
Klik kumpulan pekerja yang ingin Anda periksa untuk menampilkan panel detailnya.
Klik tab Containers untuk menampilkan konfigurasi container kumpulan pekerja.
Membaca dan menulis ke volume
Jika Anda menggunakan fitur pemasangan volume Cloud Run, Anda mengakses volume yang dipasang menggunakan library yang sama dalam bahasa pemrograman yang Anda gunakan untuk membaca dan menulis file di sistem file lokal Anda.
Cara ini sangat berguna jika Anda menggunakan container yang sudah ada yang mengharapkan data disimpan di sistem file lokal dan menggunakan operasi sistem file reguler untuk mengaksesnya.
Cuplikan berikut mengasumsikan pemasangan volume dengan mountPath
yang ditetapkan ke /mnt/my-volume
.
Nodejs
Gunakan modul Sistem File untuk membuat file baru atau menambahkan ke file yang ada
di volume, /mnt/my-volume
:
var fs = require('fs'); fs.appendFileSync('/mnt/my-volume/sample-logfile.txt', 'Hello logs!', { flag: 'a+' });
Python
Menulis ke file yang disimpan di volume, /mnt/my-volume
:
f = open("/mnt/my-volume/sample-logfile.txt", "a")
Go
Gunakan paket os
untuk membuat file baru yang disimpan di volume, /mnt/my-volume
:
f, err := os.Create("/mnt/my-volume/sample-logfile.txt")
Java
Gunakan class Java.io.File
untuk membuat file log di volume, /mnt/my-volume
:
import java.io.File; File f = new File("/mnt/my-volume/sample-logfile.txt");
Menghapus volume dan pemasangan volume
Anda dapat menghapus semua volume dan pemasangan atau menghapus volume dan pemasangan volume satu per satu.
Menghapus semua volume dan pemasangan volume
Untuk menghapus semua volume dan pemasangan volume dari kumpulan pekerja satu-penampung, jalankan perintah berikut:
gcloud beta run worker-pools update WORKER_POOL \ --clear-volumes --clear-volume-mounts
Jika Anda memiliki beberapa container, ikuti konvensi CLI sidecar untuk menghapus volume dan pemasangan volume:
gcloud beta run worker-pools update WORKER_POOL \ --container=container1 \ --clear-volumes -–clear-volume-mounts \ --container=container2 \ --clear-volumes \ -–clear-volume-mounts
Menghapus volume dan pemasangan volume individual
Untuk menghapus volume, Anda juga harus menghapus semua pemasangan volume yang menggunakan volume tersebut.
Untuk menghapus volume atau pemasangan volume satu per satu, gunakan flag remove-volume
dan remove-volume-mount
:
gcloud beta run worker-pools update WORKER_POOL \ --remove-volume VOLUME_NAME \ --container=container1 \ --remove-volume-mount MOUNT_PATH \ --container=container2 \ --remove-volume-mount MOUNT_PATH