Kubernetes шпаргалка
Kubernetes, часто сокращаемый как K8s (где «8» заменяет восемь букв в слове «ubernete»), представляет собой систему с открытым исходным кодом для управления контейнеризированными приложениями на нескольких хостах в облачной платформе. Цель Kubernetes — сделать развертывание контейнеризированных приложений простым и эффективным (мощным). Kubernetes предоставляет механизмы для развертывания приложений, планирования, обновления и обслуживания.
Просмотр информации о ресурсах
Узлы (Nodes)
Имя ресурса: nodes, Сокращение: no
$ kubectl get no # Показать все узлы
$ kubectl get no -o wide # Показать подробную информацию обо всех узлах
$ kubectl describe no # Показать детали узла
$ kubectl get no -o yaml # Показать детали узла в формате YAML
$ kubectl get node --selector=[label_name] # Фильтровать узлы по определенной метке
$ kubectl get nodes -o jsonpath='{.items[*].status.addresses[?(@.type=="ExternalIP")].address}'
# Вывод информации о полях, определенных выражением jsonpath
$ kubectl top node [node_name] # Показать использование узла (CPU/Память/Хранилище)Поды (Pods)
Имя ресурса: pods, Сокращение: po
$ kubectl get po # Показать все поды
$ kubectl get po -o wide
$ kubectl describe po
$ kubectl get po --show-labels # Показать метки подов
$ 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
# Экспорт информации о поде в YAML-файл
$ kubectl get pods --field-selector status.phase=Running
# Фильтрация информации о подах с помощью селекторов полейПространства имен (Namespaces)
Имя ресурса: namespaces, Сокращение: ns
$ kubectl get ns
$ kubectl get ns -o yaml
$ kubectl describe nsРазвертывания (Deployments)
Имя ресурса: deployments, Сокращение: deploy
$ kubectl get deploy
$ kubectl describe deploy
$ kubectl get deploy -o wide
$ kubectl get deploy -o yamlСервисы (Services)
Имя ресурса: services, Сокращение: svc
$ kubectl get svc
$ kubectl describe svc
$ kubectl get svc -o wide
$ kubectl get svc -o yaml
$ kubectl get svc --show-labelsНаборы демонов (DaemonSets)
Имя ресурса: daemonsets, Сокращение: 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 yamlСобытия (Events)
Имя ресурса: events, Сокращение: ev
$ kubectl get events
$ kubectl get events -n kube-system
$ kubectl get events -wЛоги (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.logСервисные аккаунты (Service Accounts)
Имя ресурса: serviceaccounts, Сокращение: sa
$ kubectl get sa
$ kubectl get sa -o yaml
$ kubectl get serviceaccounts default -o yaml >./sa.yaml
$ kubectl replace serviceaccount default -f ./sa.yamlНаборы реплик (ReplicaSets)
Имя ресурса: replicasets, Сокращение: rs
$ kubectl get rs
$ kubectl describe rs
$ kubectl get rs -o wide
$ kubectl get rs -o yamlРоли (Roles)
$ kubectl get roles --all-namespaces
$ kubectl get roles --all-namespaces -o yamlСекреты (Secrets)
$ kubectl get secrets
$ kubectl get secrets --all-namespaces
$ kubectl get secrets -o yamlКарты конфигурации (ConfigMaps)
Имя ресурса: configmaps, Сокращение: cm
$ kubectl get cm
$ kubectl get cm --all-namespaces
$ kubectl get cm --all-namespaces -o yamlИнгрессы (Ingresses)
Имя ресурса: ingresses, Сокращение: ing
$ kubectl get ing
$ kubectl get ing --all-namespacesПостоянные тома (PersistentVolumes)
Имя ресурса: persistentvolumes, Сокращение: pv
$ kubectl get pv
$ kubectl describe pvЗапросы на постоянные тома (PersistentVolumeClaims)
Имя ресурса: persistentvolumeclaims, Сокращение: pvc
$ kubectl get pvc
$ kubectl describe pvcКлассы хранилищ (StorageClasses)
Имя ресурса: storageclasses, Сокращение: sc
$ kubectl get sc
$ kubectl get sc -o yamlНесколько ресурсов
$ kubectl get svc, po
$ kubectl get deploy, no
$ kubectl get all
$ kubectl get all --all-namespacesИзменение атрибутов ресурсов
Тейнты (Taints)
$ kubectl taint [node_name] [taint_name]Метки (Labels)
$ kubectl label [node_name] disktype=ssd
$ kubectl label [pod_name] env=prodВывод из эксплуатации / Ввод в эксплуатацию (Cordon / Uncordon)
$ kubectl cordon [node_name] # Узел на обслуживании (запрет планирования)
$ kubectl uncordon [node_name] # Разрешить планирование на узлеОчистка узла (Draining Nodes)
$ kubectl drain [node_name] # Очистить узелУзлы / Поды
$ kubectl delete node [node_name]
$ kubectl delete pod [pod_name]
$ kubectl edit node [node_name]
$ kubectl edit pod [pod_name]Развертывания / Пространства имен
$ 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
$ kubectl edit ns [ns_name]Сервисы
$ kubectl edit svc [svc_name]
$ kubectl delete svc [svc_name]Наборы демонов
$ kubectl edit ds [ds_name] -n kube-system
$ kubectl delete ds [ds_name]Сервисные аккаунты
$ kubectl edit sa [sa_name]
$ kubectl delete sa [sa_name]Аннотации (Annotations)
$ kubectl annotate po [pod_name] [annotation]
$ kubectl annotate no [node_name]Добавление ресурсов
Создание подов
$ kubectl create -f [name_of_file]
$ kubectl apply -f [name_of_file]
$ kubectl run [pod_name] --image=nginx --restart=Never
$ kubectl run [pod_name] --generator=run-pod/v1 --image=nginx
$ kubectl run [pod_name] --image=nginx --restart=NeverСоздание сервисов
$ kubectl create svc nodeport [svc_name] --tcp=8080:80Создание развертываний
$ kubectl create -f [name_of_file]
$ kubectl apply -f [name_of_file]
$ kubectl create deploy [deploy_name] --image=nginxВзаимодействие с контейнером
$ kubectl run [pod_name] --image=busybox --rm -it --restart=Never -- shВывод YAML-файлов
$ kubectl create deploy [deploy_name] --image=nginx --dry-run -o yaml > deploy.yaml
$ kubectl get po [pod_name] -o yaml --export > pod.yamlПолучение справки
$ kubectl -h
$ kubectl create -h
$ kubectl run -h
$ kubectl explain deploy.specЗапросы
API вызовы
$ kubectl get --raw /apis/metrics.k8s.io/Информация о кластере
$ kubectl config
$ kubectl cluster-info
$ kubectl get componentstatus