Blog
Thoughts on engineering, design, and building great products.
Image và Cơ Chế Layer: Pull, Tag, Docker Hub
Image đến từ đâu và gồm những gì: cách đọc tên image, registry Docker Hub, layer dùng chung giữa các image, digest, và quản lý image trên máy bằng pull/images/tag/rmi/history.
Viết Dockerfile và Build Cache
Tự dựng image cho ứng dụng của bạn: các lệnh Dockerfile cốt lõi, mỗi lệnh tạo một layer, và build cache hoạt động ra sao — vì sao đặt cài dependency trước copy code giúp build nhanh hơn nhiều.
Volumes và Bind Mount: Lưu Dữ Liệu Bền Vững
Dữ liệu trong container biến mất khi container bị xóa. Bài này giải quyết: named volume do Docker quản lý và bind mount gắn thẳng thư mục host, khi nào dùng cái nào, kèm ví dụ chứng minh dữ liệu sống sót.
Mạng trong Docker: Bridge, veth và Port Mapping
Cách container kết nối với nhau và với bên ngoài: các network driver, bridge mặc định và cơ chế veth, port publishing, và vì sao user-defined network cho phép gọi nhau bằng tên còn bridge mặc định thì không.
Docker Compose: Chạy Ứng Dụng Nhiều Container
Khai báo cả một ứng dụng nhiều thành phần (web, database, cache) trong một file rồi chạy bằng một lệnh. Hiểu compose file, mạng tự tạo cho các service gọi nhau bằng tên, và vòng đời up/down.
Tối Ưu Image: Multi-Stage Build và Bảo Mật
Image to làm chậm deploy và tăng bề mặt tấn công. Bài này thu nhỏ image bằng multi-stage build (ví dụ thật: 301MB xuống 15.4MB), chọn base image gọn, chạy non-root, và không nhúng secret.
Docker Swarm: Kiến Trúc Cluster và Raft
Bước sang điều phối nhiều máy: Swarm gom nhiều Docker host thành một cụm với manager và worker. Hiểu mô hình desired-state, cơ chế đồng thuận Raft và vì sao nên có số manager lẻ. Kèm khởi tạo cụm và cách giả lập nhiều node để học.