Ch13 lab

Setup

Deploy the logging subsystem:

kubectl apply -f lab/logging/

Sample Solution

Part 1

Fluent Bit is configured to store entries from Pods in the namespace kiamol-ch13-lab.

Create that namespace and deploy the vweb app:

kubectl create ns kiamol-ch13-lab

kubectl apply -f lab/vweb/ -n kiamol-ch13-lab

Browse to the app which will trigger Nginx logs in the container.

Browse to Kibana and create an index pattern for the index called lab - verify that logs are coming through.

Lab part 1 - logs from Nginx

Part 2

The logs are there, but not parsed so they're just text.

Deploy an update to the vweb Deployment which adds an annotation to use the Nginx parser:

kubectl apply -f lab/solution/vweb-with-parser.yaml -n kiamol-ch13-lab

Browse to the app again and refresh Kibana - the logs should have fields for HTTP path, response code etc.

Lab part 2 - parsed fields from Nginx

Part 3

Now to filter out 304s, add a grep filter to the Fluent Bit config and update the Pod:

kubectl apply -f lab/solution/fluentbit-config-grep.yaml

kubectl rollout restart ds/fluent-bit -n kiamol-ch13-lab-logging

kubectl wait --for=condition=ContainersReady pod -l app=fluent-bit -n kiamol-ch13-lab-logging

Browse to the app again and refresh Kibana - no 304s are shown for recent requests

Lab part 3 - excluding 304s from Nginx

Teardown

Remove the namespaces and that removes everything:

kubectl delete ns kiamol-ch13-lab

kubectl delete ns kiamol-ch13-lab-logging