- vừa được xem lúc

Kubernetes gửi lời chào 👋

0 0 23

Người đăng: Mai Trung Đức

Theo Viblo Asia

Xin chào các bạn, lại là mình đâyyyy, các bạn vẫn còn nhớ mình chứ 🤝🤝

Sau một thời gian thai nghén lâu lắm rồi, thì bây giờ mình mới ra được bài đầu tiên về series Kubernetes, trước giờ muốn viết muốn chia sẻ với các bạn nhiều lắm về 1 tool tuyệt vời như này, nhưng cứ chần chừ lần nữa mãi và cũng khá bận, đợt này tranh thủ rảnh là phải ngồi xuống chia sẻ với các bạn ngay.

Ở bài này mình sẽ giới thiệu tới các bạn tổng quan về kubernetes và các thành phần liên quan, rồi ta sẽ đi sâu vào các thành phần cần thiết ở các bài sau nhé 😃

Kubernetes says Hi 😊

Phát âm

Đầu tiên chúng ta cùng học cách phát âm tool này như thế nào nhé 😄. Mình thấy có 1 vài cách phát âm:

  • Kiu-bơ-nấy-tịt-s
  • Kiu-bơ-nà-tịt-s: đây là cách mình thích vì đọc nó khá là mượt, đọc đc nhanh hơn nghe cũng hay và nhẹ nhàng hơn, nếu là tiếng Anh Mỹ thì còn có thể đọc là "Kiu-bơ-nà-địt-s", sorry các bạn mình không cố ý nói tục 🤣🤣, nhưng mà mình hay nói theo kiểu anh mỹ 😉

Kubernetes người ta cũng hay viết tắt là K8S nữa, nên để ngắn gọn thì từ giờ về sau mình sẽ dùng chủ yếu K8S nhé

Vấn đề hiện tại

Như đã trình bày về những điều tuyệt vời mà Docker mang lại ở bài Lí do tôi yêu Docker, việc deploy app bằng Docker đã giúp giải quyết rất nhiều vấn đề tồn đọng theo kiểu deploy truyền thống từ ngày xưa.

Vậy nhưng khi chạy những app được dockerize ở production thì có nhiều vấn đề cần giải quyết:

  • như các bạn thấy, mỗi lần muốn có cập nhật mới thì ta phải docker compose down xong rồi up lại, khoảng thời gian giữa lúc down và up thì app của chúng ta bị shutdown, không hoạt động được
  • làm sao để có thể auto scale app lên được theo những thông số cụ thể: traffic nhận vào, CPU/RAM tăng cao,...?
  • deploy xong thấy có lỗi thì làm sao ngay lập tức quay lại bản cũ?
  • app đang chạy mà gặp lỗi bị down thì làm sao restart lại nó? nếu HEALTHCHECK mà fail thì không nên mở cho traffic đi vào,...
  • quản lý volume
  • phân quyền, tách biệt các projects với nhau...
  • trường hợp tồi tệ hơn đấy là server của chúng ta bị down, lúc đấy thì "người ơi chẳng còn lại gì" 😂
  • ......và còn nhiều nữa

K8S được sinh ra từ đó

Với những vấn đề trên thì K8S được sinh ra để giải quyết tất cả chúng.

Theo định nghĩa trên trang chủ của K8S thì: K8S là "container orchestration" - hệ thống điều phối container giúp tự động hoá việc triển khai (deploy), scale và quản lý (manage) các ứng dụng chạy trên nền container.

K8S giúp ta giải quyết tất cả những vấn đề bên trên và còn rấttttttt nhiều nữa, nếu các bạn sau này muốn đi sâu hơn (vọc vạch hoặc theo ngạch Devops) 😃

K8S thì free và open source ngày trước ban đầu được phát triển bởi google nhưng giờ được donate cho tổ chức tên là Cloud Native Computing Foundation - tổ chức chuyên maintain các project chạy trên cloud

Ta có thể tự khởi tạo, chạy 1 K8S cluster nhưng thường thì mình thấy ít ai làm vậy, trừ khi công ty lớn lắm, cần manage nhiều lắm thì mới tự quản lý, còn lại thì dùng luôn các dịch vụ của các cloud cung cấp (GKE, AKS, EKS,...)

K8S và Docker Swarm

Có bạn thắc mắc là nom Docker Swarm hình như cũng giải quyết những vấn đề tương tự rồi mà nhỉ? Sẵn đang dùng Docker rồi thì tiện dùng luôn Docker Swarm, âu cũng là Docker dễ tiếp cận.

Theo những gì mình thấy và tìm hiểu thêm, thì với những app và kiến trúc phức tạp thì K8S làm tốt và phù hợp hơn, trong khi Docker Swarm hướng tới sự đơn giản khi sử dụng.

Những ai đang dùng Kubernetes

Cả thế giới 🤣🤣

.....

Đùa các bạn chút. Nhưng đúng là hiện tại K8S phổ biến và áp đảo thật, gần như nó có mặt khắp mọi nơi, các công ty từ lớn đến bé đều dùng K8S để deploy và quản lý các app của họ vì nó làm rất tốt việc đó.

Phiên bản Enterprise của nó là Openshift cũng được dùng rất nhiều ở các công ty, tập đoàn lớn. Ví dụ ngân hàng chỗ mình làm cũng dùng 100% Openshift

Để bắt đầu với K8S thì cần gì?

Kiến thức về Container là bắt buộc, cụ thể là những kiến thức mình đã viết ở Series học Docker - đương nhiên rồi 😉. K8S sinh ra để quản lý các app container mà.

Và cần có K8S cluster để thực hành, cái này mình sẽ nói thêm ở bài sau nhé

Tổng quan những thứ ta sẽ học ở series này

Vì K8S nó bao gồm ti tỉ thứ, vô biên bạt ngàn, mình sẽ gắng cover càng nhiều càng tốt, nhưng chủ yếu sẽ đi vào những thứ thực tế mà ta hay sử dụng.

Và bởi vì làm việc với K8S cần thực hành rất nhiều, nên mình sẽ đưa ra nhiều ví dụ nhất có thể để chúng ta có cái để vọc nhé.

Liệu rằng có cần học tới tận Kubernetes hay không trong khi không theo nghiệp DevOps?

Câu trả lời là tuỳ vào các bạn có muốn hay không 😂😂

Thực tế là mình thấy học K8S nó cũng hơi nâng cao nếu như các ta chỉ theo nghiệp Frontend, Backend,...không liên quan hẳn đến DevOps.

Vậy nhưng mình thấy những lợi ích nó mang lại thì cựccccc kì nhiều, nếu ta hiểu:

  • tự biết cách deploy và quản lý app
  • tự biết cách check logs, check deployment, auto scale,...
  • kết hợp với CICD để tự động hoá toàn bộ quá trình triển khai app
  • biết cấu hình các thứ ABCXYZ

Biết K8S nó cho mình làm việc độc lập hơn rất là nhiều, gần như mình không phải phụ thuộc vào bên team SRE hỗ trợ phần deploy vì mình tự làm được, từ viết Dockerfile, rồi viết file manifest K8S để deploy,...mặc dù công việc chính của mình là làm Frontend 😄

Vậy nên các bạn tự đặt câu hỏi liệu có muốn học thêm 1 thứ hơi nâng cao, nhưng hay ho như K8S không nhé 😉

Good night

Vèo cái đã nửa đêm 🌙🌙

Mình cố gắng viết bài này ngắn ngắn chút để những bài sau mỗi bài giới thiệu thêm một chút về K8S tới các bạn.

Mong rằng qua đây ta có cái nhìn tổng quát ban đầu về K8S và những thứ nó mang lại, hi vọng đủ ngắn để các bạn đọc được tới đây 😂

Hẹn gặp lại các bạn vào những ngày bài sau và ta cùng nhau vọc K8S nhé 💪💪💪

Bình luận

Bài viết tương tự

- vừa được xem lúc

Phần 1: Giới thiệu về Kubernetes

Kubernetes là gì. Trang chủ: https://kubernetes.io/. Ai cần Kubernetes.

0 0 100

- vừa được xem lúc

Thực hành K8S trên Google Cloud

Kubernetes (K8S) trở nên quá phổ biến ở thời điểm hiện tại, ai cũng nói về nó. Trong bài hôm nay mình sẽ không đi quá nhiều vào các định nghĩa, mà đi thẳng vào thực tế để mọi người dễ hình dung.

0 0 34

- vừa được xem lúc

Kubernetes best practices - Liveness và Readiness Health checks

Mở đầu. Kubernetes cung cấp cho bạn một framework để chạy các hệ phân tán một cách mạnh mẽ.

0 0 49

- vừa được xem lúc

Kubernetes - deployment.yaml explained

Trong bài trước, mình có giới thiệu chạy các câu lệnh K8S bằng Command Line. Để tạo 1 deloyment đơn giản chỉ cần chạy lệnh.

0 0 91

- vừa được xem lúc

Tìm hiểu cơ bản về Kubernetes - K8s (Part 2): Minikube

Lời mở đầu. .

0 0 47

- vừa được xem lúc

ETCD - Bộ não của Kubernetes và cách cài đặt cụm ETCD Cluster (High Availability)

Hello anh em, sau vài ngày nghiên cứu đọc lại liệu cũng như cài cắm thủ công đủ thể loại, với vô số lỗi fail thì mình cũng cài đặt thành công cụm etcd cluster một cách thủ công. Trước giờ chuyên tạo c

0 0 44