lab:stack_of_nucs:demonstrate_app_on_k8s
Differences
This shows you the differences between two versions of the page.
Next revision | Previous revision | ||
lab:stack_of_nucs:demonstrate_app_on_k8s [2023/05/01 19:38] – created user | lab:stack_of_nucs:demonstrate_app_on_k8s [2024/05/06 02:12] (current) – removed user | ||
---|---|---|---|
Line 1: | Line 1: | ||
- | ====== Demonstrate App on k8s ====== | ||
- | In our previous step we [[Ansible Playbook - install_kubernetes|installed Kubernetes]] (k8s) on our [[start|Stack of NUCs]]. | ||
- | Now we are going to install a web app and expose it to our internal network. | ||
- | |||
- | Purpose: | ||
- | * Demonstrate a running a web application on Kubernetes | ||
- | |||
- | References | ||
- | * [[https:// | ||
- | * [[https:// | ||
- | * [[https:// | ||
- | * [[https:// | ||
- | |||
- | ====== Step 1 - Connect to the Kubernetes Master node ====== | ||
- | From [[NUC 1]], log in to the Ansible control node, [[NUC 2]], then log in to the Kubernetes control node. | ||
- | |||
- | ====== Step 2 - Deploy a Distribution ====== | ||
- | - Create the YAML file to create the distribution | ||
- | * <file yaml speedtester-deployment.yml> | ||
- | apiVersion: apps/v1 | ||
- | kind: Deployment | ||
- | metadata: | ||
- | name: speedtester | ||
- | labels: | ||
- | run: speedtester | ||
- | namespace: default | ||
- | spec: | ||
- | selector: | ||
- | matchLabels: | ||
- | run: speedtester | ||
- | replicas: 2 | ||
- | template: | ||
- | metadata: | ||
- | labels: | ||
- | run: speedtester | ||
- | spec: | ||
- | containers: | ||
- | - name: speedtester | ||
- | image: docker.io/ | ||
- | livenessProbe: | ||
- | httpGet: | ||
- | path: / | ||
- | port: 80 | ||
- | initialDelaySeconds: | ||
- | periodSeconds: | ||
- | </ | ||
- | - Apply the definition deployment | ||
- | * '' | ||
- | - View distribution information | ||
- | * '' | ||
- | * '' | ||
- | * '' | ||
- | - Increase number of replicas | ||
- | * Edit the file speedtester-deployment.yaml to set the number of replicas to the number of Kubernetes worker nodes you have | ||
- | * '' | ||
- | * '' | ||
- | * '' | ||
- | * '' | ||
- | * '' | ||
- | |||
- | ====== Step 3 - Create a Service ====== | ||
- | - Create a service | ||
- | - Using expose | ||
- | * <code bash> | ||
- | * Removing it | ||
- | * <code bash> | ||
- | kubctl get svc | ||
- | kubecgtl delete svc speedtester-service | ||
- | </ | ||
- | - Using a manifest | ||
- | * <file yaml speedtester-service.yml> | ||
- | apiVersion: v1 | ||
- | kind: Service | ||
- | metadata: | ||
- | name: speedtester-service | ||
- | spec: | ||
- | selector: | ||
- | run: speedtester | ||
- | type: NodePort | ||
- | ports: | ||
- | - protocol: TCP | ||
- | port: 8080 | ||
- | targetPort: 80 | ||
- | nodePort: 30080 | ||
- | </ | ||
- | * '' | ||
- | - '' | ||
- | - '' | ||
- | ====== Step 4 - Testing Access ====== | ||
- | Point your web browser on [[stack - nuc 1 | NUC 1]] to the IP address of any node and the port we selected, port 300080 | ||
- | |||
- | '' | ||
- | |||
- | ====== Next Step ====== | ||
- | Congratulations, | ||
- | |||
- | ====== Optional ====== | ||
- | ===== Managing Kubernetes using Ansible ===== | ||
- | Ansible can be used for managing Kubernetes. | ||
- | |||
- | [[https:// | ||
- | |||
- | Run from the Ansible control node, NUC 2, in ''/ | ||
- | |||
- | Install python module kubernetes on all nodes | ||
- | |||
- | <file yaml install-python-kubernetes.yml> | ||
- | --- | ||
- | - hosts: all | ||
- | become: true | ||
- | tasks: | ||
- | - name: Install pip | ||
- | apt: | ||
- | name: python-pip | ||
- | - name: Copy kube-config | ||
- | copy: | ||
- | src: / | ||
- | dest | ||
- | remote_src: true | ||
- | - name: Install Kubernetes python package | ||
- | ansible.builtin.pip: | ||
- | name: kubernetes | ||
- | </ | ||
- | |||
- | ==== Creating Namespaces ==== | ||
- | This an example use case from the documentation. | ||
- | |||
- | <file yaml namespace.yml> | ||
- | --- | ||
- | - hosts: master | ||
- | become_user: | ||
- | tasks: | ||
- | - name: Create namespace | ||
- | k8s: | ||
- | name: my-namespace | ||
- | api_version: | ||
- | kind: Namespace | ||
- | state: present | ||
- | </ | ||
- | |||
- | '' | ||
- | |||
- | ==== Deploy with Ansible ==== | ||
- | This section uses the standard set out at [[https:// | ||
- | |||
- | Note the alternative approach at [[https:// | ||
- | |||
- | Example standard deployment file: | ||
- | |||
- | <file yaml> | ||
- | apiVersion: apps/v1 | ||
- | kind: Deployment | ||
- | metadata: | ||
- | name: speedtester | ||
- | labels: | ||
- | run: speedtester | ||
- | spec: | ||
- | selector: | ||
- | matchLabels: | ||
- | run: speedtester | ||
- | replicas: 2 | ||
- | template: | ||
- | metadata: | ||
- | labels: | ||
- | run: speedtester | ||
- | spec: | ||
- | containers: | ||
- | - name: speedtester | ||
- | image: docker.io/ | ||
- | livenessProbe: | ||
- | httpGet: | ||
- | path: / | ||
- | port: 80 | ||
- | initialDelaySeconds: | ||
- | periodSeconds: | ||
- | </ | ||
- | |||
- | Now we move that YAML into a definition element in your Ansible playbook: | ||
- | |||
- | <file yaml ansible-deployment.yml> | ||
- | --- | ||
- | - hosts: master | ||
- | become_user: | ||
- | collections: | ||
- | - kubernetes.core | ||
- | tasks: | ||
- | - name: Deploy speedtester2 | ||
- | k8s: | ||
- | state: present | ||
- | definition: | ||
- | api_version: | ||
- | kind: Deployment | ||
- | metadata: | ||
- | name: speedtester2 | ||
- | labels: | ||
- | run: speedtester2 | ||
- | spec: | ||
- | selector: | ||
- | matchLabels: | ||
- | run: speedtester2 | ||
- | replicas: 2 | ||
- | template: | ||
- | metadata: | ||
- | labels: | ||
- | run: speedtester2 | ||
- | spec: | ||
- | containers: | ||
- | - name: speedtester2 | ||
- | image: docker.io/ | ||
- | livenessProbe: | ||
- | httpGet: | ||
- | path: / | ||
- | port: 80 | ||
- | initialDelaySeconds: | ||
- | periodSeconds: | ||
- | </ | ||
- | |||
- | '' | ||
- | |||
- | '' | ||
- | |||
- | ===== Chaos Testing ===== | ||
- | Chaos engineering exercises the resiliency of a service by means of randomly or continually interrupting service. | ||
- | |||
- | Proper chaos testing: | ||
- | |||
- | Some small scale chase testing is outlined below. | ||
- | |||
- | ==== Kill Pods ==== | ||
- | You can watch what's happening a couple of ways: | ||
- | * '' | ||
- | * '' | ||
- | |||
- | Killing pods: | ||
- | * watch pods terminating and creating | ||
- | Rebooting nodes: | ||
- | * worker nodes show status unknown on pods, then return to running | ||
- | * once in a while the random selection hits the master node | ||
- | * watch to see what happens then | ||
- | |||
- | === Literally kill the first pod in the list === | ||
- | <code bash> | ||
- | kubectl delete pod $(kubectl get pods -l run=speedtester -o jsonpath=' | ||
- | </ | ||
- | |||
- | === Forever loop to keep killing the first pod on the list === | ||
- | <code bash> | ||
- | while true; do | ||
- | kubectl delete pod $(kubectl get pods -l run=speedtester -o jsonpath=' | ||
- | done | ||
- | </ | ||
- | |||
- | === Kill all the current pods === | ||
- | This is slow because the loop structure is sequential. | ||
- | |||
- | '' | ||
- | |||
- | <file yaml deletepod.yml> | ||
- | --- | ||
- | - name: Delete current pods matching speedtester | ||
- | hosts: master | ||
- | become: true | ||
- | become_user: | ||
- | vars: | ||
- | pod_filter: | ||
- | - speedtester # beginning of the pod name | ||
- | gather_facts: | ||
- | tasks: | ||
- | - name: Get a list of all pods from the namespace | ||
- | command: kubectl get pods --no-headers -o custom-columns=": | ||
- | register: pod_list | ||
- | - name: Print pod names | ||
- | debug: | ||
- | msg: "{{ item }}" | ||
- | loop: "{{ pod_list.stdout_lines }}" | ||
- | when: item is match(pod_filter|join(' | ||
- | - name: Delete matching pods | ||
- | command: kubectl delete pod "{{ item }}" | ||
- | loop: "{{ pod_list.stdout_lines }}" | ||
- | when: item is match(pod_filter|join(' | ||
- | </ | ||
- | |||
- | Using async we can limit the waiting to see if the command returns. | ||
- | |||
- | '' | ||
- | |||
- | <file yaml deletepod-async.yml> | ||
- | --- | ||
- | - name: Delete current pods matching speedtester | ||
- | hosts: master | ||
- | become: true | ||
- | become_user: | ||
- | vars: | ||
- | pod_filter: | ||
- | - speedtester # beginning of the pod name | ||
- | gather_facts: | ||
- | tasks: | ||
- | - name: Get a list of all pods from the namespace | ||
- | command: kubectl get pods --no-headers -o custom-columns=": | ||
- | register: pod_list | ||
- | - name: Print pod names | ||
- | debug: | ||
- | msg: "{{ item }}" | ||
- | loop: "{{ pod_list.stdout_lines }}" | ||
- | when: item is match(pod_filter|join(' | ||
- | - name: Delete matching pods | ||
- | command: kubectl delete pod "{{ item }}" | ||
- | async: 5 # timeout in seconds | ||
- | poll: 1 # poll every second | ||
- | loop: "{{ pod_list.stdout_lines }}" | ||
- | when: item is match(pod_filter|join(' | ||
- | </ | ||
- | |||
- | ==== Crash Pods ==== | ||
- | '' | ||
- | |||
- | <file yaml killpod-webservice.yml> | ||
- | --- | ||
- | - name: Crash current pods matching speedtester | ||
- | hosts: master | ||
- | become: true | ||
- | become_user: | ||
- | vars: | ||
- | pod_filter: | ||
- | - speedtester # beginning of the pod name | ||
- | gather_facts: | ||
- | tasks: | ||
- | - name: Get a list of all pods from the namespace | ||
- | command: kubectl get pods --no-headers -o custom-columns=": | ||
- | register: pod_list | ||
- | - name: Print pod names | ||
- | debug: | ||
- | msg: "{{ item }}" | ||
- | loop: "{{ pod_list.stdout_lines }}" | ||
- | when: item is match(pod_filter|join(' | ||
- | - name: Crash container by killing supervisord | ||
- | command: kubectl exec "{{ item }}" -- pkill supervisord | ||
- | loop: "{{ pod_list.stdout_lines }}" | ||
- | when: item is match(pod_filter|join(' | ||
- | </ | ||
- | |||
- | ==== Reboot a Random Ansible Node ==== | ||
- | <file yaml randomreboot.yml> | ||
- | --- | ||
- | - hosts: localhost | ||
- | connection: local | ||
- | gather_facts: | ||
- | tasks: | ||
- | - add_host: | ||
- | name: "{{ item }}" | ||
- | groups: limited_selection | ||
- | loop: "{{ (groups[' | ||
- | |||
- | - hosts: limited_selection | ||
- | gather_facts: | ||
- | tasks: | ||
- | - reboot: | ||
- | </ |
lab/stack_of_nucs/demonstrate_app_on_k8s.1682969905.txt.gz · Last modified: 2023/05/01 19:38 by user