Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
Gunakan bind mount dengan Amazon ECS
Dengan pemasangan bind, file atau direktori pada host, seperti instans Amazon EC2, dipasang ke dalam wadah. Bind mount didukung untuk tugas yang di-host di instans Fargate dan Amazon EC2. Dudukan pengikat diikat ke siklus hidup wadah yang menggunakannya. Setelah semua kontainer yang menggunakan bind mount dihentikan, seperti saat tugas dihentikan, data akan dihapus. Untuk tugas yang dihosting di instans Amazon EC2, data dapat dikaitkan dengan siklus hidup instans Amazon EC2 host dengan menentukan nilai dan opsional dalam definisi tugas Anda. host sourcePath Untuk informasi selengkapnya, lihat Bind mount
Berikut ini adalah kasus penggunaan umum untuk pemasangan terikat.
-
Untuk menyediakan volume data kosong untuk memasang dalam satu atau lebih kontainer.
-
Untuk memasang volume data host dalam satu atau lebih kontainer.
-
Untuk berbagi volume data dari kontainer sumber dengan kontainer lain dalam tugas yang sama.
-
Untuk mengekspos jalur dan isinya dari Dockerfile ke satu atau lebih kontainer.
Pertimbangan saat menggunakan pemasangan terikat
Saat menggunakan bind mount, pertimbangkan hal berikut.
-
Secara default, tugas yang di-host saat AWS Fargate menggunakan versi platform
1.4.0atau yang lebih baru (Linux)1.0.0atau yang lebih baru (Windows) menerima minimal 20 GiB penyimpanan sementara untuk bind mount. Anda dapat meningkatkan jumlah total penyimpanan sementara hingga maksimum 200 GiB dengan menentukanephemeralStorageparameter dalam definisi tugas Anda. -
Untuk mengekspos file dari Dockerfile ke volume data saat tugas dijalankan, bidang data Amazon ECS mencari arahan.
VOLUMEJika jalur absolut yang ditentukan dalamVOLUMEdirektif sama dengan yang ditentukan dalam definisi tugas, data di jalurVOLUMEdirektif akan disalin ke volume data.containerPathDalam contoh Dockerfile berikut, file yang diberi namaexamplefiledalam/var/log/exporteddirektori ditulis ke host dan kemudian dipasang di dalam wadah.FROM public.ecr.aws/amazonlinux/amazonlinux:latest RUN mkdir -p/var/log/exportedRUN touch/var/log/exported/examplefileVOLUME ["/var/log/exported"]Secara default, izin volume diatur ke
0755dan pemilik sebagairoot. Anda dapat menyesuaikan izin ini di Dockerfile. Contoh berikut mendefinisikan pemilik direktori sebagainode.FROM public.ecr.aws/amazonlinux/amazonlinux:latest RUN yum install -y shadow-utils && yum clean all RUN useraddnodeRUN mkdir -p /var/log/exported && chownnode:node/var/log/exported RUN touch /var/log/exported/examplefile USERnodeVOLUME ["/var/log/exported"] -
Untuk tugas yang dihosting di instans Amazon EC2, saat
sourcePathnilaihostdan tidak ditentukan, daemon Docker mengelola pemasangan pengikat untuk Anda. Ketika tidak ada kontainer yang mereferensikan pemasangan pengikat ini, layanan pembersihan tugas agen penampung Amazon ECS akhirnya menghapusnya. Secara default, ini terjadi tiga jam setelah wadah keluar. Namun, Anda dapat mengonfigurasi durasi ini dengan variabelECS_ENGINE_TASK_CLEANUP_WAIT_DURATIONagen. Untuk informasi selengkapnya, lihat Konfigurasi agen kontainer Amazon ECS. Jika Anda memerlukan data ini untuk bertahan di luar siklus hidup penampung, tentukansourcePathnilai untuk bind mount. -
Untuk tugas yang di-host di Instans Terkelola Amazon ECS, bagian dari sistem file root hanya bisa dibaca. Read/write bind mount harus menggunakan direktori yang dapat ditulis seperti
/varuntuk data persisten atau/tmpuntuk data sementara. Mencoba membuat read/write bind mount ke direktori lain mengakibatkan tugas gagal diluncurkan dengan kesalahan yang mirip dengan yang berikut:error creating empty volume: error while creating volume path '/path': mkdir /path: read-only file systemDudukan bind read-only (dikonfigurasi dengan
mountPointsparameter) dapat mengarah ke direktori apa pun yang dapat diakses"readOnly": truedi host.Untuk melihat daftar lengkap jalur yang dapat ditulis, Anda dapat menjalankan tugas di Instans Terkelola Amazon ECS dan menggunakannya untuk memeriksa tabel pemasangan instans. Buat definisi tugas dengan pengaturan berikut untuk mengakses sistem file host:
{ "pidMode": "host", "containerDefinitions": [{ "privileged": true,...}] }Kemudian jalankan perintah berikut dari dalam wadah:
# List writable mounts cat /proc/1/root/proc/1/mounts | awk '$4 ~ /^rw,/ || $4 == "rw" {print $2}' | sort # List read-only mounts cat /proc/1/root/proc/1/mounts | awk '$4 ~ /^ro,/ || $4 == "ro" {print $2}' | sortpenting
privilegedPengaturan memberikan kemampuan yang diperluas pada wadah pada host, setara dengan akses root. Dalam contoh ini, digunakan untuk memeriksa tabel pemasangan host untuk tujuan diagnostik. Untuk informasi selengkapnya, lihat Hindari menjalankan kontainer sebagai hak istimewa (Amazon EC2).Untuk informasi selengkapnya tentang menjalankan perintah secara interaktif dalam kontainer, lihatMemantau Kontainer Amazon ECS dengan ECS Exec.