访问 700 多个实验和课程

Build Google Cloud Infrastructure for Azure Professionals: Challenge Lab

实验 1 小时 universal_currency_alt 5 个积分 show_chart 中级
info 此实验可能会提供 AI 工具来支持您学习。
访问 700 多个实验和课程

GSP512

Google Cloud self-paced labs logo

Introduction

In a challenge lab you’re given a scenario and a set of tasks. Instead of following step-by-step instructions, you will use the skills learned from the labs in the course to figure out how to complete the tasks on your own! An automated scoring system (shown on this page) will provide feedback on whether you have completed your tasks correctly.

When you take a challenge lab, you will not be taught new Google Cloud concepts. You are expected to extend your learned skills, like changing default values and reading and researching error messages to fix your own mistakes.

To score 100% you must successfully complete all tasks within the time period!

This lab is recommended for students who have completed the labs in the Build Google Cloud Infrastructure for Azure Professionals course. Are you up for the challenge?

Setup

Before you click the Start Lab button

Read these instructions. Labs are timed and you cannot pause them. The timer, which starts when you click Start Lab, shows how long Google Cloud resources are made available to you.

This hands-on lab lets you do the lab activities in a real cloud environment, not in a simulation or demo environment. It does so by giving you new, temporary credentials you use to sign in and access Google Cloud for the duration of the lab.

To complete this lab, you need:

  • Access to a standard internet browser (Chrome browser recommended).
Note: Use an Incognito (recommended) or private browser window to run this lab. This prevents conflicts between your personal account and the student account, which may cause extra charges incurred to your personal account.
  • Time to complete the lab—remember, once you start, you cannot pause a lab.
Note: Use only the student account for this lab. If you use a different Google Cloud account, you may incur charges to that account.

Challenge scenario

As a cloud engineer who is familiar with Azure in Cymbal Group and recently trained with Google Cloud and Kubernetes you have been asked to help a new team (Griffin) set up their environment. The team has asked for your help and has done some work, but needs you to complete the work.

You are expected to have the skills and knowledge for these tasks so don’t expect step-by-step guides.

You need to complete the following tasks:

  • Create a development VPC with three subnets manually
  • Create a production VPC with three subnets manually
  • Create a bastion that is connected to both VPCs
  • Create a development Cloud SQL Instance and connect and prepare the WordPress environment
  • Create a Kubernetes cluster in the development VPC for WordPress
  • Prepare the Kubernetes cluster for the WordPress environment
  • Create a WordPress deployment using the supplied configuration
  • Enable monitoring of the cluster via stackdriver
  • Provide access for an additional engineer

Some Cymbal Group standards you should follow:

  • Create all resources in the region and zone, unless otherwise directed.
  • Use the project VPCs.
  • Naming is normally team-resource, e.g. an instance could be named kraken-webserver1.
  • Allocate cost effective resource sizes. Projects are monitored and excessive resource use will result in the containing project's termination (and possibly yours), so beware. This is the guidance the monitoring team is willing to share: unless directed, use e2-medium.

Your challenge

You need to help the team with some of their initial work on a new project. They plan to use WordPress and need you to set up a development environment. Some of the work was already done for you, but other parts require your expert skills.

As soon as you sit down at your desk and open your new laptop you receive the following request to complete these tasks. Good luck!

Environment

Google Cloud environment, Team Griffin Infrastructure diagram

Task 1. Create development VPC manually

  • Create the first VPC called griffin-dev-vpc in region with the following subnets only:

    • griffin-dev-wp
      • IP address block: 192.168.16.0/20
    • griffin-dev-mgmt
      • IP address block: 192.168.32.0/20

Click Check my progress to verify the objective. Create development VPC manually

Note: If you don't get a green check mark, click on the Score fly-out on the top right and click Check my progress on the relevant step. A hint pop up opens to give you advice.

Task 2. Create production VPC manually

  • Create the second VPC called griffin-prod-vpc in region with the following subnets only:

    • griffin-prod-wp
      • IP address block: 192.168.48.0/20
    • griffin-prod-mgmt
      • IP address block: 192.168.64.0/20

Click Check my progress to verify the objective. Create production VPC manually

Note: If you don't get a green check mark, click on the Score fly-out on the top right and click Check my progress on the relevant step. A hint pop up opens to give you advice.

Task 3. Create bastion host

  • Create a bastion host with two network interfaces, one connected to griffin-dev-mgmt and the other connected to griffin-prod-mgmt, in zone. Make sure you can SSH to the host.

Click Check my progress to verify the objective. Create bastion host

Note: If you don't get a green check mark, click on the Score fly-out on the top right and click Check my progress on the relevant step. A hint pop up opens to give you advice.

Task 4. Create and configure Cloud SQL Instance

  1. Create a MySQL Cloud SQL Instance called griffin-dev-db in region.
Note: Please wait for 5-6 minutes for the creation of the instance.
  1. Connect to the instance and run the following SQL commands to prepare the WordPress environment:
CREATE DATABASE wordpress; CREATE USER "wp_user"@"%" IDENTIFIED BY "stormwind_rules"; GRANT ALL PRIVILEGES ON wordpress.* TO "wp_user"@"%"; FLUSH PRIVILEGES; Note: Use the same password for creating and connecting the MySQL Cloud SQL Instance.

These SQL statements create the worpdress database and create a user with access to the wordpress database.

You will use the username and password in task 6.

Click Check my progress to verify the objective. Create and configure Cloud SQL Instance

Note: If you don't get a green check mark, click on the Score fly-out on the top right and click Check my progress on the relevant step. A hint pop up opens to give you advice.

Task 5. Create Kubernetes cluster

  • Create a 2 node cluster (e2-standard-4) called griffin-dev, in the griffin-dev-wp subnet, and in zone .
Hint: Switch to the standard mode while creating the cluster

Click Check my progress to verify the objective. Create Kubernetes cluster

Note: If you don't get a green check mark, click on the Score fly-out on the top right and click Check my progress on the relevant step. A hint pop up opens to give you advice.

Task 6. Prepare the Kubernetes cluster

Check the Status of the cluster. If the status of the cluster is running, periodically refresh and wait until it becomes Ready before moving to the next step.
  1. Use Cloud Shell and copy all files from gs://spls/gsp512/wp-k8s.

The WordPress server needs to access the MySQL database using the username and password you created in task 4.

  1. You do this by setting the values as secrets. WordPress also needs to store its working files outside the container, so you need to create a volume.

  2. Navigate to the directory where the files are copied, and add the following secrets and volume to the cluster using wp-env.yaml.

  3. Make sure you configure the username to wp_user and password to stormwind_rules before creating the configuration.

You also need to provide a key for a service account that was already set up. This service account provides access to the database for a sidecar container.

  1. Use the command below to create the key, and then add the key to the Kubernetes environment:
gcloud iam service-accounts keys create key.json \ --iam-account=cloud-sql-proxy@{{{project_0.project_id | Project_ID}}}.iam.gserviceaccount.com kubectl create secret generic cloudsql-instance-credentials \ --from-file key.json

Click Check my progress to verify the objective. Prepare the Kubernetes cluster

Note: If you don't get a green check mark, click on the Score fly-out on the top right and click Check my progress on the relevant step. A hint pop up opens to give you advice.

Task 7. Create a WordPress deployment

Now that you have provisioned the MySQL database, and set up the secrets and volume, you can create the deployment using wp-deployment.yaml.

  1. Before you create the deployment you need to edit wp-deployment.yaml.

  2. Replace YOUR_SQL_INSTANCE with griffin-dev-db's Instance connection name.

  3. Get the Instance connection name from your Cloud SQL instance griffin-dev-db details page.

  4. Create your WordPress deployment wp-deployment.yaml, and the service wp-service.yaml.

  5. Once the Load Balancer is created, you can visit the site and ensure you see the WordPress site installer.
    At this point the dev team will take over and complete the install and you move on to the next task.

WordPress site installer

Click Check my progress to verify the objective. Create a WordPress deployment

Note: If you don't get a green check mark, click on the Score fly-out on the top right and click Check my progress on the relevant step. A hint pop up opens to give you advice.

Task 8. Enable monitoring

  • Create an uptime check for your WordPress development site.
Note: Run the command `kubectl get svc` in the cloud shell for wordpress endpoint IP address and replace it while creating the uptime check, and leave other values as default.

Click Check my progress to verify the objective. Enable monitoring

Note: If you don't get a green check mark, click on the Score fly-out on the top right and click Check my progress on the relevant step. A hint pop up opens to give you advice.

Task 9. Provide access for an additional engineer

  • You have an additional engineer starting and you want to ensure they have access to the project, so please go ahead and grant them the editor role to the project.

Use as the additional engineer.

Click Check my progress to verify the objective. Provide access for an additional engineer

Note: If you don't get a green check mark, click on the Score fly-out on the top right and click Check my progress on the relevant step. A hint pop up opens to give you advice.

Congratulations!

Build Google Cloud Infrastructure for Azure Professionals

Earn your next skill badge

This self-paced lab is part of the Build Google Cloud Infrastructure for Azure Professionals skill badge course. Completing this skill badge quest earns you the badge above, to recognize your achievement. Share your badge on your resume and social platforms, and announce your accomplishment using #GoogleCloudBadge.

This skill badge quest is part of Google’s Google Cloud Infrastructure for Azure Professionals learning path. Search the Google Cloud Skills Boost catalog for 20+ other skill badge quests in which you can enroll.

Google Cloud training and certification

...helps you make the most of Google Cloud technologies. Our classes include technical skills and best practices to help you get up to speed quickly and continue your learning journey. We offer fundamental to advanced level training, with on-demand, live, and virtual options to suit your busy schedule. Certifications help you validate and prove your skill and expertise in Google Cloud technologies.

Manual Last Updated April 16, 2024

Lab Last Tested April 16, 2024

Copyright 2025 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.

准备工作

  1. 实验会创建一个 Google Cloud 项目和一些资源,供您使用限定的一段时间
  2. 实验有时间限制,并且没有暂停功能。如果您中途结束实验,则必须重新开始。
  3. 在屏幕左上角,点击开始实验即可开始

使用无痕浏览模式

  1. 复制系统为实验提供的用户名密码
  2. 在无痕浏览模式下,点击打开控制台

登录控制台

  1. 使用您的实验凭证登录。使用其他凭证可能会导致错误或产生费用。
  2. 接受条款,并跳过恢复资源页面
  3. 除非您已完成此实验或想要重新开始,否则请勿点击结束实验,因为点击后系统会清除您的工作并移除该项目

此内容目前不可用

一旦可用,我们会通过电子邮件告知您

太好了!

一旦可用,我们会通过电子邮件告知您

一次一个实验

确认结束所有现有实验并开始此实验

使用无痕浏览模式运行实验

请使用无痕模式或无痕式浏览器窗口运行此实验。这可以避免您的个人账号与学生账号之间发生冲突,这种冲突可能导致您的个人账号产生额外费用。