News, Devops, Software, Webdev

5 Best Practices Docker yang Harus Kamu Tahu

Eko Susilo Harjo September 10, 2024
docker
docker

1. Gunakan Multi-Stage Builds untuk Membuat Image Docker yang Lebih Kecil

Docker memiliki fitur multi-stage build yang sangat berguna untuk membuat image Docker yang lebih efisien. Dengan menggunakan multi-stage build, kamu dapat membuat image yang lebih kecil, yang pada akhirnya dapat menghemat waktu dan ruang penyimpanan.Contoh Dockerfile untuk aplikasi Go yang menggunakan multi-stage build adalah sebagai berikut:

# Stage build
FROM golang:1.16 AS builder
WORKDIR /app
COPY . .
RUN go build -o main .

# Final stage
FROM alpine:latest
WORKDIR /root/
COPY --from=builder /app/main .
CMD ["./main"]

Dalam contoh di atas, kita menggunakan image Go untuk membangun aplikasi, lalu kita copas hanya file binari yang telah dibangun ke dalam image Alpine yang lebih kecil. Dengan demikian, kita dapat menghemat ruang penyimpanan dan membuat proses deployment lebih cepat

2. Gunakan .dockerignore untuk Menghindari File yang Tidak Perlu

File .dockerignore adalah seperti .gitignore untuk Git, yaitu untuk menghindari file yang tidak perlu dimasukkan ke dalam konteks build Docker. Ini sangat penting karena dapat mempercepat proses build, mencegah file sensitif masuk ke dalam image, dan mengurangi ukuran akhir image.Contoh file .dockerignore adalah sebagai berikut:

.git
*.md
*.log
node_modules
test

Dengan menggunakan file .dockerignore, kamu dapat memastikan bahwa proses build Docker lebih cepat dan image yang dihasilkan lebih bersih dan lebih aman

3. Implementasikan Health Check dalam Dockerfile

Health check adalah fitur penting dalam Docker yang memungkinkan kamu untuk memastikan bahwa kontainer tidak hanya berjalan, tetapi juga berfungsi dengan benar. Dengan health check, kamu dapat memastikan bahwa aplikasi berfungsi dengan benar dan dapat memulai ulang kontainer jika terjadi kesalahan.Contoh implementasi health check dalam Dockerfile untuk server Nginx adalah sebagai berikut:

FROM nginx:latest
HEALTHCHECK --interval=30s --timeout=3s --start-period=5s --retries=3 \
CMD curl -f http://localhost/ || exit 1

Dengan health check, kamu dapat memastikan bahwa kontainer dapat berfungsi dengan benar dan dapat memulai ulang kontainer jika terjadi kesalahan. Ini juga memungkinkan kamu untuk mengarahkan lalu lintas ke kontainer lain jika kontainer yang sedang berjalan tidak berfungsi

4. Gunakan Docker Compose untuk Pengembangan Lokal

Docker Compose adalah alat yang sangat berguna untuk mendefinisikan dan menjalankan aplikasi Docker multi-kontainer. Ini sangat berguna dalam pengembangan lokal karena memungkinkan kamu untuk menjalankan beberapa layanan yang terkait dalam satu file. Contoh file compose.yaml untuk aplikasi web yang menggunakan PostgreSQL adalah sebagai berikut:

version: '3'
services:
web:
build: .
ports:
- "8000:8000"
volumes:
- .:/code
environment:
- DEBUG=True

db:
image: postgres:13
environment:
- POSTGRES_DB=myapp
- POSTGRES_PASSWORD=secret

Dengan menggunakan Docker Compose, kamu dapat menjalankan semua layanan dalam satu file dan memastikan bahwa lingkungan pengembangan kamu lebih konsisten dan lebih mudah diatur

5. Jangan Terlalu Bergantung pada Tag Terbaru

Menggunakan tag terbaru mungkin terdengar nyaman, tetapi ini dapat menyebabkan masalah yang tidak terduga dan membuat proses build kurang dapat diprediksi. Alasannya adalah karena tag terbaru tidak merujuk pada versi spesifik dan dapat berubah tanpa peringatan.Sebaliknya, lebih baik menggunakan versi spesifik dalam Dockerfile atau file compose.yaml. Contoh penggunaan versi spesifik adalah sebagai berikut:

FROM node:18.20.4

Dengan menggunakan versi spesifik, kamu dapat memastikan bahwa semua anggota tim menggunakan versi yang sama dan dapat mereproduksi proses build dengan lebih mudah

Bonus: Lakukan Scan Keamanan Secara Teratur

Keamanan harus menjadi prioritas utama ketika bekerja dengan image Docker. Melakukan scan keamanan secara teratur dapat membantu kamu mengidentifikasi dan mengatasi kerentanan dalam kontainer sebelum menjadi masalah.Salah satu alat yang sangat berguna untuk tujuan ini adalah Docker Scout, yang terintegrasi langsung ke Docker Desktop dan CLI Docker. Contoh penggunaan Docker Scout untuk mengscan image Nginx adalah sebagai berikut:

docker scout cve nginx:latest

Dengan melakukan scan keamanan secara teratur, kamu dapat memastikan bahwa lingkungan produksi kamu lebih aman dan dapat mengambil keputusan yang lebih tepat tentang kapan harus memperbarui base image atau dependensi

Dengan mengikuti praktik-praktik di atas, kamu dapat membuat penggunaan Docker lebih efisien, lebih aman, dan lebih mudah dijalankan. Mulai dari menggunakan multi-stage builds hingga melakukan scan keamanan secara teratur, setiap praktik dapat membantu kamu dalam membuat aplikasi container yang lebih baik dan lebih stabil.


Discover more from teknologi now

Subscribe to get the latest posts sent to your email.

Pengenalan Go 1.25 baru saja rilis dan bawa banyak peningkatan yang bikin hidup developer lebih gampang. Di artikel ini, kita bakal bahas tiga fitur paling menonjol: DWARF v5 untuk debugging yang lebih ringan, go doc -http yang menyiapkan server dokumentasi lokal dalam hitungan detik, serta interface XOF untuk hash yang output‑nya bisa diperpanjang. Semua dijelaskan dengan […]

News

Change Data Capture (CDC)

Eko Susilo Harjo

28 August 2025

Di era digital, sistem ERP (Enterprise Resource Planning) menjadi tulang punggung perusahaan. Semua proses – mulai dari keuangan, HR, inventori, hingga produksi – bertumpu pada data yang terus berubah setiap detik.Tantangannya: bagaimana cara menampilkan data yang selalu up-to-date tanpa membebani server? Jawabannya ada pada teknologi Change Data Capture (CDC). Apa itu CDC? Change Data Capture […]

Pengantar MLOps (Machine Learning Operations) adalah gabungan praktik DevOps yang diterapkan pada seluruh siklus hidup model AI. Dengan MLOps, tim dapat memindahkan model dari notebook eksperimen ke produksi secara reliable, terukur, dan otomatis. Artikel ini bakal ngasih blueprint praktis untuk developer, data scientist, dan platform engineer yang mau membangun sistem ML produksi. Siklus Hidup MLOps […]

Discover more from teknologi now

Subscribe now to keep reading and get access to the full archive.

Continue reading