Як встановити Minikube на Ubuntu 24.04 | Ubuntu 22.04

Як встановити Minikube на Ubuntu 24.04 | Ubuntu 22.04

 

Ви готові відкрити для себе всю силу Kubernetes? У цьому покроковому посібнику ми покажемо вам, як встановити Minikube на систему Ubuntu Linux, де базовим гіпервізором є Libvirt(KVM) або VirtualBox. Ми почнемо з базового знайомства з Minikube, а потім зануримося в фактичне встановлення Minikube і те, як почати ним користуватися.

Minikube — це інструмент з відкритим вихідним кодом, який був розроблений, щоб дозволити розробникам і системним адміністраторам запускати єдиний кластер Kubernetes на своєму локальному комп’ютері. Minikube запускає кластер kubernetes з одним вузлом локально з невеликим використанням ресурсів. Це ідеальний варіант для тестів розробки та цілей POC.

У двох словах, Minikube пакує та налаштовує віртуальну машину Linux, а потім встановлює в неї Docker та всі компоненти Kubernetes.

Minikube підтримує такі функції Kubernetes, як:

  • DNS
  • NodePorts (Вузлові порти)
  • ConfigMaps і секрети
  • Інформаційні панелі
  • Середовище виконання контейнерів: Docker, CRI-O та контейнерні
  • Увімкнення CNI (контейнерного мережевого інтерфейсу)
  • Попадання
  • PersistentVolumes типу hostPath

Почнемо встановлювати Minikube на Ubuntu Linux.

Встановіть гіпервізор KVM або VirtualBox

Виконайте наступні команди, щоб оновити всі системні пакети до останнього випуску:

sudo apt update && sudo apt upgrade -y

Якщо після оновлення потрібне перезавантаження, то виконайте процес.

[ -f /var/run/reboot-required ] && sudo reboot -f

Завантажте та налаштуйте Minikube на Ubuntu

Вам потрібно завантажити двійковий файл minikube. Я покладу двійковий файл у каталог /usr/local/bin, оскільки він знаходиться всередині $PATH.

wget https://storage.googleapis.com/minikube/releases/latest/minikube-linux-amd64
chmod +x minikube-linux-amd64
sudo mv minikube-linux-amd64 /usr/local/bin/minikube

Підтвердьте встановлену версію

$ minikube version
minikube version: v1.33.1
commit: 5883c09216182566a63dff4c326a6fc9ed2982ff

Нам потрібен kubectl – інструмент командного рядка, який використовується для розгортання та керування програмами на Kubernetes:

curl -LO https://storage.googleapis.com/kubernetes-release/release/`curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt`/bin/linux/amd64/kubectl

Зробіть виконуваний файл kubectl виконуваним.

chmod +x ./kubectl

Перемістіть двійковий файл у ваш PATH:

sudo mv ./kubectl /usr/local/bin/kubectl

Перевірте версію:

$ kubectl version -o json  --client
{
  "clientVersion": {
    "major": "1",
    "minor": "30",
    "gitVersion": "v1.30.2",
    "gitCommit": "39683505b630ff2121012f3c5b16215a1449d5ed",
    "gitTreeState": "clean",
    "buildDate": "2024-06-11T20:29:44Z",
    "goVersion": "go1.22.4",
    "compiler": "gc",
    "platform": "linux/amd64"
  },
  "kustomizeVersion": "v5.0.4-0.20230601165947-6ce0bf390ce3"
}

Запуск minikube на Ubuntu

Тепер, коли компоненти встановлені, можна приступати до minikube. Образ віртуальної машини буде завантажено та налаштовано d для кластера Kubernetes з одним вузлом.

minikube start --driver=kvm2
minikube start --driver=virtualbox

Приклад виведення з команд виконання.

...................................
* Using the kvm2 driver based on user configuration
*   https://minikube.sigs.k8s.io/docs/reference/drivers/none/
* Downloading driver docker-machine-driver-kvm2:
    > docker-machine-driver-kvm2-...:  65 B / 65 B [---------] 100.00% ? p/s 0s
    > docker-machine-driver-kvm2-...:  13.46 MiB / 13.46 MiB  100.00% ? p/s 100
* Downloading VM boot image ...
    > minikube-v1.33.1-amd64.iso....:  65 B / 65 B [---------] 100.00% ? p/s 0s
    > minikube-v1.33.1-amd64.iso:  314.16 MiB / 314.16 MiB  100.00% 37.68 MiB p
* Starting "minikube" primary control-plane node in "minikube" cluster
* Downloading Kubernetes v1.30.0 preload ...
    > preloaded-images-k8s-v18-v1...:  342.90 MiB / 342.90 MiB  100.00% 38.75 M
* Creating kvm2 VM (CPUs=2, Memory=2200MB, Disk=20000MB) ...
* Preparing Kubernetes v1.30.0 on Docker 26.0.2 ...
  - Generating certificates and keys ...
  - Booting up control plane ...
  - Configuring RBAC rules ...
* Configuring bridge CNI (Container Networking Interface) ...
* Verifying Kubernetes components...
  - Using image gcr.io/k8s-minikube/storage-provisioner:v5
* Enabled addons: default-storageclass, storage-provisioner
* Done! kubectl is now configured to use "minikube" cluster and "default" namespace by default

Дочекайтеся завершення завантаження та налаштування, а потім переконайтеся, що все працює нормально.

Щоб встановити драйвер Minikube за замовчуванням, використовуйте:

# VirtualBox
minikube config set driver virtualbox

# KVM
minikube config set driver kvm

Minikube основні операції

Щоб перевірити статус кластера, запустіть:

$ kubectl cluster-info

Kubernetes master is running at https://192.168.39.117:8443
KubeDNS is running at https://192.168.39.117:8443/api/v1/namespaces/kube-system/services/kube-dns:dns/proxy

To further debug and diagnose cluster problems, use 'kubectl cluster-info dump'.

Зауважте, що файл налаштувань Minikube знаходиться в розділі ~/.minikube/machines/minikube/config.json

Щоб переглянути налаштування, використовуйте:

$ kubectl config view
apiVersion: v1
clusters:
- cluster:
    certificate-authority: /root/.minikube/ca.crt
    extensions:
    - extension:
        last-update: Sat, 13 Jul 2024 15:29:47 UTC
        provider: minikube.sigs.k8s.io
        version: v1.33.1
      name: cluster_info
    server: https://192.168.39.249:8443
  name: minikube
contexts:
- context:
    cluster: minikube
    extensions:
    - extension:
        last-update: Sat, 13 Jul 2024 15:29:47 UTC
        provider: minikube.sigs.k8s.io
        version: v1.33.1
      name: context_info
    namespace: default
    user: minikube
  name: minikube
current-context: minikube
kind: Config
preferences: {}
users:
- name: minikube
  user:
    client-certificate: /root/.minikube/profiles/minikube/client.crt
    client-key: /root/.minikube/profiles/minikube/client.key

Щоб перевірити запущені вузли:

$ kubectl get nodes
NAME       STATUS   ROLES           AGE     VERSION
minikube   Ready    control-plane   5m29s   v1.30.0

Доступ до віртуальної машини minikube за допомогою ssh:

$ minikube ssh

                         _             _            
            _         _ ( )           ( )           
  ___ ___  (_)  ___  (_)| |/')  _   _ | |_      __  
/' _ ` _ `\| |/' _ `\| || , <  ( ) ( )| '_`\  /'__`\
| ( ) ( ) || || ( ) || || |\`\ | (_) || |_) )(  ___/
(_) (_) (_)(_)(_) (_)(_)(_) (_)`\___/'(_,__/'`\____)

$ sudo su -

Щоб зупинити запущений локальний кластер kubernetes, запустіть:

$ minikube stop

Щоб видалити локальний кластер kubernetes, використовуйте:

$ minikube delete

Kubernete поставляється з веб-панеллю, яка дозволяє керувати кластером без взаємодії з командою лінія. Додаток інформаційної панелі встановлено та включено за замовчуванням на minikube.

$ minikube addons list
...
|-----------------------------|----------|--------------|--------------------------------|
|         ADDON NAME          | PROFILE  |    STATUS    |           MAINTAINER           |
|-----------------------------|----------|--------------|--------------------------------|
| ambassador                  | minikube | disabled     | 3rd party (Ambassador)         |
| auto-pause                  | minikube | disabled     | minikube                       |
| cloud-spanner               | minikube | disabled     | Google                         |
| csi-hostpath-driver         | minikube | disabled     | Kubernetes                     |
| dashboard                   | minikube | disabled     | Kubernetes                     |
| default-storageclass        | minikube | enabled ✅   | Kubernetes                     |
| efk                         | minikube | disabled     | 3rd party (Elastic)            |
| freshpod                    | minikube | disabled     | Google                         |
| gcp-auth                    | minikube | disabled     | Google                         |
| gvisor                      | minikube | disabled     | minikube                       |
| headlamp                    | minikube | disabled     | 3rd party (kinvolk.io)         |
| helm-tiller                 | minikube | disabled     | 3rd party (Helm)               |
| inaccel                     | minikube | disabled     | 3rd party (InAccel             |
|                             |          |              | [example@infoit.com.ua])            |
| ingress                     | minikube | disabled     | Kubernetes                     |
| ingress-dns                 | minikube | disabled     | minikube                       |
| inspektor-gadget            | minikube | disabled     | 3rd party                      |
|                             |          |              | (inspektor-gadget.io)          |
| istio                       | minikube | disabled     | 3rd party (Istio)              |
| istio-provisioner           | minikube | disabled     | 3rd party (Istio)              |
| kong                        | minikube | disabled     | 3rd party (Kong HQ)            |
| kubeflow                    | minikube | disabled     | 3rd party                      |
| kubevirt                    | minikube | disabled     | 3rd party (KubeVirt)           |
| logviewer                   | minikube | disabled     | 3rd party (unknown)            |
| metallb                     | minikube | disabled     | 3rd party (MetalLB)            |
| metrics-server              | minikube | disabled     | Kubernetes                     |
| nvidia-device-plugin        | minikube | disabled     | 3rd party (NVIDIA)             |
| nvidia-driver-installer     | minikube | disabled     | 3rd party (Nvidia)             |
| nvidia-gpu-device-plugin    | minikube | disabled     | 3rd party (Nvidia)             |
| olm                         | minikube | disabled     | 3rd party (Operator Framework) |
| pod-security-policy         | minikube | disabled     | 3rd party (unknown)            |
| portainer                   | minikube | disabled     | 3rd party (Portainer.io)       |
| registry                    | minikube | disabled     | minikube                       |
| registry-aliases            | minikube | disabled     | 3rd party (unknown)            |
| registry-creds              | minikube | disabled     | 3rd party (UPMC Enterprises)   |
| storage-provisioner         | minikube | enabled ✅   | minikube                       |
| storage-provisioner-gluster | minikube | disabled     | 3rd party (Gluster)            |
| storage-provisioner-rancher | minikube | disabled     | 3rd party (Rancher)            |
| volumesnapshots             | minikube | disabled     | Kubernetes                     |
| yakd                        | minikube | disabled     | 3rd party (marcnuri.com)       |
|-----------------------------|----------|--------------|--------------------------------|

Для включення модуля використовується команда:

minikube addons enable <module>

Приклад:

$ minikube addons enable portainer
! portainer is a 3rd party addon and is not maintained or verified by minikube maintainers, enable at your own risk.
! portainer does not currently have an associated maintainer.
  - Using image docker.io/portainer/portainer-ce:2.15.1
* The 'portainer' addon is enabled

Щоб відкрити веб-переглядач за умовчанням, використовуйте:

$ minikube dashboard

Щоб отримати URL-адресу інформаційної панелі:

$ minikube dashboard --url
http://192.168.39.117:30000

Увійдіть до Kubernetes Dashboard, відкривши URL-адресу у своєму улюбленому браузері.

Прокрутка до верху