Làm Thế Nào Để Tạo Docker Image Cross-Platform Với Buildx Và Colima

Hello, các bạn! Hôm nay mình muốn chia sẻ một chút kinh nghiệm và mẹo nhỏ về cách mà mình đã sử dụng BuildxColima để tạo ra những image container cross-platform một cách dễ dàng. Nếu bạn cũng đang loay hoay không biết làm sao để hỗ trợ nhiều kiến trúc phần cứng khác nhau thì bài viết này sẽ là cứu tinh cho bạn đấy!

Tại Sao Lại Dùng Buildx Và Colima?

Khi làm việc với Docker, mình thường gặp phải vấn đề khi cần build image cho các kiến trúc khác nhau (VD: amd64, arm64,…). Đó là lúc mình biết đến Buildx, một công cụ cực kỳ hữu ích của Docker giúp bạn có thể build image cho nhiều nền tảng mà không cần phải sở hữu phần cứng đặc thù. Còn Colima lại là một ứng dụng nhẹ nhàng giúp bạn chạy Docker trên macOS với hiệu năng tốt hơn, mà không cần phải cài đặt nặng nề gì.

Ví dụ cụ thể: Mình có một ứng dụng Node.js chạy trên máy tính Mac (chip arm64). Thông thường, nếu build thẳng từ đây, image chỉ hỗ trợ cho kiến trúc arm64, nhưng mình lại cần deploy lên một máy chủ sử dụng chip amd64. Thay vì phải chuyển đổi thủ công, mình có thể sử dụng Buildx để tạo ra một image đa nền tảng trong một nốt nhạc!

Setup Colima Để Chạy Docker

Đầu tiên, hãy setup Colima trên máy của bạn nhé. Đối với những bạn dùng macOS như mình, Colima chính là một lựa chọn tuyệt vời. Chỉ cần một vài dòng lệnh thôi là bạn đã có thể sử dụng được rồi.

brew install colima
colima start

Để xác định colima đã chạy đúng chưa bạn chạy lệnh:

colima status

Kết quả trả về là:

INFO[0000] colima is running using QEMU                 
INFO[0000] arch: aarch64                                
INFO[0000] runtime: docker                              
INFO[0000] mountType: sshfs                             
INFO[0000] socket: unix:///Users/anthony/.colima/default/docker.sock
colima status

Voila! Docker đã sẵn sàng để bạn sử dụng rồi đó.

Cài Đặt Và Cấu Hình Buildx

Giờ thì hãy đến với Buildx. Nếu bạn chưa cài đặt nó, chỉ cần chạy lệnh sau để thêm plugin Buildx vào Docker:

docker buildx create --name multiplatform-builder
docker buildx use multiplatform-builder
docker buildx inspect --bootstrap

Giải thích: Lệnh create sẽ tạo ra một Buildx builder instance mới với tên là multiplatform-builder. Sau đó, bạn sử dụng lệnh use để chọn builder này làm builder mặc định. Cuối cùng, lệnh inspect --bootstrap giúp bạn kiểm tra xem builder instance đã được cấu hình đúng cho việc build multi-platform hay chưa.

Giờ thì bạn đã có thể bắt đầu build những image container cross-platform rồi đấy!

Build Image Cross-Platform

Nếu bạn muốn build một image hỗ trợ cho nhiều kiến trúc, bạn chỉ cần sử dụng lệnh buildx như sau:

docker buildx build --platform linux/amd64,linux/arm64 -t <your_image_name>:<tag> .

Giải thích một chút nhé: Ở đây, --platform chỉ định các kiến trúc bạn muốn hỗ trợ (như amd64arm64), và -t là tên image bạn muốn build. Cuối cùng, dấu . đại diện cho thư mục hiện tại, nơi chứa file Dockerfile của bạn.

Khi chạy lệnh này, Docker sẽ tự động build image cho cả hai nền tảng amd64arm64. Thật tiện lợi phải không nào?

Đẩy Image Lên Registry

Cuối cùng, sau khi đã build xong image, bạn có thể đẩy nó lên một Docker registry như Docker Hub, để có thể sử dụng ở bất kỳ đâu.

docker push <our_image_name>:<tag>

Bây giờ, bạn có thể sử dụng image này trên bất kỳ máy chủ nào, bất kể nền tảng mà nó chạy!

Kết Luận

Vậy là mình vừa chia sẻ xong cách để tạo ra image container cross-platform bằng Buildx và Colima. Hy vọng bài viết này sẽ giúp ích cho các bạn trong việc phát triển và triển khai ứng dụng một cách dễ dàng hơn. Hãy thử ngay và chia sẻ với mình những kết quả mà bạn đạt được nhé!

Hẹn gặp lại các bạn trong bài viết sau. Chúc bạn code vui!