This page describes how to install version 0.1 of the GCP integration in a Kubernetes container, which is scheduled for deprecation.
To ingest metrics and/or logs from Google Cloud, you need to deploy a container on GKE (it also works on Google Autopilot). After it's deployed, you get metrics for services defined in the configmap, preset dashboards, and predefined alerts.
For complete observability of your workloads, be sure to set up generic log ingestion before installation. This requires additional configuration and a second container to forward the logs. See below for instructions.
If you are using Log Monitoring v1, enable the latest version of Dynatrace log monitoring.
Create a Pub/Sub topic and add a subscription to it. There are two ways to do this:
Set up a Pub/Sub topic and add a subscription to it.
When editing the subscription, we recommend the following values:
120
seconds1
dayRun the following shell script in the GCP project you've selected for deployment.
Be sure to replace <your-subscription-name>
and <your-topic-name>
with your own values.
wget https://raw.githubusercontent.com/dynatrace-oss/dynatrace-gcp-monitor/master/scripts/deploy-pubsub.shchmod +x deploy-pubsub.sh./deploy-pubsub.sh --topic-name <your-topic-name> --subscription-name <your-subscription-name>
Configure log export to send the desired logs to the GCP Pub/Sub topic created in Step 2.
If you choose to use an existing ActiveGate during deployment, configure ActiveGate for generic log ingestion.
To deploy the Dynatrace GCP Monitor in a Kubernetes container, you need to make sure the following GCP and Dynatrace requirements are met.
Running the deployment script requires a list of permissions. You can create a custom role (see below) and use it to deploy dynatrace-gcp-monitor
.
dynatrace-gcp-monitor-helm-deployment-role.yaml
with the following content:title: Dynatrace GCP Monitor helm deployment roledescription: Role for Dynatrace GCP Monitor helm and pubsub deploymentstage: GAincludedPermissions:- container.clusters.get- container.configMaps.create- container.configMaps.delete- container.configMaps.get- container.configMaps.update- container.deployments.create- container.deployments.delete- container.deployments.get- container.deployments.update- container.namespaces.create- container.namespaces.get- container.pods.get- container.pods.list- container.replicaSets.create- container.replicaSets.get- container.replicaSets.getScale- container.replicaSets.getStatus- container.replicaSets.list- container.secrets.create- container.secrets.delete- container.secrets.get- container.secrets.list- container.secrets.update- container.serviceAccounts.create- container.serviceAccounts.delete- container.serviceAccounts.get- container.services.create- container.services.delete- container.services.get- container.statefulSets.create- container.statefulSets.delete- container.statefulSets.get- container.statefulSets.update- iam.roles.create- iam.roles.list- iam.roles.update- iam.serviceAccounts.actAs- iam.serviceAccounts.create- iam.serviceAccounts.getIamPolicy- iam.serviceAccounts.list- iam.serviceAccounts.setIamPolicy- pubsub.subscriptions.create- pubsub.subscriptions.get- pubsub.subscriptions.list- pubsub.topics.attachSubscription- pubsub.topics.create- pubsub.topics.getIamPolicy- pubsub.topics.list- pubsub.topics.setIamPolicy- pubsub.topics.update- resourcemanager.projects.get- resourcemanager.projects.getIamPolicy- resourcemanager.projects.setIamPolicy- serviceusage.services.enable- serviceusage.services.get
<your_project_ID>
with the project ID where you want to deploy the dynatrace integration.gcloud iam roles create dynatrace_monitor.helm_deployment --project=<your_project_ID> --file=dynatrace-gcp-monitor-helm-deployment-role.yaml
Be sure to add this role to your GCP user.
If you run the deployment from GCP Cloud Shell, you don't need to install additional tools.
If you run the deployment from any host with bash, you need to install:
If you run the deployment on an existing GKE standard cluster, you need to:
If you run the deployment on an existing GKE Autopilot cluster, or on a new Autopilot cluster that will be automatically created by deployment script, there are no additional settings.
Review the requirements for ActiveGate and tokens as described below.
For ActiveGate, you have two options:
The requirements for API and PaaS tokens are as follows:
To install the GCP Monitor in a Kubernetes cluster, follow the instructions below.
Download the helm deployment package in Google Cloud Shell
Determine the URL for your environment
Configure parameter values
Connect your Kubernetes cluster
Run the script
Download and run the installation script below, making sure to replace <VERSION>
with the release version you want to download, for example 0.1.19
.
Be sure to choose one of the versions before release-1.0.0
, as the newer versions require different installation instructions.
wget -q "https://github.com/dynatrace-oss/dynatrace-gcp-monitor/releases/download/release-<VERSION>/helm-deployment-package.tar"; tar -xvf helm-deployment-package.tar; chmod +x helm-deployment-package/deploy-helm.sh
https://<your-environment-id>.live.dynatrace.com
https://<your-domain>/e/<your-environment-id>
https://<your-active-gate-IP-or-hostname>:9999/e/<your-environment-id>
To determine <your-environment-id>
, see environment ID.
The values.yaml
file located in helm-deployment-package/dynatrace-gcp-monitor
allows you to set the required and optional parameter values. See below for the complete list of parameters available for this integration.
gcpProjectId
deploymentType
all
dynatraceAccessKey
dynatraceUrl
logsSubscriptionId
optional
activeGate.useExisting
false
dynatraceLogIngestUrl
requireValidCertificate
true
, Dynatrace requires the SSL certificate of your Dynatrace environment.true
selfMonitoringEnabled
dynatrace-gcp-monitor
processes and sends metrics/logs to Dynatrace properly.false
dockerImage
dynatrace/dynatrace-gcp-monitor
logIngestContentMaxLength
8192
logIngestAttributeValueMaxLength
250
logIngestRequestMaxEvents
413
.5000
logIngestRequestMaxSize
413
.1048576
logIngestEventMaxAgeSeconds
86400
printMetricIngestInput
true
, the GCP Monitor outputs the lines of metrics to stdout.false
serviceUsageBooking
source
, monitoring API calls are booked in the project where the Kubernetes container is running. If set to destination
, monitoring API calls are booked in the project that is monitored. For details, see Monitor multiple GCP projects - Step 4.source
useProxy
DT_ONLY
), GCP API (set to GCP_ONLY
), or both (set to ALL
).httpProxy
USE_PROXY
.httpsProxy
USE_PROXY
.importDashboards
true
importAlerts
true
gcpServicesYaml
queryInterval
1
- 6
3
deploymentType
all
dynatraceAccessKey
dynatraceUrl
optional
requireValidCertificate
true
, Dynatrace requires the SSL certificate of your Dynatrace environment.true
selfMonitoringEnabled
dynatrace-gcp-monitor
processes and sends metrics/logs to Dynatrace properly.false
dockerImage
dynatrace/dynatrace-gcp-monitor
printMetricIngestInput
true
, the GCP Monitor outputs the lines of metrics to stdout.false
serviceUsageBooking
source
, monitoring API calls are booked in the project where the Kubernetes container is running. If set to destination
, monitoring API calls are booked in the project that is monitored. For details, see Monitor multiple GCP projects - Step 4.source
useProxy
DT_ONLY
), GCP API (set to GCP_ONLY
), or both (set to ALL
).httpProxy
USE_PROXY
.httpsProxy
USE_PROXY
.importDashboards
true
importAlerts
true
gcpServicesYaml
queryInterval
1
- 6
3
gcpProjectId
deploymentType
all
dynatraceAccessKey
dynatraceUrl
logsSubscriptionId
optional
activeGate.useExisting
false
dynatraceLogIngestUrl
requireValidCertificate
true
, Dynatrace requires the SSL certificate of your Dynatrace environment.true
selfMonitoringEnabled
dynatrace-gcp-monitor
processes and sends metrics/logs to Dynatrace properly.false
dockerImage
dynatrace/dynatrace-gcp-monitor
logIngestContentMaxLength
8192
logIngestAttributeValueMaxLength
250
logIngestRequestMaxEvents
413
.5000
logIngestRequestMaxSize
413
.1048576
logIngestEventMaxAgeSeconds
86400
--create-autopilot-cluster
to the script. No connection is needed in this case, because the deployment script will connect to the new cluster automatically.dynatrace-gcp-monitor
to your Kubernetes cluster.--create-autopilot-cluster
option, the script will automatically create the new GKE Autopilot cluster and deploy dynatrace-gcp-monitor
to it.To run the script, follow the instructions below.
To check whether installation was successful
Check if the container is running.
After the installation, it may take couple of minutes until the container is up and running.
kubectl -n dynatrace get pods
Check the container logs for errors or exceptions. You have two options:
Check if dashboards are imported (for deployments of type 'metrics' or 'all').
Go to Dashboards or Dashboards Classic (latest Dynatrace) and filter by Tag for Google Cloud. A number of dashboards for Google Cloud Services should be available.
After deploying the integration, depending on your deployment type, you can:
cloud.provider: gcp
.To investigate potential deployment and connectivity issues, see Troubleshoot Google Cloud monitoring setup.