Kubernetes-yaml-examples
Namespace
kind: Namespace
apiVersion: v1
metadata:
  name: test
  labels:
    name: test
Deployment
apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx-deployment
  labels:
    app: nginx
spec:
  replicas: 3
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:1.14.2
        ports:
        - containerPort: 80
Secrets
echo -n 'secret value' | base64
echo $SECRET | base64 -d
- [[sealed-secrets]]
 
apiVersion: v1
kind: Secret
metadata:
  name: mysecret
type: Opaque
data:
  username: YWRtaW4=
  password: MWYyZDFlMmU2N2Rm
- Secrets from env files:
 kubectl create secret generic env --from-env-file=.env
envFrom:
- secretRef:
  name: env
Services
- ### Nodeport
	- ```yaml
	  apiVersion: v1
	  kind: Service
	  metadata:
	    name: my-service
	  spec:
	    type: NodePort
	    selector:
	      app.kubernetes.io/name: MyApp
	    ports:
	        # By default and for convenience, the `targetPort` is set to the same value as the `port` field.
	      - port: 80
	        targetPort: 80
	        # Optional field
	        # By default and for convenience, the Kubernetes control plane will allocate a port from a range (default: 30000-32767)
	        nodePort: 30007
	  ```
Ingress
- 
NFS Volumes
 - There are two ways to handle NFS:
- 
Example for NFS Volume:
apiVersion: apps/v1 kind: Deployment metadata: name: example-app labels: app: example-app spec: replicas: 1 selector: matchLabels: app: example-app template: metadata: labels: app: example-app spec: containers: - name: example-app image: busybox:latest command: ["sleep", "3000"] volumeMounts: - mountPath: /persistent-volume name: nfs-volume volumes: - name: nfs-volume nfs: server: "server_ip" path: "/path/to/directory"