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

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

0 0 35

Người đăng: Vương Minh Thái

Theo Viblo Asia

Lời mở đầu

  • Xin chào các bạn, và sau khoảng 10 tháng "ấp ủ" thì giờ phần 2 của series đã quay trở lại với các bạn rồi đây (thực sự xin lỗi các bạn vì om series này lâu đến vậy ????). Với bài viết đầu tiên, chúng ta đã cùng nhau tìm hiểu một số khái niệm cơ bạn về K8s như là cluster/nodes/pods, ..., và sang đến bài viết này chúng ta sẽ tiếp tục tìm hiểu về cách setup K8s trên môi trường "local" để các bạn có thể tự học tập và nghiên cứu nhé, và công cụ chúng ta sử dụng ở đây là Minikube.

Nội dung

  • Tìm hiều sơ quá 1 chút thì Minikube là một bộ cài đăt K8s bằng cách tạo ra một máy ảo trên máy tính của bạn và triển khai một single-node Kubernetes cluster(cluster mà chỉ có 1 node).

  • Minikube có thể chạy trên đa nên tảng Linux, macOS, Windows nên bạn có thể dễ dàng cài đặt và sử dụng mà không gặp bất cứ khó khăn nào về về platform.

Cài đặt Minikube

1. Yêu cầu cấu hình:

  • Tối thiểu 2 CPUs

  • 2GB of free memory

  • Dung lượng ở cứng trống 20GB.

  • Cài đặt một trong những driver sau để quản lý máy ảo: Docker, Hyperkit, Hyper-V, KVM, Parallels, Podman, VirtualBox hoặc VMWare.

    => hãy lựa chọn driver phù hợp với OS mà bạn đang sử dụng nhé, chi tiết các driver ứng với từng OS các bạn có thể tham khảo ở đây. Trong bài viết này, mình sẽ sử dụng OS Linux và driver Docker.

  • Cuối cùng và không kém phần quan trọng, đó là kết nối Internet ??

2. Cài đặt minikube:

  • Sau khi đã đảm bảo được đầy đủ những yêu cầu phía trên, bạn có thể truy cập vào đây để tìm phiên bản phù hợp vs OS mà bạn đang sử dụng (có cả Linux/macOS/Window).

  • Để kiểm tra rằng việc cài đặt đã thành công, bạn có thể sử dụng câu lệnh minikube version, như máy mình là đang cài đặt phiên bản mới nhất hiện tại 1.22 (đã được release vào ngày 07/07/2021):

  • Sau khi đã cài đặt xong, mở cửa sổ CLI và gõ lệnh minikube start hoặc minikube start --driver=docker để khởi động minikube (nhớ là thay câu lệnh bằng driver tương ứng của bạn nhé). Và đây là thành quả:

3. Các câu lệnh quản lý cluster thường dùng

  • Màn quản lý dashboard của minikube:

    minikube dashboard
    

    Sau khi chạy lệnh thì trình duyệt sẽ tự động mở tab dashboard như hình bên dưới:

  • Tạm dừng (không ảnh hưởng đến các ứng dụng đang được deploy):

    minikube pause [flags]
    minikube unpause [flags] # ngược với pause  #list flags
    # -A: pause/unpause tất cả namespaces
    # -m: pause/unpause theo namespaces chỉ định
    

  • Start/stop cluster:

    minikube start
    minikube stop
    
  • Thay đổi cấu hình, ví dụ như memory (bạn cần restart lại để có thể sử dụng được config này)

    minikube config set memory XXXXX 

    Ngoài cấu hình memory, bạn có thể set cấu hình một số thông tin khác như là driver, cpus, disk-size, ...

  • Xóa tất cả các cluster:

    minikube delete --all
    

4. Thử deploy ứng dụng

  • Đầu tiên bạn cần tạo một deployment và config port cho nó:

    minikube kubectl -- create deployment hello-minikube --image=k8s.gcr.io/echoserver:1.4
    minikube kubectl -- expose deployment hello-minikube --type=NodePort --port=XXXX
    

    Sau khi chạy 2 câu lệnh trên, để kiểm tra tình trạng của deployment thì phải chạy câu lệnh minikube kubectl get services. Ở đây bạn có thể thấy một số thông tin như tên/phân loại/IP/Port/Thời gian khởi tạo của deployment.

    Và để chạy service lên thì bạn sẽ cần chạy câu lệnh minikube service hello-minikube

5. Tạo service để LoadBalancer

  • Cũng tương tự như phía trên, bạn sẽ phải tạo thêm 1 deployment có phân loại là LoadBalancer

    minikube kubectl -- create deployment hello-minikube-balance --image=k8s.gcr.io/echoserver:1.4
    minikube kubectl -- expose deployment hello-minikube-balance --type=LoadBalancer --port=XXXX #chú ý type ở đây là LoadBalance chứ ko phải NodePort như ở trên nhé 
    
  • Sau đó kiểm tra minikube kubectl get services sẽ thấy 1 deployment hello-minikube loại NodePort đã khởi tạo ở phần 4 và 1 deployment hello-minikube-balance loại LoadBalancer vừa tạo xong.

  • Sau khi đã tạo một LoadBalance deployment như hình bên trên, mở một cửa sổ cmd mới và bạn cần chạy câu lệnh minikube tunnel để truy cập vào LoadBalance deployment thông qua http://EXTERNAL-IP:PORT trên trình duyệt.

Tổng kết

  • Trong phạm vi bài viết này, mình đã giới thiệu cho các bạn về minikube trong K8s, tất nhiên là chỉ mới dừng lại ở mức cài đặt và nhưngx thao tác cơ bản thôi. Hy vọng là những kiến thức này sẽ giúp ích cho các bạn đang tìm hiểu, nghiên cứu về chủ đề này. Nếu có bất cứ thắc mắc hoặc phản hồi gì về nội dung cũng như cách trình bày của bài viết, hãy comment góp ý cho mình nhé, mình sẽ cố gắng tiếp thu và giải đáp thắc mắc của các bạn.
  • Và cũng rất xin lỗi các bạn về việc ra bài chậm trễ này, gần đây mình khá bận và không có nhiều thời gian để có thể research và viết tiếp series này, mong các bạn có thể thông cảm và tiếp tục ủng hộ những bài viết của mình.

Tài liệu tham khảo

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 80

- 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 19

- 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 35

- 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 76

- 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 31

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

HPA là gì? Auto scaling pod bằng HPA và KEDA

Auto Scaling Pod là gì. Auto Scaling để làm gì.

0 0 43