Google Cloud Load Balancer
This DataDome module is developed in Go and integrates with a compatible Application Load Balancer using Google Service Extension callout.
Compatibility
DataDome supports Google Load Balancer Service Extensions Traffic
Prerequisites
This article assumes that the user has already:
- A Google Cloud account: https://console.cloud.google.com/
- Created a project in GCP: https://console.cloud.google.com/projectcreate
- Created a Load Balancer: https://console.cloud.google.com/net-services/loadbalancing/add
Installation
There are three main steps and they outline the essential fields required to successfully activate DataDome integration:
- Cloud Run: Create a service to run the DataDome module.
- Load Balancer Backend Service: Create a Backend Service and a NEG (Network Endpoint Group) that allows the Service Extension to connect to the Cloud Run service (step 1).
- Service Extensions: Create a Service Extension and attach the Load Balancer to the Backend Service (step 2).
1 - Cloud Run
To call DataDome, it is mandatory to execute the module within the GCP project by creating a service on Cloud Run:
- Go to the Cloud Run main page
- Click on Deploy Container button and select Service
data:image/s3,"s3://crabby-images/c992c/c992c01c6cc3d2a0787ec12a20ade240a17de110" alt=""
- Click on Deploy one revision from an existing container image button
- Add DataDome DockerHub image path to Container image URL field:
datadome/datadome-google-cloud-service-extensions-callout
- Service name will be automatically filled
- Select a Region on the dropdown list
- Select Allow unauthenticated invocations button
data:image/s3,"s3://crabby-images/905c7/905c77f16549c1c2290fe646780ea76819290e51" alt=""
- Ingress control
- Click on Internal button
- Check Allow traffic from external Application Load Balancer
- Click on Internal button
data:image/s3,"s3://crabby-images/305dc/305dc41cf011f88ab9e81c5353d3ad779dc56a66" alt=""
-
Expand Container(s), Volume, Networking Security
- Container(s)
- Container port
- use the default
8080
value on the text field
- use the default
- Variable & Secrets
- Click on Add variable button:
- Name:
DATADOME_SERVER_SIDE_KEY
- Value: DataDome server side key, found on the dashboard
- Name:
- Click on Add variable button:
- Container port
- Container(s)
data:image/s3,"s3://crabby-images/2d1d2/2d1d29d0f6b8c4f7ba74ea240e4d3af2118b2423" alt=""
- Go to Networking
- Check Use HTTP/2 end-to-end
data:image/s3,"s3://crabby-images/e1af4/e1af4b6c18c057213343004c47ea30db3791fbd1" alt=""
- Click on Create button
2 - Load Balancer Backend Service
The Load Balancer Backend Service calls the Cloud Run service via gRPC to execute DataDome module.
To achieve this, create a Backend Service with a NEG (Network Endpoint Group) pointing to the CloudRun service created on step 1:
- Go to Load Balancing page
data:image/s3,"s3://crabby-images/4a6b6/4a6b6675aeb1deac89ae6fa2fcc6d2c2a324c2be" alt=""
- Go to Backends tab and click on the Create BackendService button
data:image/s3,"s3://crabby-images/e6783/e6783ce33117bf637f2a81013c22cec392d9efd3" alt=""
- Select the type of service based on the Load Balancer in place
data:image/s3,"s3://crabby-images/051d4/051d47cfe54fa9517e529ea978aed1ce67f7a0b9" alt=""
- Add a Name to the backend service text field
- Select a Region on the dropdown list
- Select Backend type : Serverless network endpoint group
data:image/s3,"s3://crabby-images/bc737/bc7376055c9a2e1f19dd0a25848a750310553e09" alt=""
- Add a Backend
- Select Create Serverless Network Endpoint Group
data:image/s3,"s3://crabby-images/abebd/abebda5543d06bafce06c8cd808ea239216ab70c" alt=""
- Add a Name to the network endpoint group
- Select on the the Cloud Run service created on step 1
- Click on Create button
data:image/s3,"s3://crabby-images/3240f/3240f838324d78375ea4dacedef84d83e0cf2ffb" alt=""
- Now, back to the backend service, click on Create button
data:image/s3,"s3://crabby-images/f65a4/f65a49fa36f2c6760756a879b0104d8fc4185b02" alt=""
3 - Service Extensions
To protect the Load Balancer, create and configure a Service Extension which will call the Backend Service (step 2) and DataDome integration hosted on Cloud Run (step 1):
- Go to Service Extensions page
- Click on Create extension button
data:image/s3,"s3://crabby-images/4754d/4754d9502fc9294de1ecdc9ec88eff8ef39bc505" alt=""
- Click on Continue button
data:image/s3,"s3://crabby-images/cf2c3/cf2c36261e5f153ebb3fa06f55f5a208b465fa2b" alt=""
- Select the Load Balancer type
- Select a Region on the dropdown list
- Click on Continue button
data:image/s3,"s3://crabby-images/46aad/46aad90931a87bf0cc7a3b7e02ceb3d46033ff03" alt=""
- Add a Service Extension name
- Select the forwarding rule attached to the Load Balancer on the dropdown list
data:image/s3,"s3://crabby-images/a4da0/a4da0856fb7ecbc745cb19668c5d91170200bb84" alt=""
- Add a matching condition to trigger the Service Extension
- e.g.:
request.host != "example.com"
- e.g.:
- Add an Extension name and Authority
- Select the Backend service created on step 2
- Select the timeout of the Service Extension
- note: It should be higher than DataDome timeout
- Select Request headers and Response headers on Events dropdown list
- Check Enabled on Fail open
- Click on Create Extension button
data:image/s3,"s3://crabby-images/f46a5/f46a52f9606a1c621af2026226ce21c6d3607f89" alt=""
Settings
Setting | Description | Required | Default Value |
---|---|---|---|
DATADOME_SERVER_SIDE_KEY | DataDome server side key, found on the dashboard | yes | - |
DATADOME_ENDPOINT | Host of the API Server Available endpoints | no | api.datadome.co |
DATADOME_TIMEOUT | Timeout for regular API calls | no | 150 (in milliseconds) |
DATADOME_URL_PATTERN_INCLUSION | Regular expression to include URLs | no | - |
DATADOME_URL_PATTERN_EXCLUSION | Regular expression to exclude URLs | no | List of excluded static assets below |
"\\.(avi|flv|mka|mkv|mov|mp4|mpeg|mpg|mp3|flac|ogg|ogm|opus|wav|webm|webp|bmp|gif|ico|jpeg|jpg|png|svg|svgz|swf|eot|otf|ttf|woff|woff2|css|less|js|map|json)$"
Logging
The execution of this integration on Cloud Run automatically sends logs to Google Cloud Logging.
- To manage the logs, go to Google Cloud Logging
- Logs are stored in the
_Default
bucket - Log retention can be configured to control storage costs
- The default retention is 30 days
- To change it, click on the button on the right and select Edit Bucket
- Choose the Retention period (in days)
- Logs are stored in the
data:image/s3,"s3://crabby-images/57765/5776549585e7e4c93399d1f4c1092922d0868a2f" alt=""
data:image/s3,"s3://crabby-images/c0799/c0799c89ae8996a574417188a5dce2bfd927560e" alt=""
- Alerts can be set up to monitor bucket size and notify you of potential cost increases
- Click on Create Policy
- Select Global -> Logs-Based metrics
- Select the desired metric
data:image/s3,"s3://crabby-images/d5f70/d5f70607ad2d73efd0d63f94c4a40d10d74172d1" alt=""
data:image/s3,"s3://crabby-images/89df9/89df9767d6fc6eb12ebb8dfd022c5e7e5a3be082" alt=""
Updated 23 days ago