Hoja de referencia de Kubernetes (Cheat Sheet)
Kubernetes, a menudo abreviado como K8s (donde el “8” reemplaza las ocho letras de “ubernete”), es un sistema de código abierto para automatizar el despliegue, el escalado y la gestión de aplicaciones contenedorizadas en múltiples hosts en una plataforma en la nube. El objetivo de Kubernetes es hacer que el despliegue de aplicaciones contenedorizadas sea sencillo y eficiente (potente). Kubernetes proporciona mecanismos para el despliegue de aplicaciones, planificación, actualizaciones και mantenimiento.
Ver información de recursos
Nodos
Nombre del recurso: nodes, Abreviatura: no
$ kubectl get no # Mostrar todos los nodos
$ kubectl get no -o wide # Mostrar más información sobre todos los nodos
$ kubectl describe no # Mostrar detalles del nodo
$ kubectl get no -o yaml # Mostrar detalles del nodo en formato YAML
$ kubectl get node --selector=[label_name] # Filtrar nodos por una etiqueta específica
$ kubectl get nodes -o jsonpath='{.items[*].status.addresses[?(@.type=="ExternalIP")].address}'
# Salida de información de campos definida por la expresión jsonpath
$ kubectl top node [node_name] # Mostrar uso del nodo (CPU/Memoria/Almacenamiento)Pods
Nombre del recurso: pods, Abreviatura: po
$ kubectl get po # Mostrar todos los pods
$ kubectl get po -o wide
$ kubectl describe po
$ kubectl get po --show-labels # Ver etiquetas de los pods
$ 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
# Exportar información del pod a un archivo YAML
$ kubectl get pods --field-selector status.phase=Running
# Filtrar información de pods usando selectores de campoEspacios de nombres (Namespaces)
Nombre del recurso: namespaces, Abreviatura: ns
$ kubectl get ns
$ kubectl get ns -o yaml
$ kubectl describe nsDespliegues (Deployments)
Nombre del recurso: deployments, Abreviatura: deploy
$ kubectl get deploy
$ kubectl describe deploy
$ kubectl get deploy -o wide
$ kubectl get deploy -o yamlServicios (Services)
Nombre del recurso: services, Abreviatura: svc
$ kubectl get svc
$ kubectl describe svc
$ kubectl get svc -o wide
$ kubectl get svc -o yaml
$ kubectl get svc --show-labelsDaemonSets
Nombre del recurso: daemonsets, Abreviatura: 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 yamlEventos (Events)
Nombre del recurso: events, Abreviatura: ev
$ kubectl get events
$ kubectl get events -n kube-system
$ kubectl get events -wRegistros (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.logCuentas de servicio (Service Accounts)
Nombre del recurso: serviceaccounts, Abreviatura: sa
$ kubectl get sa
$ kubectl get sa -o yaml
$ kubectl get serviceaccounts default -o yaml >./sa.yaml
$ kubectl replace serviceaccount default -f ./sa.yamlReplicaSets
Nombre del recurso: replicasets, Abreviatura: rs
$ kubectl get rs
$ kubectl describe rs
$ kubectl get rs -o wide
$ kubectl get rs -o yamlRoles
$ kubectl get roles --all-namespaces
$ kubectl get roles --all-namespaces -o yamlSecretos (Secrets)
$ kubectl get secrets
$ kubectl get secrets --all-namespaces
$ kubectl get secrets -o yamlMapas de configuración (ConfigMaps)
Nombre del recurso: configmaps, Abreviatura: cm
$ kubectl get cm
$ kubectl get cm --all-namespaces
$ kubectl get cm --all-namespaces -o yamlIngressos (Ingresses)
Nombre del recurso: ingresses, Abreviatura: ing
$ kubectl get ing
$ kubectl get ing --all-namespacesVolúmenes Persistentes (PersistentVolumes)
Nombre del recurso: persistentvolumes, Abreviatura: pv
$ kubectl get pv
$ kubectl describe pvReclamaciones de Volúmenes Persistentes (PersistentVolumeClaims)
Nombre del recurso: persistentvolumeclaims, Abreviatura: pvc
$ kubectl get pvc
$ kubectl describe pvcClases de Almacenamiento (StorageClasses)
Nombre del recurso: storageclasses, Abreviatura: sc
$ kubectl get sc
$ kubectl get sc -o yamlMúltiples Recursos
$ kubectl get svc, po
$ kubectl get deploy, no
$ kubectl get all
$ kubectl get all --all-namespacesModificar atributos de recursos
Taints
$ kubectl taint [node_name] [taint_name]Etiquetas (Labels)
$ kubectl label [node_name] disktype=ssd
$ kubectl label [pod_name] env=prodCordon / Uncordon
$ kubectl cordon [node_name] # Marcar nodo como no programable
$ kubectl uncordon [node_name] # Marcar nodo como programableVaciar nodos (Draining Nodes)
$ kubectl drain [node_name] # Vaciar nodoNodos / Pods
$ kubectl delete node [node_name]
$ kubectl delete pod [pod_name]
$ kubectl edit node [node_name]
$ kubectl edit pod [pod_name]Despliegues / Espacios de nombres
$ 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]Servicios
$ kubectl edit svc [svc_name]
$ kubectl delete svc [svc_name]DaemonSets
$ kubectl edit ds [ds_name] -n kube-system
$ kubectl delete ds [ds_name]Cuentas de servicio
$ kubectl edit sa [sa_name]
$ kubectl delete sa [sa_name]Anotaciones (Annotations)
$ kubectl annotate po [pod_name] [annotation]
$ kubectl annotate no [node_name]Añadir recursos
Crear Pods
$ 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=NeverCrear Servicios
$ kubectl create svc nodeport [svc_name] --tcp=8080:80Crear Despliegues
$ kubectl create -f [name_of_file]
$ kubectl apply -f [name_of_file]
$ kubectl create deploy [deploy_name] --image=nginxInteracción con contenedores
$ kubectl run [pod_name] --image=busybox --rm -it --restart=Never -- shGenerar archivos YAML
$ kubectl create deploy [deploy_name] --image=nginx --dry-run -o yaml > deploy.yaml
$ kubectl get po [pod_name] -o yaml --export > pod.yamlObtener ayuda
$ kubectl -h
$ kubectl create -h
$ kubectl run -h
$ kubectl explain deploy.specSolicitudes
Llamadas a la API
$ kubectl get --raw /apis/metrics.k8s.io/Información del cluster
$ kubectl config
$ kubectl cluster-info
$ kubectl get componentstatus