Skip to content

emka.web.id

menulis pengetahuan – merekam peradaban

Menu
  • Home
  • Tutorial
  • Search
Menu

Apa Itu Docker Image Layers?

Posted on September 4, 2022

Docker terdiri dari beberapa layers yang secara kolektif menyediakan konten yang Anda lihat di wadah Anda. Tapi apa sebenarnya layers itu, dan apa bedanya dengan images utuh?

Dalam artikel ini Anda akan mempelajari cara membedakan kedua konsep ini dan mengapa perbedaan itu penting. Meskipun Anda dapat menggunakan Docker tanpa pemahaman yang menyeluruh tentang layers, memiliki kesadaran akan tujuannya akan membantu Anda mengidentifikasi peluang pengoptimalan.

Apa itu Docker Images?

A “images” Docker berperilaku seperti template tempat container yang konsisten dapat dibuat. Jika Docker adalah mesin virtual tradisional, image dapat disamakan dengan ISO yang digunakan untuk menginstal VM Anda. Ini bukan perbandingan yang kuat, karena Docker berbeda dari VM dalam hal konsep dan implementasi, tetapi tetap saja ini adalah titik awal yang berguna.

Images menentukan status sistem file awal dari container baru. Mereka menggabungkan kode sumber aplikasi Anda dan dependensinya ke dalam paket mandiri yang siap digunakan dengan runtime container. Di dalam images, konten sistem file direpresentasikan sebagai beberapa layers independen.

Apa itu layers?

Layers adalah hasil dari cara images Docker dibangun. Setiap langkah dalam Dockerfile membuat “layers” baru yang pada dasarnya berbeda dengan perubahan sistem file sejak langkah terakhir. Instruksi metadata seperti LABEL dan MAINTAINER tidak membuat layer karena tidak mempengaruhi filesystem.

images ini memiliki dua instruksi (COPY dan RUN) sehingga akan membuat dua layer:

FROM ubuntu:latest
SALIN foo.txt /foo.txt
RUN date > /built-on.txt

Langkah pertama menyalin foo.txt ke dalam layer baru yang didasarkan pada ubuntu:images terbaru.Langkah kedua menjalankan perintah date dan menyalurkan outputnya ke dalam file. Ini membuat layers kedua yang didasarkan pada one.

Create foo.txt sebelumnya di direktori kerja Anda:

$ echo “Hello World” > foo.txt

Sekarang buat contoh images:

$ docker build . -t demo: terbaru
Mengirim konteks build ke daemon Docker 2.56kB
Langkah 1/3 : DARI ubuntu: terbaru
—> df5de72bdb3b
Langkah 2/3 : SALIN foo.txt /foo.txt
—> 4932aede6a15
Langkah 3/3 : JALANKAN tanggal > /built-on.txt
—> Berjalan di 91d260fc2e68
Menghapus wadah perantara 91d260fc2e68
—> 6f653c6a60fa
Berhasil membangun 6f653c6a60fa
Berhasil memberi tag foo:latest

Setiap build step memancarkan ID dari layer yang dibuat. layers langkah terakhir menjadi images akhir sehingga diberi tag dengan foo:latest.

Urutan mengungkapkan bahwa layers adalah images Docker yang valid. Meskipun istilah “layers” biasanya tidak digunakan untuk merujuk pada images yang diberi tag, semua images yang diberi tag secara teknis hanyalah layers dengan pengenal yang ditetapkan.

Anda dapat memulai wadah dari images layers perantara:

$ docker run -it 4932aede6a15 sh
# cat /foo.txt
Halo Dunia
# cat /built-on.txt
cat: /built-on.txt: No such file or directory

Contoh ini memulai container dari layer yang dibuat oleh langkah build kedua. foo.txt tersedia di wadah tetapi built-on.txt tidak ada karena tidak ditambahkan sampai langkah ketiga. File itu hanya tersedia di sistem file layers berikutnya.

Peranan Layers

Layers berisi perubahan yang dibuat oleh langkah pembuatan, relatif terhadap layers sebelumnya di Dockerfile. Instruksi FROM adalah kasus khusus yang mereferensikan layers terakhir dari images yang ada.

Layers memungkinkan langkah-langkah pembangunan di-cache untuk menghindari pekerjaan yang berlebihan. Docker dapat melewati instruksi yang tidak diubah di Dockerfile Anda dengan menggunakan kembali layers yang dibuat sebelumnya. Ini mendasarkan langkah selanjutnya pada layers yang ada, alih-alih membangun yang baru.

Anda dapat melihat ini dengan memodifikasi file Docker Anda sebagai berikut:

FROM ubuntu:latest
SALIN foo.txt /foo.txt
Tanggal RUN +%Y-%m-%d > /built-on.txt

Langkah build ketiga telah berubah. Sekarang bangun kembali image:

$ docker build Anda. -t demo: terbaru
Mengirim konteks build ke daemon Docker 3.584kB
Langkah 1/3 : DARI ubuntu: terbaru
—> df5de72bdb3b
Langkah 2/3 : SALIN foo.txt /foo.txt
—> Menggunakan cache
—> 4932aede6a15
Langkah 3/3 : JALANKAN tanggal +%Y-%m-%d > /built-on.txt
—> Berjalan di 2b91ec0462c4
Menghapus wadah perantara 2b91ec0462c4
—> c6647ff378c1
Berhasil membangun c6647ff378c1
Berhasil menandai demo:latest

Langkah pembuatan kedua ditampilkan sebagai Menggunakan cache dan menghasilkan ID layers yang sama. Docker dapat melewati pembuatan layers ini karena sudah dibuat sebelumnya dan foo.txt tidak berubah sejak build.

pertama Caching ini hanya berfungsi sampai layers dimodifikasi. Semua langkah setelah layers itu perlu dibangun kembali juga sehingga didasarkan pada revisi sistem file baru.

Layers dan Operasi Pull

Manfaat lain dari layers adalah cara mereka mengaktifkan penarikan images sebagian. Setelah Anda mengunduh beberapa images ke mesin Anda, Anda akan sering menemukan tarikan baru dapat melewati beberapa layers yang sudah Anda miliki. images ini berisi 13 layers tetapi hanya enam yang harus diunduh oleh operasi tarik:

docker pull php: 8.0-apache
8.0-apache: Menarik dari perpustakaan/php
7a6db449b51b: Sudah ada
ad2afdb99a9d: Sudah ada
dbc5aa907229: Sudah ada
82f252ab4ad1: Sudah ada
bf5b34fc9894: Sudah ada
6161651d3d95: Sudah ada
cf2adf296ef1: Sudah ada
f0d7c5221e44: Tarik selesai
f647198f6316: Tarik selesai
c37afe1da4e5: Tarik selesai
09c93531cbca: Tarik selesai
fef371007dd3: Tarik selesai
52043dbb1c06: Tarik selesai
Intisari: sha256:429889e8f9eac0a806a005b0728a004303b0d49d77b09496d39158707abd6280
Status: Mengunduh images yang lebih baru untuk php:8.0-apache
docker.io/library/php:8.0-apache

layers lain sudah ada di host Docker sehingga dapat digunakan kembali. Ini meningkatkan kinerja dan menghindari pemborosan bandwidth jaringan.

Memeriksa layers images

Anda dapat membuat daftar layers di dalam images dengan menjalankan perintah riwayat images buruh pelabuhan. Setiap layers menampilkan ID dari images yang dibuat dan instruksi Dockerfile yang menyebabkan perubahan. Anda juga dapat melihat ukuran total konten di dalam layers.

$ docker images ls
images DIBUAT OLEH UKURAN KOMENTAR
6f653c6a60fa 4 menit yang lalu /bin/sh -c date > /built-on.txt 29B
f8420d1a96f3 4 menit yang lalu /bin/sh -c #(nop) SALIN file:a5630a7506b26a37… 0B
df5de72bdb3b 4 minggu yang lalu /bin/sh -c #(nop) CMD [“bash”] 0B
4 minggu yang lalu /bin/sh -c #(nop) ADD file:396eeb65c8d737180… 77.8MB

layers terakhir ditampilkan karena mengacu pada layers di dalam ubuntu:images dasar terbaru. Ini tidak tersedia secara lokal, karena hanya layers terakhir dari images dasar (df5de72bdb3b) yang ditarik ke bawah selama pembuatan. Tidak perlu secara independen menarik semua layers perantara saat Anda ingin menggunakan images tertentu.

Kesimpulan

images dan layers Docker umumnya merupakan istilah yang dapat dipertukarkan. layers adalah images dan images terbentuk dari satu atau lebih layers. Perbedaan utama terletak pada tag: images akan ditandai dan dirancang untuk pengguna akhir, sedangkan istilah “layers” biasanya mengacu pada images perantara yang tidak ditandai yang dibuat sebagai bagian dari operasi pembuatan. Ini tidak terlihat kecuali Anda mencarinya.

Ada satu topik lagi yang berhubungan dengan layers: menjalankan wadah menambahkan layers tambahan yang dapat ditulis di atas imagesnya. layers yang bersumber dari images penampung bersifat hanya-baca sehingga modifikasi sistem file yang dibuat oleh penampung menargetkan layers ephemeral yang dapat ditulis. layers yang dapat ditulis akan dibuang saat penampung dihentikan atau dihapus.

Itulah berita seputar Apa Itu layers images Docker?, semoga bermanfaat. Disadur dari HowToGeek.com.

Terbaru

  • Inilah 7 Produk Digital Paling Realistis untuk Kalian yang Mau Jualan Online Tahun Ini!
  • Inilah 4 Strategi Memilih Niche SEO Terbaik Supaya Blog Kalian Cepat Ranking
  • Ini Trik Supaya Pengunjung Toko Online Kalian Jadi Pembeli Setia Pakai Omnisend!
  • 3 Strategi AI Terbukti Biar Bisnis E-Commerce Kalian Makin Cuan 2026!
  • Inilah 6 Langkah Tembus 5.000 Follower di X, Gini Caranya Supaya Akun Kalian Nggak Stuck Lagi!
  • SEO LinkedIn: Inilah Alasan Kenapa LinkedIn Ads Lebih Efektif Buat Bisnis B2B Dibanding Platform Lain
  • Inilah Alasan Kenapa Kolom Komentar YouTube Kalian Sering Menghilang Secara Misterius!
  • Cara Kelola Auto-Posting Semua Media Sosial Kalian Pakai Metricool
  • Studi Kasus Sukses Instagram Maria Wendt Dapat 12 Juta View Instagram Per Bulan
  • ZenBook S16, Vivobook Pro 15 OLED, ProArt PX13, dan ROG Zephyrus G14, Laptop Bagus dengan Layar OLED!
  • Caranya Ngebangun Website Directory dengan Traffic Tinggi dalam Seminggu!
  • Cara Mengembangkan Channel YouTube Shorts Tanpa Wajah
  • Inilah Cara Menghitung Diskon Baju Lebaran Biar Nggak Bingung Saat Belanja di Mall!
  • Cara Jitu Ngebangun Bisnis SaaS di Era AI Pakai Strategi Agentic Workflow
  • Inilah Rincian Gaji Polri Lulusan Baru 2026, Cek Perbedaan Jalur Akpol, Bintara, dan Tamtama Sebelum Daftar!
  • Inilah 5 Channel YouTube Membosankan yang Diam-diam Menghasilkan Banyak Uang
  • Inilah Cara Pakai Google Maps Offline Biar Mudik Lebaran 2026 Nggak Nyasar Meski Tanpa Sinyal!
  • Inilah Alasan Mahkamah Agung Tolak Kasasi Google, Denda Rp202,5 Miliar Resmi Menanti Akibat Praktik Monopoli
  • Inilah Cara Daftar dan Syarat SPMB SMK Boarding Jawa Tengah 2026, Sekolah Gratis Sampai Lulus!
  • Inilah Daftar Sekolah Kedinasan 2026 untuk Lulusan SMK, Bisa Kuliah Gratis dan Berpeluang Besar Langsung Jadi CPNS!
  • Inilah Pajak TER: Skema Baru PPh 21 yang Nggak Bikin Pusing, Begini Cara Hitungnya!
  • Inilah Jadwal Resmi Jam Buka Tol Jogja-Solo Segmen Prambanan-Purwomartani Saat Mudik Lebaran 2026
  • Inilah Cara Mendapatkan Witherbloom di Fisch Roblox, Rahasia Menangkap Ikan Paling Sulit di Toxic Grove!
  • Kenapa Indomart Point Bisa Kalahkan Bisnis Kafe?
  • Inilah Cara Mendapatkan Rotten Seed di Fisch Roblox, Lokasi Rahasia di Toxic Grove Buat Unlock Toxic Lotus!
  • Inilah Cara Zakat Crypto Kalian Bisa Jadi Pengurang Pajak Berdasarkan Aturan Resmi Pemerintah!
  • Inilah Perbandingan Airwallex vs Payoneer 2026: Jangan Sampai Profit Kalian Ludes Gara-Gara Biaya Admin!
  • Inilah Roadmap 7 Tahap Bangun Bisnis Digital dari Nol Biar Nggak Cuma Putar-Putar di Tempat!
  • Inilah Cara Tetap Gajian dari YouTube Meski View Masih Ratusan, Penasaran?
  • Inilah Alasan Akun TikTok Affiliate GMV 270 Juta Kena Banned Permanen!
  • Why Does the VirtualBox System Service Terminate Unexpectedly? Here is the Full Definition
  • Why is Your Laptop Touchpad Overheating? Here are the Causes and Fixes
  • How to Disable All AI Features in Chrome Using Windows 11 Registry
  • How to Avoid Problematic Windows Updates: A Guide to System Stability
  • What is Microsoft Visual C++ Redistributable and How to Fix Common Errors?
  • How to Use Orbax Checkpointing with Keras and JAX for Robust Training
  • How to Automate Any PDF Form Using the Power of Manus AI
  • How to Training Your Own YOLO26 Object Detection Model!
  • How to Build a Full-Stack Mobile App in Minutes with YouWare AI
  • How to Create Consistent Characters and Cinematic AI Video Production with Seedance
  • Apa itu Spear-Phishing via npm? Ini Pengertian dan Cara Kerjanya yang Makin Licin
  • Apa Itu Predator Spyware? Ini Pengertian dan Kontroversi Penghapusan Sanksinya
  • Mengenal Apa itu TONESHELL: Backdoor Berbahaya dari Kelompok Mustang Panda
  • Siapa itu Kelompok Hacker Silver Fox?
  • Apa itu CVE-2025-52691 SmarterMail? Celah Keamanan Paling Berbahaya Tahun 2025

©2026 emka.web.id | Design: Newspaperly WordPress Theme