Overview
In this lab, you build a GKE cluster and then deploy pods for use with Kubernetes Engine Monitoring. You will create charts and a custom dashboard, work with custom metrics, and create and respond to alerts.
Note: For this lab, GKE Standard Mode will be used. The lab explores System logging and monitoring and these are enabled by default in GKE Autopilot.
Objectives
In this lab, you learn how to perform the following tasks:
- Use Kubernetes Engine Monitoring to view cluster and workload metrics
- Use Cloud Monitoring Alerting to receive notifications about the cluster’s health
Lab setup
Access Qwiklabs
For each lab, you get a new Google Cloud project and set of resources for a fixed time at no cost.
- 
Click the Start Lab button. If you need to pay for the lab, a pop-up opens for you to select your payment method.
On the left is the Lab Details panel with the following: 
- The Open Google Cloud console button
- Time remaining
- The temporary credentials that you must use for this lab
- Other information, if needed, to step through this lab
 
- 
Click Open Google Cloud console (or right-click and select Open Link in Incognito Window if you are running the Chrome browser). The lab spins up resources, and then opens another tab that shows the Sign in page. Tip: Arrange the tabs in separate windows, side-by-side. Note: If you see the Choose an account dialog, click Use Another Account.
- 
If necessary, copy the Username below and paste it into the Sign in dialog. {{{user_0.username | "Username"}}}You can also find the Username in the Lab Details panel. 
- 
Click Next. 
- 
Copy the Password below and paste it into the Welcome dialog. {{{user_0.password | "Password"}}}You can also find the Password in the Lab Details panel. 
- 
Click Next. Important: You must use the credentials the lab provides you. Do not use your Google Cloud account credentials. 
 
Note: Using your own Google Cloud account for this lab may incur extra charges.
- 
Click through the subsequent pages: 
- Accept the terms and conditions.
- Do not add recovery options or two-factor authentication (because this is a temporary account).
- Do not sign up for free trials.
 
After a few moments, the Google Cloud console opens in this tab.
Note: To view a menu with a list of Google Cloud products and services, click the Navigation menu at the top-left, or type the service or product name in the Search field.
 
Activate Google Cloud Shell
Google Cloud Shell is a virtual machine that is loaded with development tools. It offers a persistent 5GB home directory and runs on the Google Cloud.
Google Cloud Shell provides command-line access to your Google Cloud resources.
- 
In Cloud console, on the top right toolbar, click the Open Cloud Shell button.  
 
- 
Click Continue. 
It takes a few moments to provision and connect to the environment. When you are connected, you are already authenticated, and the project is set to your PROJECT_ID. For example:

gcloud is the command-line tool for Google Cloud. It comes pre-installed on Cloud Shell and supports tab-completion.
- You can list the active account name with this command:
gcloud auth listOutput:
Credentialed accounts:
 - @.com (active)
Example output:
Credentialed accounts:
 - google1623327_student@qwiklabs.net
 
- You can list the project ID with this command:
gcloud config list projectOutput:
[core]
project = 
Example output:
[core]
project = qwiklabs-gcp-44776a13dea667a6
Note: 
  Full documentation of gcloud is available in the
  
    gcloud CLI overview guide
  .
Task 1. Using Kubernetes Engine Monitoring
Google Kubernetes Engine includes managed support for Monitoring.
In this task, you will create a new cluster with Kubernetes Engine Monitoring support and then perform typical monitoring tasks using the Kubernetes Engine monitoring and logging interface.
Configuring a GKE cluster with Kubernetes Engine Monitoring
In this task, you will create a GKE cluster with Kubernetes Engine Monitoring enabled. Then you will deploy sample workloads to your GKE cluster for later use in this exercise.
- In Cloud Shell, type the following command to create environment variables for the Google Cloud zone and cluster name that will be used to create the cluster for this lab:
export my_zone={{{ project_0.default_zone| "Zone" }}}
export my_cluster=standard-cluster-1
- Configure tab completion for the  kubectl command-line tool:
source <(kubectl completion bash)
- Create a VPC-native Kubernetes cluster with native Kubernetes monitoring enabled:
gcloud container clusters create $my_cluster \
   --num-nodes 3 --enable-ip-alias --zone $my_zone  \
   --logging=SYSTEM \
   --monitoring=SYSTEM
Note: You need to wait a few minutes for the cluster deployment to complete.
- Configure access to your cluster for kubectl:
gcloud container clusters get-credentials $my_cluster --zone $my_zoneUse the Google Cloud console to verify monitoring's configuration
- 
In the Google Cloud console, in the Navigation menu ( ), click Kubernetes Engine > Clusters. ), click Kubernetes Engine > Clusters.
 
- 
Click the cluster name standard-cluster-1 to view the cluster details. 

You can scroll down the page to view more details.
Under the Features heading, you can see the Logging and Cloud Monitoring settings that set the logging type to System.

Deploy a sample workload to your GKE cluster
You will now deploy a sample workload to the default namespace of your GKE cluster. This workload consists of a deployment of three pods running a simple Hello World demo application. Later in this lab exercise, you will be able to monitor the health of this workload in Monitoring.
- In Cloud Shell, enter the following command  to clone the lab repository to the lab Cloud Shell:
git clone https://github.com/GoogleCloudPlatform/training-data-analyst
- Create a soft link as a shortcut to the working directory:
ln -s ~/training-data-analyst/courses/ak8s/v1.1 ~/ak8s
- Change to the directory that contains the sample files for this lab:
cd ~/ak8s/Monitoring/
- In the Cloud Shell, execute the following command to deploy a manifest that creates a sample deployment that will provide some items for you to monitor later in this lab exercise using Monitoring:
kubectl create -f hello-v2.yamlThis deployment manifest creates three Pods running a simple Hello World demo application.
- In the Cloud Shell, execute the following command to verify the deployment exists:
kubectl get deploymentsThe output of this command will show that the hello-v2 application is running in the default namespace:
NAME       READY   UP-TO-DATE   AVAILABLE   AGE
hello-v2   3/3     3            3           6s
Click Check my progress to verify the objective.
Configuring a GKE cluster with Kubernetes Engine Monitoring and deploy a sample workload
Deploy the GCP-GKE-Monitor-Test application
You will now deploy the GCP-GKE-Monitor-Test application to the default namespace of your GKE cluster. This workload has a deployment consisting of a single pod that is then exposed to the internet via a LoadBalancer service.
- In the Cloud Shell, execute the following command to store the current Project ID in an environment variable:
export PROJECT_ID="$(gcloud config get-value project -q)"
- In the Cloud Shell, execute the following command to change to the load application directory:
cd gcp-gke-monitor-test
- In the Cloud Shell, execute the following command to build the Docker image for the load testing application and push the image to the Google gcr.io registry for your lab project:
gcloud builds submit --tag=gcr.io/$PROJECT_ID/gcp-gke-monitor-test .Alternatively, you can also use Docker directly to build and push an image to gcr.io:
docker build -t gcr.io/${PROJECT_ID}/gcp-gke-monitor-test .
- In the Cloud Shell, execute the following command to change back to the main working directory for the lab:
cd ..
- In the Cloud Shell, execute the following command to replace a placeholder value in the gcp-gke-monitor-test.yamlfile with the Docker image you just pushed to gcr.io:
sed -i "s/\[DOCKER-IMAGE\]/gcr\.io\/${PROJECT_ID}\/gcp-gke-monitor-test\:latest/" gcp-gke-monitor-test.yaml
Note: 
The sed command in UNIX stands for stream editor and it can perform many functions on files such as replace, insertion, or deletion. Though most common use of sed is for substitution.
By using sed you can edit files even without opening them, which is much quicker way to find and replace something in file, than first opening that file in an editor and then changing it.
- In Cloud Shell, enter the following command to deploy the manifest you just updated to create the deployment and service you will use to test Kubernetes Engine Monitoring:
kubectl create -f gcp-gke-monitor-test.yaml
- In the Cloud Shell, execute the following command to verify that the deployment exists:
kubectl get deploymentsThe output of this command will show that the hello-v2 application is running in the default namespace:
NAME                   READY   UP-TO-DATE   AVAIL   AGE
gcp-gke-monitor-test   1/1     1            0       1s
hello-v2               3/3     3            3       38s
- In the Cloud Shell, execute the following command  to verify the service exists:
kubectl get serviceThe output of this command will show that the gcp-gke-monitor-test-service is running in the default namespace. You may need to run this command multiple times until this service is assigned an external IP address.
Click Check my progress to verify the objective.
Deploy the GCP-GKE-Monitor-Test application
Task 2. Using the GCP-GKE-Monitor-Test application
In this task, you will use the GCP-GKE-Monitor-Test application to explore different aspects of Kubernetes Engine Monitoring. The tool is composed of four sections:
- Generate CPU Load
- Custom Metrics
- Log Test
- Crash the Pod

In the first section, Generate CPU Load, you have buttons to start and stop a CPU Load Generator. The tool starts a loop of math operations which will consume an entire CPU core. To prevent losing control of the pod due to CPU saturation, the loop yields the processor periodically for 100 nanoseconds. This allows you to quickly stop the CPU Load Generator without killing the pod.
The second section, Custom Metrics, allows you to explore custom metric monitoring within Cloud Monitoring. When you click Start Monitoring, the tool first creates the necessary Custom Metric Descriptor, and then starts a loop which sends the custom metric values to Monitoring every 60 seconds. The custom metrics coded into this tool are designed to simulate an application that can keep track of the number of active users connected, and then report that number to an external service.
To take advantage of these custom metrics, some additional instrumentation may be required within your application's code. In this lab exercise you can simulate users connecting and disconnecting by clicking the Increase and Decrease Users buttons.
Also keep in mind that although the web tool will allow you to change the number of users in real time (just as users may connect and disconnect in real life), the Cloud Monitoring APIs only allow the tool to send its current value once per minute. This means your Cloud Monitoring charts will not reflect changes which occur between the per-minute updates.
The third section, Log Test, allows you to send different text strings to the container's standard output (the console), which is then periodically collected by Cloud Monitoring and stored as log messages associated with the pod and container. You can optionally enable Debug-level logging to see more entries in the logs. This will allow you to see messages in the logs when you increase the number of users in the Custom Metrics section, or when you enable or disable the CPU Load Generator. Note that these logs are sent in plain-text format to simulate legacy applications which do not support JSON formatted messages. When you view the logs in Logging you will notice that your pod's JSON-based Kubernetes event logs have much more robust filtering and querying options than what is available for the unstructured logs.
The fourth and final section, Crash the Pod, allows you to crash the pod with the click of a button. The tool executes a section of code with an unhandled error, which crashes the pod and triggers the deployment to restart a new pod in its place. You can use this tool to see how quickly Kubernetes Engine can recover from errors. It is also an opportunity to see the loss of session state in action because each pod maintains its own session instead of storing it in a central location. When the pod restarts, all your toggle buttons and settings return to their default values.
Start the CPU Load Generator
You will now open a web browser, connect to the GCP-GKE-Monitor-Test tool, and start the CPU load generator.
- In Cloud Shell, enter the following command to get the EXTERNAL-IP address of the gcp-gke-monitor-test-service:
kubectl get service
- Open your web browser and navigate to the EXTERNAL-IP address of the service.
- In the Generate CPU Load section, click the Start CPU Load button. Note that the STATUS text will change when the load generator starts running.

Start collecting custom metrics
You will now start a process within the GCP-GKE-Monitor-Test tool which creates a Custom Metric Descriptor within Cloud Monitoring. Later, when the tool begins sending the custom metric data, Monitoring will associate the data with this metric descriptor. Note that Monitoring can often automatically create the custom metric descriptors for you when you send the custom metric data, but creating the descriptor manually gives you more control over the text that appears in the Monitoring interface, making it easier for you to find your data in the Metric Explorer.
- In the GCP-GKE-Monitor-Test tool, in the Custom Metrics section, click the Start Monitoring button.

You can now click the Increase and Decrease Users buttons to change the Current User Count displayed below the STATUS text.
- Click Increase Users Counter and repeat until the Current User Count is set to 10 users.

It may take 2-3 minutes for the first data point to appear in Monitoring. You will check this custom metric in Cloud Monitoring in a later step.
Generate test log messages
You will now use the GCP-GKE-Monitor-Test tool to create sample text-based logs which you will later view in Cloud Monitoring.
- In the GCP-GKE-Monitor-Test tool, in the Log Test section, click the Enable Debug Logging button to increase the number of logs the tool generates.

- Click the other four log entry buttons to generate some additional sample log messages. It's important to select a variety of severity levels so that you can see how the different message types are displayed in Monitoring.

Task 3. Using Kubernetes Engine Monitoring
In this task, you will use Kubernetes Engine Monitoring to view the current health of your GKE cluster and the two workloads running on it.
Create a Monitoring workspace
You will now setup a Monitoring workspace that's tied to your Google Cloud Project. The following steps create a new account that has a free trial of Monitoring.
- 
On the Google Cloud console title bar, type Monitoring in the Search field, then click Monitoring (Infrastructure and application quality checks) in the search results. 
- 
Click Pin next to Observability Monitoring. 
- 
Wait for your workspace to be provisioned. 
When the Monitoring dashboard opens, your workspace is ready.

Review the Kubernetes Engine monitoring interface
You will now open and browse the three different sections of the Kubernetes Engine Monitoring interface. The three sections are: Infrastructure, Workloads, and Services.
Note: 
The GKE option might not appear immediately in the Monitoring menus. It might take 5 to 10 minutes to enable the cluster for the new features. Refresh your page periodically until the option appears.
- 
In the Monitoring interface, click GKE  in the Dashboards section to view the new monitoring interface. 
- 
Review the monitoring interface. This is a dashboard which shows the health of your GKE clusters and their workloads.  Take note of the following: 
- A dynamic Timeline is displayed in the top portion of the interface. If required, expand it by clicking on the dropdown icon. You can adjust the Time Span from the top of the screen: 1h, 6h, 1d, 1w, 1m, 6w, or custom. This timeline will include markers that indicate the occurrence of alerts (also known as incidents).

- The Auto refresh button (toggle button to the left of the screen): Click the Auto refresh button to allow the screen to update as new events are received.
- The lower portion of this dashboard contains a multiple section views of your clusters and their workloads. The interface is divided into several sections: Clusters, Namespaces, Nodes, Workloads, Kubernetes services, Pods, and Containers.
Examine each section in the interface:
- 
The Clusters, Nodes, and Pods sections allow you to check the health of particular elements in the cluster. You can also use this to inspect the pods which are running on a particular node in the cluster. 
- 
To see the details of your cluster, click on the cluster element. 
- 
The Workloads section is very helpful, especially when looking for workloads which do not have services exposed. 
- 
The Kubernetes services section organizes the services configured in your environment by cluster, then by namespace (the administrative barrier or partition within the cluster), and then shows the various services available to users within that namespace. You can see more details on each service by clicking on their name. 
- 
The Namespaces section shows the list of namespaces within the cluster. 
The monitoring interface can provide even more detail about the deployments and pods.
- In the Pods section, click the pod beginning with fluentbit-gke-xxxx (If required, click on View all), and then click on Metrics tab to see more metrics.
Note the value of your pod's CPU request utilization. That number represents the amount of CPU resources the pod is consuming relative to what it originally requested from the cluster.
- 
Click the X in the upper right corner of the Pod Details window. 
- 
Now, click the pod beginning with gcp-gke-monitor-test to view more detail about it. 
Note that you will see slightly different information if you selected the Namespaces instead of the Pod.
- 
Click on the Metrics tab to see more metrics such as CPU request utilization and CPU Usage Time. 
- 
In the Pod Details window, click the Logs tab to view the log activity for the pod. 
This shows the log messages the pod has generated as well as a graph indicating the logging activity of the pod over time. Here you can see some of the sample logs you generated in the tool.

- Click the X in the upper right corner of the Pod Details window to return to the Monitoring interface.
Create a custom Monitoring dashboard to monitor your pods
In Monitoring, you can create custom dashboards to display important metrics such as CPU utilization, container restarts, and more such as our custom metric for the number of connected users.
- 
In the navigation bar at the left of the Observability Monitoring page, click on Metrics Explorer to begin building your dashboard. 
- 
Click on Select a metric. 
This will filter the list to the resource types supported by the new Kubernetes Engine Monitoring tools.
- 
Select  Kubernetes Container > Popular Metrics > CPU request utilization. 
- 
Click Apply. 
This is the same CPU request utilization chart we saw earlier when we examined the fluentbit-gke-xxxx pod, but now the chart will display that metric for all the pods.
- 
Now click the Save Chart button in the upper right corner of the screen. 
- 
Give the chart title a name such as Container CPU Request, and then click Dashboard. 
The chart name should represent only this chart. You'll be able to give the entire dashboard a name in the next step.
- 
Click New Dashboard. 
- 
Name your dashboard Container Dashboard. 
- 
Click Save Chart. 
- 
Now you can launch your dashboard by clicking Dashboards in the navigation pane, and then selecting the name of your new dashboard. 
You now have a dashboard showing a single chart with a standard Monitoring metric. Next, you will create a chart for our custom Monitoring metric and then add it to this dashboard.
- 
Click Metrics explorer. 
- 
Click on Select a metric. 
- 
Select Kubernetes Pod > Custom metrics > Web App - Active Users. 
- 
Click Apply. 
- 
Click on Save Chart. 
- 
Give the new chart a name, such as Active Users. 
- 
Select Container Dashboard from the dashboards dropdown. 
- 
Click Save Chart. 
- 
Navigate back to your Container dashboard and click the Gear icons to display the settings menu. 
- 
Then click Legends > Table to display the text under each chart. 
- 
Click the three vertical bars next to the word Value at the right of each chart. 
This displays a popup which contains the various labels which were included in the timeSeries data sent by our application server. You can use this information to filter or even aggregate the data in the chart.
Task 4. Creating alerts with Kubernetes Engine Monitoring
In this task, you will configure an alert within Kubernetes Engine Monitoring and then use the dashboard to identify and respond to the incident.
Create an Alert Policy
You will now create an alert policy to detect high CPU utilization among the containers.
- In the Cloud console, from the Navigation menu, select Monitoring > Alerting.
- Click + Create Policy.
- Click on Select a metric dropdown.
- Uncheck the Active option.
- Type Kubernetes Container in filter by resource and metric name.
- Click on Kubernetes Container > Container.
- Select CPU request utilization.
- Click Apply.
Note: If you cannot locate the Kubernetes Container resource type, you might have to refresh the page.
- Set Rolling windows to 1 min.
- Click Next.
- Set Threshold position to Above Threshold.
- Set 0.99 as your Threshold value.
- Click Next.
Configure notifications and finish the alerting policy
- 
Click on dropdown arrow next to Notification Channels, then click on Manage Notification Channels, then click on Notification channels page will open in new tab. 
- 
Scroll down the page and click on ADD NEW for Email. 
- 
Enter your personal email in the Email Address field and a Display name. 
- 
Click Save. 
- 
Go back to the previous Create alerting policy tab. 
- 
Click on Notification Channels again, then click on the Refresh icon to get the display name you mentioned in the previous step. Click Notification Channels again if needed. 
- 
Now, select your Display name and click OK. 
- 
Name the alert CPU request utilization.
 
- 
Click Next. 
- 
Review the alert and click Create Policy. 
Click Check my progress to verify the objective.
Creating Alerts with Kubernetes Engine Monitoring
Respond to an Incident
Now, you will return to the monitoring dashboard where an incident is being reported on one of the containers.
- In the Observability Monitoring page, select Overview > GKE.
On the Kubernetes Engine Monitoring dashboard, you should see an incident reported on the container.
- In the Containers tab, click on the container name which shows the alert.
It will take a minute or two to register the alert and you may need to refresh the page to see the alert.
- Go to Alerting page.
- Click the alert name CPU request utilization to view additional details.
- Open the incident and click on the Incident summary entry.
- Click on Acknowledge Incident.
The incident status now shows Acknowledged, but that doesn't solve the problem. You need to fix the root cause of the problem; the CPU Load Generator container.
- Open the web interface for the GCP-GKE-Monitor-Test tool.
- In the Generate CPU Load section, click the Stop CPU Load button to resolve the issue by stopping the CPU Load Generator.
- You may now close the GCP-GKE-Monitor-Test web browser window.
End your lab
When you have completed your lab, click End Lab. Google Cloud Skills Boost removes the resources you’ve used and cleans the account for you.
You will be given an opportunity to rate the lab experience. Select the applicable number of stars, type a comment, and then click Submit.
The number of stars indicates the following:
- 1 star = Very dissatisfied
- 2 stars = Dissatisfied
- 3 stars = Neutral
- 4 stars = Satisfied
- 5 stars = Very satisfied
You can close the dialog box if you don't want to provide feedback.
For feedback, suggestions, or corrections, please use the Support tab.
Copyright 2022 Google LLC All rights reserved. Google and the Google logo are trademarks of Google LLC. All other company and product names may be trademarks of the respective companies with which they are associated.