Listă recapitulativă Kubernetes
Kubernetes, prescurtat adesea K8s (unde 8 reprezintă cele opt caractere dintre „K” și „s” din „ubernete”), este un sistem open-source pentru gestionarea aplicațiilor containerizate pe mai multe gazde într-o platformă cloud. Obiectivul Kubernetes este de a face implementarea aplicațiilor containerizate simplă și eficientă (puternică). Kubernetes oferă un mecanism pentru implementarea, planificarea, actualizarea și întreținerea aplicațiilor.
Vizualizarea informațiilor despre resurse
Noduri (Nodes)
Nume resursă: nodes, Prescurtare: no
$ kubectl get no # Afișează informații despre toate nodurile
$ kubectl get no -o wide # Afișează mai multe informații despre toate nodurile
$ kubectl describe no # Afișează detaliile nodului
$ kubectl get no -o yaml # Afișează detaliile nodului în format yaml
$ kubectl get node --selector=[label_name] # Filtrează nodurile după label-uri specificate
$ kubectl get nodes -o jsonpath='{.items[*].status.addresses[?(@.type=="ExternalIP")].address}'
# Afișează câmpurile definite prin expresia jsonpath
$ kubectl top node [node_name] # Afișează consumul nodului (CPU/Memorie/Stocare)Pod-uri (Pods)
Nume resursă: pods, Prescurtare: po
$ kubectl get po # Afișează informații despre toate pod-urile
$ kubectl get po -o wide
$ kubectl describe po
$ kubectl get po --show-labels # Vizualizează label-urile pod-urilor
$ kubectl get po -l app=nginx
$ kubectl get po -o yaml
$ kubectl get pod [pod_name] -o yaml --export
$ kubectl get pod [pod_name] -o yaml --export > nameoffile.yaml
# Exportă informațiile pod-ului într-un fișier yaml
$ kubectl get pods --field-selector status.phase=Running
# Utilizează un selector de câmpuri pentru a filtra informațiile pod-urilorSpații de nume (Namespaces)
Nume resursă: namespaces, Prescurtare: ns
$ kubectl get ns
$ kubectl get ns -o yaml
$ kubectl describe nsDeployments
Nume resursă: deployments, Prescurtare: deploy
$ kubectl get deploy
$ kubectl describe deploy
$ kubectl get deploy -o wide
$ kubectl get deploy -o yamlServicii (Services)
Nume resursă: services, Prescurtare: svc
$ kubectl get svc
$ kubectl describe svc
$ kubectl get svc -o wide
$ kubectl get svc -o yaml
$ kubectl get svc --show-labelsDaemonSets
Nume resursă: daemonsets, Prescurtare: ds
$ kubectl get ds
$ kubectl describe ds --all-namespaces
$ kubectl describe ds [daemonset_name] -n [namespace_name]
$ kubectl get ds [ds_name] -n [ns_name] -o yamlEvenimente (Events)
Nume resursă: events, Prescurtare: ev
$ kubectl get events
$ kubectl get events -n kube-system
$ kubectl get events -wLog-uri (Logs)
$ kubectl logs [pod_name]
$ kubectl logs --since=1h [pod_name]
$ kubectl logs --tail=20 [pod_name]
$ kubectl logs -f -c [container_name] [pod_name]
$ kubectl logs [pod_name] > pod.logConturi de serviciu (Service Accounts)
Nume resursă: serviceaccounts, Prescurtare: sa
$ kubectl get sa
$ kubectl get sa -o yaml
$ kubectl get serviceaccounts default -o yaml >./sa.yaml
$ kubectl replace serviceaccount default -f ./sa.yamlReplicaSets
Nume resursă: replicasets, Prescurtare: rs
$ kubectl get rs
$ kubectl describe rs
$ kubectl get rs -o wide
$ kubectl get rs -o yamlRoluri (Roles)
$ kubectl get roles --all-namespaces
$ kubectl get roles --all-namespaces -o yamlSecrete (Secrets)
$ kubectl get secrets
$ kubectl get secrets --all-namespaces
$ kubectl get secrets -o yamlConfigMaps
Nume resursă: configmaps, Prescurtare: cm
$ kubectl get cm
$ kubectl get cm --all-namespaces
$ kubectl get cm --all-namespaces -o yamlIngress (Ingresses)
Nume resursă: ingresses, Prescurtare: ing
$ kubectl get ing
$ kubectl get ing --all-namespacesVolume persistente (Persistent Volumes)
Nume resursă: persistentvolumes, Prescurtare: pv
$ kubectl get pv
$ kubectl describe pvCereri de volume persistente (Persistent Volume Claims)
Nume resursă: persistentvolumeclaims, Prescurtare: pvc
$ kubectl get pvc
$ kubectl describe pvcClase de stocare (Storage Classes)
Nume resursă: storageclasses, Prescurtare: sc
$ kubectl get sc
$ kubectl get sc -o yamlResurse multiple
$ kubectl get svc, po
$ kubectl get deploy, no
$ kubectl get all
$ kubectl get all --all-namespacesModificarea atributelor resurselor
Taints
$ kubectl taint [node_name] [taint_name]Etichete (Labels)
$ kubectl label [node_name] disktype=ssd
$ kubectl label [pod_name] env=prodMentenanță/Programabil (Cordon / Uncordon)
$ kubectl cordon [node_name] # Mentenanță nod (nescheduling)
$ kubectl uncordon [node_name] # Nod programabilGolire nod (Drain)
$ kubectl drain [node_name] # Golire nodNoduri / Pod-uri
$ kubectl delete node [node_name]
$ kubectl delete pod [pod_name]
$ kubectl edit node [node_name]
$ kubectl edit pod [pod_name]Deployments / Namespaces
$ kubectl edit deploy [deploy_name]
$ kubectl delete deploy [deploy_name]
$ kubectl expose deploy [deploy_name] --port=80 --type=NodePort
$ kubectl scale deploy [deploy_name] --replicas=5
$ kubectl delete ns [ns_name]
$ kubectl edit ns [ns_name]Servicii
$ kubectl edit svc [svc_name]
$ kubectl delete svc [svc_name]DaemonSets
$ kubectl edit ds [ds_name] -n kube-system
$ kubectl delete ds [ds_name]Conturi de serviciu
$ kubectl edit sa [sa_name]
$ kubectl delete sa [sa_name]Adnotări (Annotations)
$ kubectl annotate po [pod_name] [annotation]
$ kubectl annotate no [node_name] [annotation]Adăugarea de resurse
Crearea de pod-uri
$ kubectl create -f [name_of_file]
$ kubectl apply -f [name_of_file]
$ kubectl run [pod_name] --image=nginx --restart=NeverCrearea de servicii
$ kubectl create svc nodeport [svc_name] --tcp=8080:80Crearea de aplicații fără stare (Deployments)
$ kubectl create -f [name_of_file]
$ kubectl apply -f [name_of_file]
$ kubectl create deploy [deploy_name] --image=nginxInteracțiune cu containerul
$ kubectl run [pod_name] --image=busybox --rm -it --restart=Never -- shExport fișier YAML
$ kubectl create deploy [deploy_name] --image=nginx --dry-run -o yaml > deploy.yaml
$ kubectl get po [pod_name] -o yaml --export > pod.yamlAjutor
$ kubectl -h
$ kubectl create -h
$ kubectl run -h
$ kubectl explain deploy.specCereri (Requests)
Apeluri API
$ kubectl get --raw /apis/metrics.k8s.io/Informații cluster
$ kubectl config
$ kubectl cluster-info
$ kubectl get componentstatus