Mulai Cepat: Menyusun dan menjalankan gambar kontainer menggunakan Tugas Azure Container Registry

Dalam mulai cepat ini, Anda menggunakan perintah Tugas Azure Container Registry untuk menyusun, mendorong, dan menjalankan gambar kontainer Docker dengan cepat langsung di dalam Azure, tanpa penginstalan Docker lokal. Tugas ACR adalah serangkaian fitur dalam Azure Container Registry untuk membantu Anda mengelola dan memodifikasi citra kontainer di seluruh siklus hidup kontainer. Contoh ini menunjukkan cara memindahkan siklus pengembangan gambar kontainer "inner-loop" Anda ke cloud dengan build sesuai permintaan menggunakan Dockerfile lokal.

Setelah mulai cepat ini, jelajahi fitur yang lebih canggih dari Tugas Azure Container Registry menggunakan tutorial. Tugas ACR dapat mengotomatiskan build gambar berdasarkan penerapan kode atau pembaruan gambar dasar, atau menguji beberapa kontainer secara paralel, di antara skenario lainnya.

Jika Anda tidak memiliki Langganan Azure, buat Akun gratis Azure sebelum memulai.

Prasyarat

  • Mulai cepat ini memerlukan Azure CLI versi 2.0.58 atau yang lebih baru. Jika menggunakan Azure Cloud Shell, versi terbaru sudah terinstal.

Buat grup sumber daya

Jika Anda belum memiliki registri kontainer, pertama-tama buat grup sumber daya dengan perintah az group create. Grup sumber daya Azure adalah kontainer logis tempat sumber daya Azure disebarkan dan dikelola.

Contoh berikut ini menampilkan cara membuat grup sumber daya bernama myResourceGroup di lokasi eastus.

az group create --name myResourceGroup --location eastus

Membuat registri kontainer

Buat registri kontainer menggunakan perintah az acr create. Nama registri haruslah unik dalam Azure, dan berisi antara 5-50 karakter alfanumerik. Dalam contoh berikut, mycontainerregistry008 digunakan. Perbarui nama ini ke nilai yang unik.

az acr create --resource-group myResourceGroup \
  --name mycontainerregistry008 --sku Basic

Contoh ini membuat registri Dasar, opsi dengan biaya yang dioptimalkan untuk pengembang yang masih belajar tentang Azure Container Registry. Untuk detail tentang tingkat layanan yang tersedia, lihat Tingkat layanan registri kontainer.

Membangun dan mendorong gambar dari Dockerfile

Sekarang gunakan Azure Container Registry untuk membuat dan mendorong gambar. Pertama, buat direktori kerja lokal lalu buat Dockerfile bernama Dockerfile dengan satu baris: FROM mcr.microsoft.com/hello-world. Ini adalah contoh sederhana untuk membuat gambar kontainer Linux dari gambar hello-world yang dihosting di Microsoft Container Registry. Anda dapat membuat Dockerfile standar Anda sendiri dan membuat gambar untuk platform lain. Jika Anda bekerja di shell bash, buat Dockerfile dengan perintah berikut:

echo "FROM mcr.microsoft.com/hello-world" > Dockerfile

Jalankan perintah az acr build, yang membuat gambar, dan setelah gambar berhasil dibuat, dorong ke registri Anda. Contoh berikut membuat dan mendorong gambar sample/hello-world:v1. Bagian . di akhir perintah mengatur lokasi Dockerfile, dalam hal ini yaitu direktori saat ini.

az acr build --image sample/hello-world:v1 \
  --registry mycontainerregistry008 \
  --file Dockerfile . 

Output dari pembuatan dan pendorongan yang berhasil serupa dengan hal berikut:

Packing source code into tar to upload...
Uploading archived source code from '/tmp/build_archive_b0bc1e5d361b44f0833xxxx41b78c24e.tar.gz'...
Sending context (1.856 KiB) to registry: mycontainerregistry008...
Queued a build with ID: ca8
Waiting for agent...
2019/03/18 21:56:57 Using acb_vol_4c7ffa31-c862-4be3-xxxx-ab8e615c55c4 as the home volume
2019/03/18 21:56:57 Setting up Docker configuration...
2019/03/18 21:56:58 Successfully set up Docker configuration
2019/03/18 21:56:58 Logging in to registry: mycontainerregistry008.azurecr.io
2019/03/18 21:56:59 Successfully logged into mycontainerregistry008.azurecr.io
2019/03/18 21:56:59 Executing step ID: build. Working directory: '', Network: ''
2019/03/18 21:56:59 Obtaining source code and scanning for dependencies...
2019/03/18 21:57:00 Successfully obtained source code and scanned for dependencies
2019/03/18 21:57:00 Launching container with name: build
Sending build context to Docker daemon  13.82kB
Step 1/1 : FROM mcr.microsoft.com/hello-world
latest: Pulling from hello-world
Digest: sha256:2557e3c07ed1e38f26e389462d03ed943586fxxxx21577a99efb77324b0fe535
Successfully built fce289e99eb9
Successfully tagged mycontainerregistry008.azurecr.io/sample/hello-world:v1
2019/03/18 21:57:01 Successfully executed container: build
2019/03/18 21:57:01 Executing step ID: push. Working directory: '', Network: ''
2019/03/18 21:57:01 Pushing image: mycontainerregistry008.azurecr.io/sample/hello-world:v1, attempt 1
The push refers to repository [mycontainerregistry008.azurecr.io/sample/hello-world]
af0b15c8625b: Preparing
af0b15c8625b: Layer already exists
v1: digest: sha256:92c7f9c92844bbbb5d0a101b22f7c2a7949e40f8ea90c8b3bc396879d95e899a size: 524
2019/03/18 21:57:03 Successfully pushed image: mycontainerregistry008.azurecr.io/sample/hello-world:v1
2019/03/18 21:57:03 Step ID: build marked as successful (elapsed time in seconds: 2.543040)
2019/03/18 21:57:03 Populating digests for step ID: build...
2019/03/18 21:57:05 Successfully populated digests for step ID: build
2019/03/18 21:57:05 Step ID: push marked as successful (elapsed time in seconds: 1.473581)
2019/03/18 21:57:05 The following dependencies were found:
2019/03/18 21:57:05
- image:
    registry: mycontainerregistry008.azurecr.io
    repository: sample/hello-world
    tag: v1
    digest: sha256:92c7f9c92844bbbb5d0a101b22f7c2a7949e40f8ea90c8b3bc396879d95e899a
  runtime-dependency:
    registry: registry.hub.docker.com
    repository: library/hello-world
    tag: v1
    digest: sha256:2557e3c07ed1e38f26e389462d03ed943586f744621577a99efb77324b0fe535
  git: {}

Run ID: ca8 was successful after 10s

Menjalankan gambar

Sekarang cepat jalankan gambar yang Anda buat dan dorong ke registri Anda. Di sini Anda menggunakan az acr run untuk menjalankan perintah kontainer. Dalam alur kerja pengembangan kontainer Anda, langkah ini mungkin merupakan langkah validasi sebelum Anda menyebarkan gambar, atau Anda bisa menyertakan perintah dalam file YAML multi-step.

Contoh berikut menggunakan $Registry untuk menentukan titik akhir registri tempat Anda menjalankan perintah:

az acr run --registry mycontainerregistry008 \
  --cmd '$Registry/sample/hello-world:v1' /dev/null

Parameter cmd dalam contoh ini menjalankan kontainer dalam konfigurasi defaultnya, tetapi cmd mendukung parameter docker run tambahan atau bahkan perintah docker lainnya.

Outputnya mirip dengan berikut ini:

Packing source code into tar to upload...
Uploading archived source code from '/tmp/run_archive_ebf74da7fcb04683867b129e2ccad5e1.tar.gz'...
Sending context (1.855 KiB) to registry: mycontainerre...
Queued a run with ID: cab
Waiting for an agent...
2019/03/19 19:01:53 Using acb_vol_60e9a538-b466-475f-9565-80c5b93eaa15 as the home volume
2019/03/19 19:01:53 Creating Docker network: acb_default_network, driver: 'bridge'
2019/03/19 19:01:53 Successfully set up Docker network: acb_default_network
2019/03/19 19:01:53 Setting up Docker configuration...
2019/03/19 19:01:54 Successfully set up Docker configuration
2019/03/19 19:01:54 Logging in to registry: mycontainerregistry008.azurecr.io
2019/03/19 19:01:55 Successfully logged into mycontainerregistry008.azurecr.io
2019/03/19 19:01:55 Executing step ID: acb_step_0. Working directory: '', Network: 'acb_default_network'
2019/03/19 19:01:55 Launching container with name: acb_step_0

Hello from Docker!
This message shows that your installation appears to be working correctly.

To generate this message, Docker took the following steps:
 1. The Docker client contacted the Docker daemon.
 2. The Docker daemon pulled the "hello-world" image from the Docker Hub.
    (amd64)
 3. The Docker daemon created a new container from that image which runs the
    executable that produces the output you are currently reading.
 4. The Docker daemon streamed that output to the Docker client, which sent it
    to your terminal.

To try something more ambitious, you can run an Ubuntu container with:
 $ docker run -it ubuntu bash

Share images, automate workflows, and more with a free Docker ID:
 https://hub.docker.com/

For more examples and ideas, visit:
 https://docs.docker.com/get-started/

2019/03/19 19:01:56 Successfully executed container: acb_step_0
2019/03/19 19:01:56 Step ID: acb_step_0 marked as successful (elapsed time in seconds: 0.843801)

Run ID: cab was successful after 6s

Membersihkan sumber daya

Ketika tidak lagi diperlukan, Anda dapat menggunakan perintah az group delete untuk menghapus grup sumber daya, registri kontainer, dan gambar kontainer yang disimpan di sana.

az group delete --name myResourceGroup

Langkah berikutnya

Dalam mulai cepat ini, Anda akan menggunakan fitur Tugas Azure Container Registry untuk membuat, mendorong, dan menjalankan gambar kontainer Docker dengan cepat langsung di dalam Azure, tanpa penginstalan Docker lokal. Lanjutkan ke tutorial Tugas Azure Container Registry untuk mempelajari penggunaan Tugas Azure Container Registry untuk mengotomatiskan pembuatan dan pembaruan gambar.