Our Temporal Cloud integration monitors the performance of your Temporal Cloud data, helping you diagnose issues in your workflows, namespaces and scalable applications. Our Temporal Cloud integration gives you a pre-built dashboard with your most important Temporal Cloud metrics.
After setting up the integration with New Relic, see your data in dashboards like these, right out of the box.
Install the infrastructure agent
To use the Temporal Cloud integration, you need to first install the infrastructure agent on the same host. The infrastructure agent monitors the host itself, while the integration you'll install in the next step extends your monitoring with Temporal-specific data such as database and instance metrics.
Configure nri-flex
for Temporal Cloud
Once the Temporal Cloud metrics are exposed on the Prometheus endpoint, accessible via https://<account-id>.tmprl.cloud/prometheus
, you will need to configure your setup accordingly.
Note
Flex requires a New Relic account and is compatible with the following operating systems/platforms:
Linux
Windows
Kubernetes
For more information on compatible distros and versions, see the Infrastructure agent compatibility page.
Create file with named
nri-flex-temporal-cloud-config.yml
in this path:bash$touch /etc/newrelic-infra/integrations.d/Below is a
nri-flex
configuration file. Be sure to copy and paste its contents into your previously creatednri-flex-temporal-cloud-config.yml
file, and remember to update your account ID in the Prometheus endpoint URL, as well as the paths for the certificate files:integrations:- name: nri-flexconfig:name: temporalCloudIntegrationglobal:base_url: https://<your_account_id>.tmprl.cloud/prometheus/api/v1/headers:accept: application/jsontls_config:enable: truekey: /certs/client.keycert: /certs/client.peminterval: 60stimeout: 55sapis:- event_type: temporalCloudFrontendServiceError# sum(increase(temporal_cloud_v0_frontend_service_error_count[1m])) by (temporal_namespace,operation)url: query?query=sum%28increase%28temporal_cloud_v0_frontend_service_error_count%5B1m%5D%29%29%20by%20%28temporal_namespace%2Coperation%29split_array: trueleaf_array: true- event_type: temporalCloudFrontendServiceRequest# sum(increase(temporal_cloud_v0_frontend_service_request_count[1m])) by (temporal_namespace,operation)url: query?query=sum%28increase%28temporal_cloud_v0_frontend_service_request_count%5B1m%5D%29%29%20by%20%28temporal_namespace%2Coperation%29split_array: trueleaf_array: true- event_type: temporalCloudPollSuccess# sum(increase(temporal_cloud_v0_poll_success_count[1m])) by (temporal_namespace,operation,task_type)url: query?query=sum%28increase%28temporal_cloud_v0_poll_success_count%5B1m%5D%29%29%20by%20%28temporal_namespace%2Coperation%2Ctask_type%29split_array: trueleaf_array: true- event_type: temporalCloudPollSuccessSync# sum(increase(temporal_cloud_v0_poll_success_sync_count[1m])) by (temporal_namespace,operation,task_type)url: query?query=sum%28increase%28temporal_cloud_v0_poll_success_sync_count%5B1m%5D%29%29%20by%20%28temporal_namespace%2Coperation%2Ctask_type%29split_array: trueleaf_array: true- event_type: temporalCloudPollTimeout# sum(increase(temporal_cloud_v0_poll_timeout_count[1m])) by (temporal_namespace,operation,task_type)url: query?query=sum%28increase%28temporal_cloud_v0_poll_timeout_count%5B1m%5D%29%29%20by%20%28temporal_namespace%2Coperation%2Ctask_type%29split_array: trueleaf_array: true- event_type: temporalCloudResourceExhaustedErrors# sum(increase(temporal_cloud_v0_resource_exhausted_error_count[1m])) by (temporal_namespace,resource_exhausted_cause)url: query?query=sum%28increase%28temporal_cloud_v0_resource_exhausted_error_count%5B1m%5D%29%29%20by%20%28temporal_namespace%2Cresource_exhausted_cause%29split_array: trueleaf_array: true- event_type: temporalCloudScheduleActionSuccess# sum(increase(temporal_cloud_v0_schedule_action_success_count[1m])) by (temporal_namespace)url: query?query=sum%28increase%28temporal_cloud_v0_schedule_action_success_count%5B1m%5D%29%29%20by%20%28temporal_namespace%29split_array: trueleaf_array: true- event_type: temporalCloudScheduleBufferOverruns# sum(increase(temporal_cloud_v0_schedule_buffer_overruns_count[1m])) by (temporal_namespace)url: query?query=sum%28increase%28temporal_cloud_v0_schedule_buffer_overruns_count%5B1m%5D%29%29%20by%20%28temporal_namespace%29split_array: trueleaf_array: true- event_type: temporalCloudScheduleMissedCatchupWindow# sum(increase(temporal_cloud_v0_schedule_missed_catchup_window_count[1m])) by (temporal_namespace)url: query?query=sum%28increase%28temporal_cloud_v0_schedule_missed_catchup_window_count%5B1m%5D%29%29%20by%20%28temporal_namespace%29split_array: trueleaf_array: true- event_type: temporalCloudScheduleRateLimited# sum(increase(temporal_cloud_v0_schedule_rate_limited_count[1m])) by (temporal_namespace)url: query?query=sum%28increase%28temporal_cloud_v0_schedule_rate_limited_count%5B1m%5D%29%29%20by%20%28temporal_namespace%29split_array: trueleaf_array: true- event_type: temporalCloudStateTransition# sum(increase(temporal_cloud_v0_state_transition_count[1m])) by (temporal_namespace)url: query?query=sum%28increase%28temporal_cloud_v0_state_transition_count%5B1m%5D%29%29%20by%20%28temporal_namespace%29split_array: trueleaf_array: true- event_type: temporalCloudTotalAction# sum(increase(temporal_cloud_v0_total_action_count[1m])) by (temporal_namespace, namespace_mode)url: query?query=sum%28increase%28temporal_cloud_v0_total_action_count%5B1m%5D%29%29%20by%20%28temporal_namespace%2C%20namespace_mode%29split_array: trueleaf_array: true- event_type: temporalCloudWorkflowCancel# sum(increase(temporal_cloud_v0_workflow_cancel_count[1m])) by (temporal_namespace, operation)url: query?query=sum%28increase%28temporal_cloud_v0_workflow_cancel_count%5B1m%5D%29%29%20by%20%28temporal_namespace%2C%20operation%29split_array: trueleaf_array: true- event_type: temporalCloudWorkflowContinued# sum(increase(temporal_cloud_v0_workflow_continued_as_new_count[1m])) by (temporal_namespace, operation)url: query?query=sum%28increase%28temporal_cloud_v0_workflow_continued_as_new_count%5B1m%5D%29%29%20by%20%28temporal_namespace%2C%20operation%29split_array: trueleaf_array: true- event_type: temporalCloudWorkflowFailed# sum(increase(temporal_cloud_v0_workflow_failed_count[1m])) by (temporal_namespace, operation)url: query?query=sum%28increase%28temporal_cloud_v0_workflow_failed_count%5B1m%5D%29%29%20by%20%28temporal_namespace%2C%20operation%29split_array: trueleaf_array: true- event_type: temporalCloudWorkflowSuccess# sum(increase(temporal_cloud_v0_workflow_success_count[1m])) by (temporal_namespace, operation)url: query?query=sum%28increase%28temporal_cloud_v0_workflow_success_count%5B1m%5D%29%29%20by%20%28temporal_namespace%2C%20operation%29split_array: trueleaf_array: true- event_type: temporalCloudWorkflowTerminate# sum(increase(temporal_cloud_v0_workflow_terminate_count[1m])) by (temporal_namespace, operation)url: query?query=sum%28increase%28temporal_cloud_v0_workflow_terminate_count%5B1m%5D%29%29%20by%20%28temporal_namespace%2C%20operation%29split_array: trueleaf_array: true- event_type: temporalCloudWorkflowTimeout# sum(increase(temporal_cloud_v0_workflow_timeout_count[1m])) by (temporal_namespace, operation)url: query?query=sum%28increase%28temporal_cloud_v0_workflow_timeout_count%5B1m%5D%29%29%20by%20%28temporal_namespace%2C%20operation%29split_array: trueleaf_array: true- event_type: temporalCloudWorkflowExecutionLatencySecP95# histogram_quantile(0.95, sum(rate(temporal_cloud_v0_service_latency_bucket[1m] offset 1m)) by (temporal_namespace, operation, le))url: query?query=histogram_quantile%280.95%2C%20sum%28rate%28temporal_cloud_v0_service_latency_bucket%5B1m%5D%20offset%201m%29%29%20by%20%28temporal_namespace%2C%20operation%2C%20le%29%29split_array: trueleaf_array: true- event_type: temporalCloudReplicationLagSecP95# histogram_quantile(0.95, sum(rate(temporal_cloud_v0_replication_lag_bucket[1m] offset 1m)) by (temporal_namespace, le))url: query?query=histogram_quantile%280.95%2C%20sum%28rate%28temporal_cloud_v0_replication_lag_bucket%5B1m%5D%20offset%201m%29%29%20by%20%28temporal_namespace%2C%20le%29%29split_array: trueleaf_array: trueUse our instructions to restart your infrastructure agent:
bash$sudo systemctl restart newrelic-infra.serviceWait a few minutes until data starts folowing into your New Relic account.
Find your data
You can choose our pre-built dashboard template named Temporal Cloud to monitor your Temporal Cloud metrics. Follow these steps to use our pre-built dashboard template:
From one.newrelic.com, go to the + Integrations & Agents page.
Click on Dashboards.
In the search bar, type Temporal Cloud.
The Temporal Cloud dashboard should appear. Click on it to install it.
Your Temporal Cloud dashboard is considered a custom dashboard and can be found in the Dashboards UI. For docs on using and editing dashboards, see our dashboard docs.
Here is a NRQL query to check the Temporal Cloud frontend service requests count:
FROM temporalCloudFrontendServiceRequest SELECT latest(`data.result-value1`) FACET `data.result-metric-__name__`
What's next?
To learn more about building NRQL queries and generating dashboards, check out these docs:
- Introduction to the query builder to create basic and advanced queries.
- Introduction to dashboards to customize your dashboard and carry out different actions.
- Manage your dashboard to adjust your dashboards display mode, or to add more content to your dashboard.