Як встановити 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 з драйвером KVM
minikube start --driver=kvm2
- З драйвером VirtualBox
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-адресу у своєму улюбленому браузері.