![Addon nfs não foi encontrado em nenhum repositório microk8s](https://rvso.com/image/1072876/Addon%20nfs%20n%C3%A3o%20foi%20encontrado%20em%20nenhum%20reposit%C3%B3rio%20microk8s.png)
Eu tenho um cluster microk8s com 3 nós, rodando em multipass no Ubuntu 22.04. Tudo rodando no meu antigo Macbookpro de meados de 2012. (com o Ubuntu, 22.04 eu removi o Macos)
Estou recebendo esta mensagem quando executo o comando:
microk8s enable nfs
Addon nfs was not found in any repository
Instalei o nfs em todas as 3 instâncias multipass.
sudo apt install -y nfs-common
dns habilitado painel habilitado Posso acessar o cluster do meu host ubuntu.
kubectl get node
NAME STATUS ROLES AGE VERSION
worker01 Ready <none> 40m v1.24.8-2+1dda18a15eea38
master Ready <none> 46m v1.24.8-2+1dda18a15eea38
worker02 Ready <none> 42m v1.24.8-2+1dda18a15eea38
os seguintes pods estão em execução
kubectl get po -A
NAMESPACE NAME READY STATUS RESTARTS AGE
kube-system calico-node-hv6sd 1/1 Running 0 84m
kube-system calico-node-wbm9h 1/1 Running 0 82m
kube-system coredns-66bcf65bb8-s7xjx 1/1 Running 0 40m
kube-system calico-node-cwfzt 1/1 Running 1 (60m ago) 84m
kube-system calico-kube-controllers-655d5f4c66-d7q8q 1/1 Running 0 87m
ingress nginx-ingress-microk8s-controller-2fgwk 1/1 Running 0 38m
kube-system metrics-server-5f8f64cb86-p4tcn 1/1 Running 0 36m
kube-system dashboard-metrics-scraper-6b6f796c8d-vp4j5 1/1 Running 0 35m
ingress nginx-ingress-microk8s-controller-7vjgh 1/1 Running 0 38m
ingress nginx-ingress-microk8s-controller-qzwsj 1/1 Running 0 38m
kube-system kubernetes-dashboard-765646474b-s89wj 1/1 Running 0 35m
Execute também
microk8s enable community
A mensagem é sempre a mesma. Addon nfs não foi encontrado em nenhum repositório
ubuntu@master:~$ microk8s enable community
Infer repository core for addon community
Addon core/community is already enabled
ubuntu@master:~$ microk8s enable nfs
Addon nfs was not found in any repository
Responder1
O complemento nfs é bastante novo. Tive o mesmo problema com o microk8s 1.24.0, não fazia parte da lista. Atualizei meus nós para 1.26.0, tive que desabilitar e reativar o complemento da comunidade, e ele apareceu na lista.
Responder2
Primeiro de tudo, acho que não há nfs
módulos no microk8s
. No meu servidor Ubuntu 22.04.1, os módulos disponíveis estão listados abaixo:
$ microk8s status
microk8s is running
high-availability: no
datastore master nodes: 127.0.0.1:19001
datastore standby nodes: none
addons:
enabled:
dashboard # (core) The Kubernetes dashboard
dns # (core) CoreDNS
ha-cluster # (core) Configure high availability on the current node
helm # (core) Helm - the package manager for Kubernetes
helm3 # (core) Helm 3 - the package manager for Kubernetes
ingress # (core) Ingress controller for external access
metrics-server # (core) K8s Metrics Server for API access to service metrics
rbac # (core) Role-Based Access Control for authorisation
disabled:
cert-manager # (core) Cloud native certificate management
community # (core) The community addons repository
gpu # (core) Automatic enablement of Nvidia CUDA
host-access # (core) Allow Pods connecting to Host services smoothly
hostpath-storage # (core) Storage class; allocates storage from host directory
kube-ovn # (core) An advanced network fabric for Kubernetes
mayastor # (core) OpenEBS MayaStor
metallb # (core) Loadbalancer for your Kubernetes cluster
observability # (core) A lightweight observability stack for logs, traces and metrics
prometheus # (core) Prometheus operator for monitoring and logging
registry # (core) Private image registry exposed on localhost:32000
storage # (core) Alias to hostpath-storage add-on, deprecated
Para a implementação do NFS, você precisa ter o servidor NFS configurado e criar um driver de armazenamento no cluster.
Requisitos
Você já deve ter um servidor NFS fora dos clusters, você pode usar os hosts ou gerar outra VM e configurar o servidor NFS com a configuração abaixo:
# Assuming you use Ubuntu VM
# Install the NFS Kernel
sudo apt-get install nfs-kernel-server
# Create a directory to be used for NFS
sudo mkdir -p /srv/nfs
sudo chown nobody:nogroup /srv/nfs
sudo chmod 0777 /srv/nfs
Em seguida, edite o /etc/exports
arquivo. Certifique-se de que os endereços IP de todos os nós do MicroK8s sejam capazes de montar este compartilhamento. Por exemplo, para permitir todos os endereços IP na 10.0.0.0/24
sub-rede:
sudo mv /etc/exports /etc/exports.bak
echo '/srv/nfs 10.0.0.0/24(rw,sync,no_subtree_check)' | sudo tee /etc/exports
Finalmente, reinicie o servidor NFS:
sudo systemctl restart nfs-kernel-server
Ajuste com sua configuração.
Método de instalação em clusters:
- Instale o driver CSI para NFS
Usaremos odriver NFS CSI upstream. Primeiro, implantaremos o provisionador NFS usando o gráfico oficial do Helm.
Habilite o complemento Helm3 (se ainda não estiver habilitado) e adicione o repositório para o driver NFS CSI:
microk8s enable helm3
microk8s helm3 repo add csi-driver-nfs https://raw.githubusercontent.com/kubernetes-csi/csi-driver-nfs/master/charts
microk8s helm3 repo update
Em seguida, instale o gráfico Helm no kube-system
namespace com:
microk8s helm3 install csi-driver-nfs csi-driver-nfs/csi-driver-nfs \
--namespace kube-system \
--set kubeletDir=/var/snap/microk8s/common/var/lib/kubelet
Depois de implantar o gráfico Helm, aguarde o controlador CSI e os pods de nó aparecerem usando o seguinte kubectl
comando…
microk8s kubectl wait pod --selector app.kubernetes.io/name=csi-driver-nfs --for condition=ready --namespace kube-system
… que, uma vez bem-sucedido, produzirá resultados semelhantes a:
pod/csi-nfs-controller-7bd5678cbc-nc6l2 condition met
pod/csi-nfs-node-lsn6n condition met
Neste ponto, você também deve ser capaz de listar os drivers CSI disponíveis em seu cluster Kubernetes…
microk8s kubectl get csidrivers
… e veja nfs.csi.k8s.io na lista:
NAME ATTACHREQUIRED PODINFOONMOUNT STORAGECAPACITY TOKENREQUESTS REQUIRESREPUBLISH MODES AGE
nfs.csi.k8s.io false false false <unset> false Persistent 23h
- Crie um StorageClass para NFS
A seguir, precisaremos criar uma classe de armazenamento Kubernetes que use o nfs.csi.k8s.io
driver CSI. Supondo que você tenha configurado um compartilhamento NFS /srv/nfs
e o endereço do seu servidor NFS seja 10.0.0.1
, crie o seguinte arquivo:
# sc-nfs.yaml
---
apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
name: nfs-csi
provisioner: nfs.csi.k8s.io
parameters:
server: 10.0.0.1
share: /srv/nfs
reclaimPolicy: Delete
volumeBindingMode: Immediate
mountOptions:
- hard
- nfsvers=4.1
Nota: A última linha do YAML acima indica uma versão específica do NFS. Isso deve corresponder à versão do servidor NFS que está sendo usado - se você estiver usando um serviço existente, verifique qual versão ele usa e ajuste de acordo.
Em seguida, aplique-o em seu MicroK8s
cluster com:
microk8s kubectl apply -f - < sc-nfs.yaml
- Crie um novo PVC
A etapa final é criar um novo PersistentVolumeClaim usando a classe de armazenamento nfs-csi. Isto é tão simples quanto especificar storageClassName: nfs-csi
na definição do PVC, por exemplo:
# pvc-nfs.yaml
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: test-pvc
spec:
storageClassName: nfs-csi
accessModes: [ReadWriteOnce]
resources:
requests:
storage: 5Gi
Em seguida, crie o PVC com:
microk8s kubectl apply -f - < pvc-nfs.yaml
Se tudo foi configurado corretamente, você poderá verificar o PVC…
microk8s kubectl describe pvc/test-pvc
… e veja se um volume foi provisionado com sucesso:
Name: test-pvc
Namespace: default
StorageClass: nfs-csi
Status: Bound
Volume: pvc-0d7e0c27-a6d6-4b64-9451-3209f98d6472
Labels: <none>
Annotations: pv.kubernetes.io/bind-completed: yes
pv.kubernetes.io/bound-by-controller: yes
volume.beta.kubernetes.io/storage-provisioner: nfs.csi.k8s.io
volume.kubernetes.io/storage-provisioner: nfs.csi.k8s.io
Finalizers: [kubernetes.io/pvc-protection]
Capacity: 5Gi
Access Modes: RWO
VolumeMode: Filesystem
Used By: <none>
Events: <none>
É isso! Agora você pode usar este PVC para executar cargas de trabalho com estado em seu cluster MicroK8s.
Você só precisa recriar o ponto 3 para criar um novo PVC.