kustomize-example | ||
node-server-example | ||
other_infrastructure_resources/Chef_Examples | ||
README.md |
Resources for Kubernetes
Quick overview
-
A Kubernetes cluster consists of Nodes (simialr to servers)
-
Nodes run Pods, which are collections of Docker containers. Containers in a Pod share the same network.
-
The Kubernetes object responsible for launching and maintaining the desired number of pods is called a Deployment.
-
Kubernetes provides objects called a Service so thart Pods to communicate with other Pods. They are tied to Deployments through Selectors and Labels, and they can be exposed to external clients either by exposing a NodePort as a static port on each Kubernetes node or by creating a LoadBalancer object/
-
Kubernetes provides the Secret object for managing sensitive information such as passwords, API keys, and other credentials.
Examples in this repository
- Spin up a node server example.
- Use kustomize to organize and combine YAML templates of your services and deployments.
Tools
Minikube
Minikube implements a local Kubernetes cluster on macOS, Linux, and Windows. You can install it following this instructions.
Kubectl
Kubectl is a command line interface for running commands against Kubernetes clusters. You can install it here.
Pods
Get pods:
kubectl get pods -n <namespace>
Debug pods:
kubectl describe pod <podname>
Get pod's log:
kubectl logs <podname>
Services
Get services:
kubectl get services -n <namespace>
Deployments
Get deployments:
kubectl get deployment -n <namespace>
Secrets
kubectl get secret
Namespaces
kubectl get namespaces
Configmaps
kubectl get configmaps -n <namespace>
Ingress
kubectl get ingress -n <namespace>