Get access to 700+ labs and courses

Creating a Real-time Data Pipeline using Eventarc and MongoDB Atlas

Lab 1 hour 30 minutes universal_currency_alt 1 Credit show_chart Introductory
info This lab may incorporate AI tools to support your learning.
Get access to 700+ labs and courses

This lab was developed with the partner, MongoDB. Your personal information may be shared with MongoDB, the lab sponsor, if you have opted-in to receive product updates, announcements, and offers in your Account Profile.

Note: This lab requires a partner account. Please follow the lab instructions to create your account before starting the lab.

GSP1148

Google Cloud Self-Paced Labs

Overview

In this lab, you will construct a pipeline that seamlessly transports real-time data generated by edge devices or sensors to MongoDB using MongoDB Atlas Data API. Through this process, you will establish a Pub/Sub topic that monitors change stream data, an Eventarc trigger that connects the Pub/Sub topic to a Google Cloud Function, and a MongoDB collection to securely store the data. You'll also visualize the data with MongoDB Atlas Charts.

With MongoDB Atlas on Google Cloud, you will be able to integrate with the Google Cloud product suite to create more value. MongoDB with Google Cloud provides great geographic presence, Cost to performance ratio and security.

overview

Objectives

In this lab, you will do the following:

  • Provision your MongoDB Atlas cluster.
  • Create a database and collections within it and load with the initial set of data.
  • Set up the MongoDB Atlas Data API and create an API key.
  • Create a Pub/Sub topic that can read the change stream IIoT data.
  • Create an Eventarc trigger with Pub/Sub as a source and Cloud Function as destination.
  • Create a Cloud Function that uses MongoDB Atlas Data API to write the data to MongoDB.
  • Configure MongoDB Atlas Charts to display and visualize the data.
  • Run a Cloud Function to simulate an IIOT sensor that publishes data to Pub/Sub.

Prerequisites

If you are new to MongoDB Atlas, take up the lab Introduction to MongoDB Atlas to setup your first MongoDB cluster or refer below documentation:

  1. Through the Google Cloud Marketplace if you have a Google Cloud account. Refer to the documentation to set up your subscription.
  2. With the Atlas registration page.

Setup and Requirements

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 will be made available to you.

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

What you need

To complete this lab, you need:

  • Access to a standard internet browser (Chrome browser recommended).
  • Time to complete the lab.

Note: If you already have your own personal Google Cloud account or project, do not use it for this lab.

Note: If you are using a Pixelbook, open an Incognito window to run this lab.

How to start your lab and sign in to the Google Cloud Console

  1. 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 a panel populated with the temporary credentials that you must use for this lab.

    Open Google Console

  2. Copy the username, and then click Open Google Console. The lab spins up resources, and then opens another tab that shows the Sign in page.

    Sign in

    Tip: Open the tabs in separate windows, side-by-side.

  3. In the Sign in page, paste the username that you copied from the Connection Details panel. Then copy and paste the password.

    Important: You must use the credentials from the Connection Details panel. Do not use your Qwiklabs credentials. If you have your own Google Cloud account, do not use it for this lab (avoids incurring charges).

  4. 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 Cloud Console opens in this tab.

Task 1. Setting up and Configuring Atlas for Data Management: Cluster, API, and Charts

Set up a MongoDB cluster

Scenario: There is a weather station generating weather data. The data generator is mimicking the weather station sensors. You will be creating a real time monitoring system for the weather data using MongoDB Charts in this section.

{ "Formatted Date":{"$date":{"$numberLong":"1143842400000"}}, "Summary":"Partly Cloudy", "Precip Type":"rain", "Temperature (C)":{"$numberDouble":"9.472222222222221"}, "Apparent Temperature (C)":{"$numberDouble":"7.3888888888888875"}, "Humidity":{"$numberDouble":"0.89"}, "Wind Speed (km/h)":{"$numberDouble":"14.1197"}, "Wind Bearing (degrees)":{"$numberInt":"251"}, "Visibility (km)":{"$numberDouble":"15.826300000000002"}, "Loud Cover":{"$numberInt":"0"}, "Pressure (millibars)":{"$numberDouble":"1015.13"}, "Daily Summary":"Partly cloudy throughout the day." }
  1. [Prerequisite] Register for MongoDB Atlas either from Google Cloud Marketplace or MongoDB Atlas registration page.
  2. Log into your Atlas account, and click on Build a Cluster. (or, you may see +Create button.)

build databse

  1. On the Deploy your cluster page select M0.

  2. Name the cluster Sandbox.

  3. Select Google Cloud in Cloud Provider & Region. Select the nearest region to you.

  4. Click on Create Deployment.

Create deployment

  1. Click Close.

  2. Click on Browse Collections and then click on the +Create Database button.

  3. Name your database weather_station and collection name sensor and click on Create. Make sure you observe this exact casing and spelling on the database and collection names, otherwise your Cloud Function will fail later.

  4. To insert a sample document into the collection, click on Insert document.

You can either enter the fields one at a time, or add the whole document as JSON. Switch to the JSON view:

Select Json format

Copy and paste the below document into the collection.

{ "Formatted Date":{"$date":{"$numberLong":"1143842400000"}}, "Summary":"Partly Cloudy", "Precip Type":"rain", "Temperature (C)":{"$numberDouble":"9.472222222222221"}, "Apparent Temperature (C)":{"$numberDouble":"7.3888888888888875"}, "Humidity":{"$numberDouble":"0.89"}, "Wind Speed (km/h)":{"$numberDouble":"14.1197"}, "Wind Bearing (degrees)":{"$numberInt":"251"}, "Visibility (km)":{"$numberDouble":"15.826300000000002"}, "Loud Cover":{"$numberInt":"0"}, "Pressure (millibars)":{"$numberDouble":"1015.13"}, "Daily Summary":"Partly cloudy throughout the day." }

Repeat the above step to insert one more document.

{ "FormattedDate":{"$date":{"$numberLong":"1143910800000"}}, "Summary":"Mostly Cloudy", "Precip Type":"rain", "Temperature (C)":{"$numberDouble":"13.144444444444442"}, "Apparent Temperature (C)":{"$numberDouble":"13.144444444444442"}, "Humidity":{"$numberDouble":"0.7"}, "Wind Speed (km/h)":{"$numberDouble":"7.631400000000001"}, "Wind Bearing (degrees)":{"$numberInt":"139"}, "Visibility (km)":{"$numberDouble":"11.2056"}, "Loud Cover":{"$numberInt":"0"}, "Pressure (millibars)":{"$numberDouble":"1015.83"}, "Daily Summary":"Partly cloudy throughout the day." }

Collection format

  1. Your collection should look like this.

Documents example

Set up the Atlas Data API

In this section you will configure the Data API in MongoDB Atlas. The MongoDB Atlas Data API lets you read and write data in Atlas with standard HTTPS requests. To use the Data API, all you need is an HTTPS client and a valid API key. You will use the Data API to communicate with the weather_station database from Cloud Functions.

  1. On the MongoDB Home screen of data services, Click on Data API from the side pane.

Data API

  1. Click on Select data sources drop down and select Sandbox cluster created in MongoDB Create cluster stage. Click on Enable Data Access from Data API.

Enable Data API

  1. Click on Users tab.

  2. Click on Create API Key, Name your API key weather_station-api-key and click on Generate API Key. Copy the API key, store it locally and click on Close.

  3. Click Data API tab and select Read and Write.

Data API Access

  1. Copy the Data API URL Endpoint and store it locally to use in upcoming steps.

Endpoint URL

Set up Charts on MongoDB Atlas

To get a sense of what's in the data set, You can use Charts and visualize the data. In this section you will create a Discrete Line chart to understand the correlation between the Temperature and Humidity and how it changes with time.

  1. Navigate to Charts from MongoDB Atlas Home page. Click on Charts.

  2. Click Select for Chart builder. (You may also get an option like Add dashboard > Name the dashboard > Save > Add chart)

  3. Select the data source > Sandbox (Cluster) > weather_station > sensor.

Charts

  1. Select the Discrete Line chart type and drag and drop the Formatted Date field to x axis and Humidity and Temperature fields to y axis.

You are Halfway through!!!

At this stage you have now completed the Atlas set up. You have set up an Atlas cluster, created a database and collection to store sensor data, created a Data API to write the data to the collections and created charts to visualize the data.

Task 2. Building the Real-time Data Pipeline in Google Cloud Console

Verify the pre-configured Pub/Sub Topic

  1. In the Google Cloud console, click on Navigation menu ( Navigation menu icon) > Analytics> Pub/Sub.

Create topic

  1. A topic with the name "weather-sensor-trigger" is pre configured to read the Change Stream data from the generator function.

Create a Cloud Function with an Eventarc trigger

  1. In the Google Cloud console, find the Search bar on the top and search for "Cloud Functions". You will see a previously created function that you'll use later.

  2. Click on Create Function. Use the following configuration:

Property Value
Environment 2nd gen
Function name weather-sensor-function
Region The one allocated to you for the project
Trigger type Cloud Pub/Sub
Select a Cloud Pub/Sub topic weather-sensor-trigger
  1. Expand the Runtime, build, connections and security settings section. Enter the following values:
Property value
Memory allocated 512 MiB
Timeout 540 seconds
Autoscaling: Max number of instances 5

Click Next. Enable all required APIs in the prompt that follows.

  1. Change the Runtime to Python 3.9 or Python 3.10. The Entry Point will be replaced by hello_pubsub.

  2. Replace the default main.py content by the below code snippet.

import base64 import functions_framework # Triggered from a message on a Cloud Pub/Sub topic. @functions_framework.cloud_event def hello_pubsub(cloud_event): api_key = "paste the api key copied from Setup Data API from MongoDB step" url = "Paste the Data API copied from Step Setup Data API from MongoDB data services"+"/action/insertOne" import requests import json payload = json.dumps({ "collection": "sensor", "database": "weather_station", "dataSource": "Sandbox", "document": json.loads(base64.b64decode(cloud_event.data["message"]["data"]).decode("utf-8")) }) headers = { 'Content-Type': 'application/json', 'Access-Control-Request-Headers': '*', 'api-key': api_key, } print(payload) response = requests.request("POST", url, headers=headers, data=payload) return response
  1. Get the values for url and api_key from the MongoDB Atlas Data API section under Setup a MongoDB App services section. Please note that the url should be followed by /action/insertOne.

  2. Add below requirements in requirements.txt file:

functions-framework==3.* requests
  1. Click on the Deploy button. It should take a few seconds to finish deployment.

Click Check my progress to verify the objective. Create a Cloud Function

Testing it all together

Go back to the list with your Cloud Functions. The cloud function with name "sensor-data-generator" is pre configured..

cloud function sensor-data-generator

  1. Click on the "sensor-data-generator" function.
  2. Click on Trigger.
  3. Click on the trigger URL. The function will generate the data and push to the Pub/Sub topic.
  4. To verify the data is loaded into MongoDB > Navigate to your collection and click on refresh.

loaded documents

Click Check my progress to verify the objective. Verify the data has successfully loaded into MongoDB

Congratulations!

In this lab you learned how to build an IoT use case using MongoDB Atlas and Google Cloud Eventarc, Cloud Pub/Sub and Cloud functions. You have also learned how to use MongoDB Data API to read and write from MongoDB and use MongoDB Charts to visualize the data.

Next Steps / Learn More

To keep learning MongoDB try these labs:

Be sure to check out MongoDB on the Google Cloud Marketplace!

Get free $500 credits for MongoDB on Google Cloud Marketplace - Applicable only for new customers

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: June 21, 2024

Lab Last Tested: June 21, 2024

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

Before you begin

  1. Labs create a Google Cloud project and resources for a fixed time
  2. Labs have a time limit and no pause feature. If you end the lab, you'll have to restart from the beginning.
  3. On the top left of your screen, click Start lab to begin

Use private browsing

  1. Copy the provided Username and Password for the lab
  2. Click Open console in private mode

Sign in to the Console

  1. Sign in using your lab credentials. Using other credentials might cause errors or incur charges.
  2. Accept the terms, and skip the recovery resource page
  3. Don't click End lab unless you've finished the lab or want to restart it, as it will clear your work and remove the project

This content is not currently available

We will notify you via email when it becomes available

Great!

We will contact you via email if it becomes available

One lab at a time

Confirm to end all existing labs and start this one

Use private browsing to run the lab

Use an Incognito or private browser window to run this lab. This prevents any conflicts between your personal account and the Student account, which may cause extra charges incurred to your personal account.