9.5 KiB
Das Kubernetis unter windows WSL:
Idee: ich würde gerne versuchen mein windows so zu konfigurieren das ich den verschiedenen spaces meines kubectls ein locales cluster und einmal das desy dchace rencher cluster habe. dafür würde ich gerne einzelene hosts durch WSL emuliern... Erkenntnis es funktioniert nicht (ohne weiteres)
Einrichtung unserer Tools:
Zu diesem Tutorial: Ich habe c.a 10 jahre linux nutzer Erfahrung und bin mit vielen geflogenheiten unter windows nicht vertraut. Daher werde ich hier auch vieleicht einige erklärungen dalegen die ich hier gelernt habe in den seitnotizen / zitaten.
in diesem Tutorial werde ich dalegen wiso ich bestimmte dinge getan habe, und wiso diese notwendig waren.
Das tutorial wird sich auf 3 teile beschrenken Systemconfiguratin Kübernetis im Allgemeninen und das Ziel ein Helm Chart für Graphana zu erstellen.
Einrichtung WSL: (Instanzen)
erste schritte:
- installing WSL
in der cmd :
wsl --install
- schritt
Ubuntu WSL aus dem Software Store holen ... Debian WSL aus dem Software Store Holen ...
Der Mikrosoft store ist ein showroom kein paket mannager, Daher muss die installierte software extern verwaltet und Aktualisiert werden.
- WSL konfigurieren:
Ändern des Hostnamens folge für ubuntu dem tuturial , das ist gut denn wsl macht dinge anders als sytemd es vorsieht. https://medium.com/@AnupamMajhi/change-ubuntu-hostname-running-on-wsl-7122b83fd6ed
dieses Tutorial funktioniert nur für ubuntu, das Debian WSL ist anders gebaut Die standard Systemd Tools für die hostnameanzeige funkioniern halb im debian container (die verenderungen werden nicht persistent übernommen) und ganicht im ubutu container
Installieren von HSTR https://github.com/dvorka/hstr/blob/master/INSTALLATION.md#ubuntu
Konfigurieren der Bashrc mitl hstr (Jeder hat hier seine eigene präferenz HSTR ist ein sehr konfortables tool um die bashrc zu nutzen)
einrichten notwendiger alias funkttionen, (es ist ratsam am ende der konfig ein cfetch oder neofetch einzutragen damit man beim login in die bash schell erkennen kann in welchem wsl man ist. )
normale cli systhem tools wie htop müssen nicht instlliert werden, da sie nicht unbedingt zutreffend auf die hardware gemappt werden derzeit kann man das was htop liefert mit top und free abdecken um alle implimentierten features weitgehend abzudeken. (htop hat noch einige vorteile für die darstellung siehe htop config, jedoch kommt man in unserm usecase weniger damit in berührung)
Installieren standard Software
sudo apt update; sudo apt upgrade -y; sudo apt autoremove; sudo apt install vim, neovim, neofetch
tools können nach vorliebe variirt werden.
als nächstes müssen wir podman Installieren
Docker erkennt das wir uns in einem WSL Befinden und Möchte uns lieber Docker for windows ans hertz legen.
sudo apt -y install podman
now enable podman
sudo systemctl start podman
sudo systemctl enable podman
you can inform yourself if it worked by the status option of systemctl
now you can logout and test podman mit podman -v
this are the tools you need for the minicube installation
sudo apt install conntrack coreutils curl wget apt-transport-https
Downlod the installer
curl -LO https://storage.googleapis.com/minikube/releases/latest/minikube-linux-amd64
install minikube
sudo install minikube-linux-amd64 /usr/local/bin/minikube
type ** minikube version** to test minikube.
start Minikube
you can do the following step as root
sudo minikube start --force
das das minicube schon einer vm läuft mag minicube nicht so gerne das forcen führt dazu das das trotzdem started.
minikube status
now you can install kubectl follow this official guidlines. https://kubernetes.io/docs/tasks/tools/install-kubectl-linux/#install-using-native-package-management
you want to use the cluster from external therefore we have to add ouer user to the sudoers group
sudo usermod -a -G $user
then you have to add your minicube config to run as non root
minikube config set rootless true
we now bend the ip to 0.0.0.0 therefore we use the minikube option --listen-address='0.0.0.0'
This is a potential securaty risc but it shuld allow us to acsess the ip of wsl system .
(and it dont works therefore i shuld dig into that difrently it dont work in userspace run it as root dos the trick sudo minikube start --force)
Based on this tutorills https://medium.com/@areesmoon/installing-minikube-on-ubuntu-20-04-lts-focal-fossa-b10fad9d0511 https://medium.com/@redswitches/how-to-install-podman-on-ubuntu-20-04-and-22-04-81592ef0e3d1 https://minikube.sigs.k8s.io/docs/start/?arch=%2Flinux%2Fx86-64%2Fstable%2Fdebian+package and some more googleling
ggf die Bash rc weiter anpassen.
Einrichtung Windows als Client kubectl client
wir wollen unter windows die beiden kubernetes instanzen erhalten. dafür giebt es 2 essenzielle tools
Kubectl und helm. Kubectl ist ein wichtiges tool um ein kubernetis cluster zu managen, Pods die aus ein oder mehreren kontainern bestehn können zu starten ud zu stoppen, die Pods zu konfiguriern mit duch deployments, die zu ein ander schnittstellen bekommen zum beispile über services und konfig maps.
diese konfigurationen werden durch helm chart getemplated sodass einfachere kube konfiguration möglich werden. Helm chart verwaltet viele konfigurationen für kubernetis , wie ein paketmannager wie apt. oder später winget.
Einrichtung von kubectl unter windows.
windows terminals sind anders als wir das aus der linux welt kennen, unm das zusammenzufassen: windows hat eine CMD, eine Powershell und eine Powerschell ISE, All diese haben ihre eigenen eigenheiten, wir werden in diesem tutorial die Powershell verwenden.
ihre powershell läuft in einem terminal emulator, normales control +shift +c und control+shift+v funktionirt nicht wenn sie das nerft installieren sie sich Alacritty https://github.com/alacritty/alacritty damit fühlt sich der kram dann ein wenig mehr wie ein standard terminal emulator an. you would also get in touch with msys2 its allso a good oportonity to do linux stuff un windows but its more pain theen wsl in some cases it adds their own cli , you will got in touch if you install git for windows xD
erste installation von Kubernetes kubectl
winget install -e --id Kubernetes.kubectl
nun müssen sie die konfiguration ihres kubernetisclusters in das .kube in ihrem nutzer direktory legen. hierfür müssen sie den ordner erstellen und das file was sie in dem ranshers ihrer kübernetis cluster erhalten in das direktory kopieren mit dem namen config.
windows toolig also gui stuff ist seltsam teilweise endstehen ordnernamen mit seltsamen zeichen darin am sichersten genen sie wenn sie das mit den standard unix bordmitteln machen. mkdir ls touch (diese funktioniern in der Powershell cmd ist teilweise anders ...)
in der cubeconfig fügen sie am besten mit die zeile
namespace: graphana
set a default namespace read more about rbac :)
diese zeile setzt den default namespace in dem kontext
in der yaml sektion context: unter contexts: hinzu:
Es giebt keinen unterschied zwischn .yml und .yaml files es giebt wohl ältere systeme die keine 4 zeichen dateisuffix vertragen.
weitere cluster configuration würden so auch hier eingefügt (contexts)
im anshluss bitte Helm Chat installieren das sollte die konfiguration von kubectl verwenden.
winget install Helm.Helm
Based on: https://helm.sh/docs/intro/install/ https://kubernetes.io/docs/tasks/tools/install-kubectl-windows/ many other futer resouces
side info we have DSM too, with winget you go in the rigth direction ^^
now you can try to get recoures from kubernetis if your rights are not enough like what you are willing to do you now have two options, find a way around or grant this privilages ... i was into the first aproge caus we only have to grant privilages for nesseserry things right ... therrefore we shuld change a bit
Use full commands
kubectl get pods kubectl get all
many things you normaly do in the cli you can now do by hand :)
we have to add reposetorys that we can use helm carts for graphana and phrometeus
helm repo add grafana https://grafana.github.io/helm-charts helm repo add prometheus-community https://prometheus-community.github.io/helm-charts
than you want to know if enythink worked
helm repo list
now you shuld see at least two repos :)
grafana and prometheus-community
than you can giv the following commands
helm install monitoring-prometheus prometheus-community/prometheus -f .\prometheus.yaml helm install my-grafana grafana/grafana -f grafanaconf.yaml
now we have two sporned up configs ... the promometeus and graphanaconf are based on the original valuses files with changed settings
the grphana is changed that it can run with out the right to modyfing the namespace its the same fpr prometheus , the same is for the prometeus char. prometeus has an option to place on any node a automatic collector for metricis , I disabled it for leake of pemissions
you have now conect both sevices maualy. this could be possibly solfed with a helmcaht that wraps other charts.
helm upgradel my-grafana grafana/grafana -f grafanaconf.yaml
with the related upgrade kommands you can upgrade the chart by edding the config
https://grafana.com/docs/grafana/latest/setup-grafana/installation/helm/ https://github.com/prometheus-community/helm-charts