forked from inno-devops-labs/S24-core-course-labs
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #14 from dfarkhutdinova/lab14
Lab14
- Loading branch information
Showing
6 changed files
with
260 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,182 @@ | ||
# Components of the Kube Prometheus Stack | ||
|
||
The Kube Prometheus Stack is a comprehensive solution for Kubernetes monitoring and alerting. It consists of several key components, each playing a crucial role in monitoring the health and performance of Kubernetes clusters: | ||
|
||
## 1. Prometheus Operator | ||
|
||
The Prometheus Operator automates the deployment and management of Prometheus instances on Kubernetes. It provides a Kubernetes-native way to define and configure Prometheus servers, alerting rules, and recording rules using custom resources. | ||
|
||
### Role: | ||
- Automates the lifecycle management of Prometheus instances. | ||
- Provides declarative configuration for Prometheus and related resources. | ||
- Enables easy scaling and management of Prometheus deployments. | ||
|
||
## 2. Alertmanager | ||
|
||
Alertmanager is responsible for handling alerts generated by Prometheus and routing them to the appropriate receivers such as email, Slack, PagerDuty, etc. It takes care of deduplicating, grouping, and routing alerts based on predefined configurations. | ||
|
||
### Role: | ||
- Receives alerts from Prometheus. | ||
- Groups and deduplicates alerts based on configured criteria. | ||
- Routes alerts to the appropriate receiver integration for further action. | ||
|
||
## 3. Grafana | ||
|
||
Grafana is a powerful open-source analytics and visualization platform used for creating, exploring, and sharing dashboards and data. It integrates seamlessly with Prometheus to provide rich visualizations of metrics collected from Kubernetes clusters. | ||
|
||
### Role: | ||
- Provides a user-friendly interface for visualizing metrics. | ||
- Allows the creation of custom dashboards to monitor Kubernetes resources. | ||
- Supports the integration of various data sources, including Prometheus. | ||
|
||
## 4. kube-state-metrics | ||
|
||
kube-state-metrics is a simple service that listens to the Kubernetes API server and generates metrics about the state of Kubernetes objects (e.g., pods, nodes, services). It exposes these metrics in a format that Prometheus can scrape and store for monitoring purposes. | ||
|
||
### Role: | ||
- Collects metrics about the state of Kubernetes objects. | ||
- Exposes metrics in a Prometheus-compatible format. | ||
- Enables monitoring of Kubernetes resource utilization and health. | ||
|
||
## 5. node-exporter | ||
|
||
node-exporter is a Prometheus exporter that collects hardware and OS metrics from *NIX-based systems. It provides metrics related to CPU usage, memory utilization, disk I/O, network statistics, and more from Kubernetes nodes. | ||
|
||
### Role: | ||
- Collects system-level metrics from Kubernetes nodes. | ||
- Exposes metrics in a Prometheus-compatible format. | ||
- Enables monitoring of node-level resource consumption and health. | ||
|
||
These components work together to provide a comprehensive monitoring and alerting solution for Kubernetes clusters, ensuring the reliability and performance of containerized applications. | ||
|
||
|
||
``` | ||
(venv) (base) dilaraf@MacBook-Air S24-core-course-labs % kubectl get po,sts,svc,pvc,cm | ||
NAME READY STATUS RESTARTS AGE | ||
pod/alertmanager-monitoring-kube-prometheus-alertmanager-0 2/2 Running 0 4m37s | ||
pod/monitoring-grafana-657659866f-2sqjk 3/3 Running 0 5m9s | ||
pod/monitoring-kube-prometheus-operator-7f557c868d-jdrhf 1/1 Running 0 5m9s | ||
pod/monitoring-kube-state-metrics-7fc7cf6558-fc44g 1/1 Running 0 5m9s | ||
pod/monitoring-prometheus-node-exporter-hn5h8 1/1 Running 0 5m9s | ||
pod/my-app-bb94d8f7d-6494g 1/1 Running 2 14d | ||
pod/my-app-bb94d8f7d-pph9l 1/1 Running 2 14d | ||
pod/my-app-bb94d8f7d-zmj52 1/1 Running 2 14d | ||
pod/new-app-684f958d54-4tjhh 1/1 Running 19 28d | ||
pod/prometheus-monitoring-kube-prometheus-prometheus-0 2/2 Running 0 4m36s | ||
pod/vault-0 1/1 Running 3 20d | ||
pod/vault-agent-injector-dbfc5cd77-wvtkw 1/1 Running 11 20d | ||
NAME READY AGE | ||
statefulset.apps/alertmanager-monitoring-kube-prometheus-alertmanager 1/1 4m37s | ||
statefulset.apps/my-new-chart-new-app 0/1 7d1h | ||
statefulset.apps/prometheus-monitoring-kube-prometheus-prometheus 1/1 4m36s | ||
statefulset.apps/vault 1/1 20d | ||
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE | ||
service/alertmanager-operated ClusterIP None <none> 9093/TCP,9094/TCP,9094/UDP 4m37s | ||
service/kubernetes ClusterIP 10.96.0.1 <none> 443/TCP 34d | ||
service/monitoring-grafana ClusterIP 10.108.77.64 <none> 80/TCP 5m9s | ||
service/monitoring-kube-prometheus-alertmanager ClusterIP 10.110.48.207 <none> 9093/TCP,8080/TCP 5m9s | ||
service/monitoring-kube-prometheus-operator ClusterIP 10.96.33.51 <none> 443/TCP 5m9s | ||
service/monitoring-kube-prometheus-prometheus ClusterIP 10.100.70.106 <none> 9090/TCP,8080/TCP 5m9s | ||
service/monitoring-kube-state-metrics ClusterIP 10.108.221.254 <none> 8080/TCP 5m9s | ||
service/monitoring-prometheus-node-exporter ClusterIP 10.108.227.127 <none> 9100/TCP 5m9s | ||
service/my-new-chart-new-app ClusterIP 10.97.235.199 <none> 80/TCP 7d1h | ||
service/new-app ClusterIP 10.109.11.167 <none> 80/TCP 28d | ||
service/prometheus-operated ClusterIP None <none> 9090/TCP 4m36s | ||
service/vault ClusterIP 10.110.116.148 <none> 8200/TCP,8201/TCP 20d | ||
service/vault-agent-injector-svc ClusterIP 10.99.100.207 <none> 443/TCP 20d | ||
service/vault-internal ClusterIP None <none> 8200/TCP,8201/TCP 20d | ||
NAME DATA AGE | ||
configmap/app-config 1 7d1h | ||
configmap/kube-root-ca.crt 1 35d | ||
configmap/monitoring-grafana 1 5m9s | ||
configmap/monitoring-grafana-config-dashboards 1 5m9s | ||
configmap/monitoring-kube-prometheus-alertmanager-overview 1 5m9s | ||
configmap/monitoring-kube-prometheus-apiserver 1 5m9s | ||
configmap/monitoring-kube-prometheus-cluster-total 1 5m9s | ||
configmap/monitoring-kube-prometheus-controller-manager 1 5m9s | ||
configmap/monitoring-kube-prometheus-etcd 1 5m9s | ||
configmap/monitoring-kube-prometheus-grafana-datasource 1 5m9s | ||
configmap/monitoring-kube-prometheus-grafana-overview 1 5m9s | ||
configmap/monitoring-kube-prometheus-k8s-coredns 1 5m9s | ||
configmap/monitoring-kube-prometheus-k8s-resources-cluster 1 5m9s | ||
configmap/monitoring-kube-prometheus-k8s-resources-multicluster 1 5m9s | ||
configmap/monitoring-kube-prometheus-k8s-resources-namespace 1 5m9s | ||
configmap/monitoring-kube-prometheus-k8s-resources-node 1 5m9s | ||
configmap/monitoring-kube-prometheus-k8s-resources-pod 1 5m9s | ||
configmap/monitoring-kube-prometheus-k8s-resources-workload 1 5m9s | ||
configmap/monitoring-kube-prometheus-k8s-resources-workloads-namespace 1 5m9s | ||
configmap/monitoring-kube-prometheus-kubelet 1 5m9s | ||
configmap/monitoring-kube-prometheus-namespace-by-pod 1 5m9s | ||
configmap/monitoring-kube-prometheus-namespace-by-workload 1 5m9s | ||
configmap/monitoring-kube-prometheus-node-cluster-rsrc-use 1 5m9s | ||
configmap/monitoring-kube-prometheus-node-rsrc-use 1 5m9s | ||
configmap/monitoring-kube-prometheus-nodes 1 5m9s | ||
configmap/monitoring-kube-prometheus-nodes-darwin 1 5m9s | ||
configmap/monitoring-kube-prometheus-persistentvolumesusage 1 5m9s | ||
configmap/monitoring-kube-prometheus-pod-total 1 5m9s | ||
configmap/monitoring-kube-prometheus-prometheus 1 5m9s | ||
configmap/monitoring-kube-prometheus-proxy 1 5m9s | ||
configmap/monitoring-kube-prometheus-scheduler 1 5m9s | ||
configmap/monitoring-kube-prometheus-workload-total 1 5m9s | ||
configmap/prometheus-monitoring-kube-prometheus-prometheus-rulefiles-0 35 4m36s | ||
(venv) (base) dilaraf@MacBook-Air S24-core-course-labs % | ||
``` | ||
|
||
data:image/s3,"s3://crabby-images/2a2cd/2a2cd97b2012071960cd76319a6e2ab8feb0a92c" alt="k8s screenshots" | ||
data:image/s3,"s3://crabby-images/ebca9/ebca9c58d33781c4c542905cd6e601590333a9c4" alt="k8s screenshots" | ||
data:image/s3,"s3://crabby-images/b62ee/b62ee4eec18d8549713ba800866dd8c2a95a6207" alt="k8s screenshots" | ||
data:image/s3,"s3://crabby-images/c4679/c467973b7db3b482895722735151b5ca1ff7cfb2" alt="k8s screenshots" | ||
|
||
# Containers | ||
``` | ||
(venv) (base) dilaraf@MacBook-Air S24-core-course-labs % kubectl exec python-web-app-0 -- cat /app_python/web_page.html | ||
Defaulted container "python-web-app" out of: python-web-app, download-file (init) | ||
<!doctype html> | ||
<html> | ||
<head> | ||
<title>Example Domain</title> | ||
<meta charset="utf-8" /> | ||
<meta http-equiv="Content-type" content="text/html; charset=utf-8" /> | ||
<meta name="viewport" content="width=device-width, initial-scale=1" /> | ||
<style type="text/css"> | ||
body { | ||
background-color: #f0f0f2; | ||
margin: 0; | ||
padding: 0; | ||
font-family: -apple-system, system-ui, BlinkMacSystemFont, "Segoe UI", "Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif; | ||
} | ||
div { | ||
width: 600px; | ||
margin: 5em auto; | ||
padding: 2em; | ||
background-color: #fdfdff; | ||
border-radius: 0.5em; | ||
box-shadow: 2px 3px 7px 2px rgba(0,0,0,0.02); | ||
} | ||
a:link, a:visited { | ||
color: #38488f; | ||
text-decoration: none; | ||
} | ||
@media (max-width: 700px) { | ||
div { | ||
margin: 0 auto; | ||
width: auto; | ||
} | ||
} | ||
</style> | ||
</head> | ||
<body> | ||
<div> | ||
<h1>Example Domain</h1> | ||
<p>This domain is for use in illustrative examples in documents. You may use this | ||
domain in literature without prior coordination or asking for permission.</p> | ||
<p><a href="https://www.iana.org/domains/example">More information...</a></p> | ||
</div> | ||
</body> | ||
</html>``` |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,78 @@ | ||
# Lab 14: Kubernetes Monitoring and Init Containers | ||
|
||
## Overview | ||
|
||
In this lab, you will explore Kubernetes cluster monitoring using Prometheus with the Kube Prometheus Stack. Additionally, you'll delve into the concept of Init Containers in Kubernetes. | ||
|
||
## Task 1: Kubernetes Cluster Monitoring with Prometheus | ||
|
||
**6 Points:** | ||
|
||
1. This lab was tested on a specific version of components: | ||
- Minikube v1.33.0 | ||
- Minikube kubectl v1.28.3 | ||
- kube-prometheus-stack-57.2.0 v0.72.0 | ||
- the minikube start command - `minikube start --driver=docker --container-runtime=containerd` | ||
|
||
2. Read about `Kube Prometheus Stack`: | ||
- [Helm chart with installation guide](https://github.com/prometheus-community/helm-charts/tree/main/charts/kube-prometheus-stack) | ||
- [Explanation of components](https://github.com/prometheus-operator/kube-prometheus#kubeprometheus) | ||
|
||
3. Describe Components: | ||
- Create `14.md` and detail the components of the Kube Prometheus Stack, explaining their roles and functions. Avoid direct copy-pasting; provide a personal understanding. | ||
|
||
4. Install Helm Charts: | ||
- Install the Kube Prometheus Stack to your Kubernetes cluster. | ||
- Install your app's Helm chart. | ||
- Provide the output of the `kubectl get po,sts,svc,pvc,cm` command in the report and explain each part. | ||
|
||
5. Utilize Grafana Dashboards: | ||
- Access Grafana using `minikube service monitoring-grafana`. | ||
- Explore existing dashboards to find information about your cluster: | ||
1. Check CPU and Memory consumption of your StatefulSet. | ||
2. Identify Pods with higher and lower CPU usage in the default namespace. | ||
3. Monitor node memory usage in percentage and megabytes. | ||
4. Count the number of pods and containers managed by the Kubelet service. | ||
5. Evaluate network usage of Pods in the default namespace. | ||
6. Determine the number of active alerts; also check the Web UI with `minikube service monitoring-kube-prometheus-alertmanager`. | ||
- Provide answers to all these points in the report. | ||
|
||
## Task 2: Init Containers | ||
|
||
**4 Points:** | ||
|
||
1. Read about `Init Containers`: | ||
- [Concept](https://kubernetes.io/docs/concepts/workloads/pods/init-containers/) | ||
- [Tutorial](https://kubernetes.io/docs/tasks/configure-pod-container/configure-pod-initialization/#create-a-pod-that-has-an-init-container) | ||
|
||
2. Implement Init Container: | ||
- Create a new Volume. | ||
- Implement an Init container to download any file using `wget` (you can use a site from the example). | ||
- Provide proof of success, e.g., `kubectl exec pod/demo-0 -- cat /test.html`. | ||
|
||
**List of Requirements:** | ||
|
||
- Detailed explanation of monitoring stack components in `14.md`. | ||
- Output and explanation of `kubectl get po,sts,svc,pvc,cm`. | ||
- Answers to all 6 questions from point 4 in `14.md`. | ||
- Implementation of Init Container. | ||
- Proof of Init Container downloading a file. | ||
|
||
## Bonus Task: App Metrics & Multiple Init Containers | ||
|
||
**2.5 Points:** | ||
|
||
1. App Metrics: | ||
- Fetch metrics from your app and provide proof. | ||
|
||
2. Init Container Queue: | ||
- Create a queue of three Init containers, with any logic like adding new lines to the same file. | ||
- Provide proof using the `cat` tool. | ||
|
||
### Guidelines | ||
|
||
- Ensure clear and organized documentation. | ||
- Use appropriate naming conventions for files and folders. | ||
- For your repository PR, ensure it's from the `lab14` branch to the main branch. | ||
|
||
> Note: Demonstrate successful implementation and understanding of Kubernetes monitoring and Init Containers. Take your time to explore the bonus tasks for additional learning opportunities. |