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

Nội dung

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!

Anthony Nguyễn

Cây bút chính tại VietnamTutor

Bài viết cùng chuyên mục

Git reset revert restore: chọn lệnh đúng

Bài viết so sánh git reset, git revert và git restore theo mục đích sử dụng: sửa staging area, khôi phục file, undo commit chưa push

Git commit vào nhánh sai: cách chuyển an toàn

Bài viết hướng dẫn xử lý git commit vào nhánh sai theo từng tình huống: commit chưa push, đã push, nhiều commit liên tiếp hoặc branch

TypeScript cho website doanh nghiệp: API, form và lỗi

TypeScript cho website doanh nghiệp đáng dùng khi bạn cần kiểm soát API contract, form schema, CMS payload và cấu hình môi trường. Bài này giúp

React Server Components performance: khi nào nên dùng?

React Server Components performance không phải phép màu. Bài này giúp bạn biết khi nào RSC giảm JavaScript thật, khi nào làm kiến trúc phức tạp

Git commit nhầm file: bỏ file khỏi commit an toàn

Bài viết hướng dẫn xử lý git commit nhầm file theo từng tình huống: chưa commit, đã commit chưa push, đã push lên remote, hoặc lỡ

Git reflog: khôi phục commit đã mất an toàn

Bài viết hướng dẫn dùng git reflog để khôi phục commit đã mất sau reset, rebase, amend hoặc xóa nhánh. Bạn sẽ biết cách đọc reflog,

Git pull bị conflict: cách sửa không mất code

Bài viết hướng dẫn cách xử lý git pull bị conflict theo từng bước: kiểm tra trạng thái, sửa file xung đột, test lại và hoàn

Môi trường database cô lập cho AI Agent: fork an toàn

Bài viết giải thích cách dùng môi trường database cô lập cho AI Agent theo mô hình baseline, fork, run, diff và discard/promote để thử nghiệm

Next.js production performance: chọn SSR, SSG, ISR hay Edge

Bài viết giúp developer và tech lead chọn cách render phù hợp để tối ưu Next.js production performance mà không làm kiến trúc phức tạp quá

Giảm chi phí Claude Code với Dynamic Workflows

Bài viết giúp developer, tech lead và agency giảm chi phí Claude Code khi thử Dynamic Workflows: biết khi nào nên dùng, đo token ra sao

Claude Code dynamic workflows vs subagents và Agent Teams

Claude Code dynamic workflows, Claude Code subagents và Claude Code Agent Teams khác nhau thế nào? Bài này giúp developer và tech lead chọn đúng cơ

Hóa đơn Claude 500 triệu USD: Kiểm soát chi phí AI

Hóa đơn Claude 500 triệu USD là con số được Axios dẫn lại từ một nguồn ẩn danh, chưa được xác nhận độc lập. Doanh nghiệp