Creates a new synthetic monitor.
The configuration of the new monitor is passed via its JSON script.
POST | SaaS | https://{your-environment-id}.live.dynatrace.com/api/v1/synthetic/monitors |
Environment ActiveGate | https://{your-activegate-domain}:9999/e/{your-environment-id}/api/v1/synthetic/monitors |
To execute this request, you need an access token with ExternalSyntheticIntegration
scope.
To learn how to obtain and use it, see Tokens and authentication.
To find all model variations that depend on the type of the model, see JSON models.
The JSON body of the request, containing parameters of the new synthetic monitor.
SyntheticMonitorUpdate
objectThe synthetic monitor update.
The actual set of fields depends the type of the monitor. Find the list of actual objects in the description of the type field or see Synthetic monitors API - JSON models.
The monitor is enabled (true
) or disabled (false
).
The frequency of the monitor, in minutes.
You can use one of the following values: 5
, 10
, 15
, 30
, and 60
.
A list of locations from which the monitor is executed.
To specify a location, use its entity ID.
A set of manually assigned applications.
The name of the monitor.
A set of tags assigned to the monitor.
You can specify only the value of the tag here and the CONTEXTLESS
context and source 'USER' will be added automatically. But preferred option is usage of TagWithSourceDto model.
Defines the actual set of fields depending on the value. See one of the following objects:
BROWSER
-> BrowserSyntheticMonitorUpdateHTTP
-> HttpSyntheticMonitorUpdateBROWSER
HTTP
AnomalyDetection
objectThe anomaly detection configuration.
LoadingTimeThresholdsPolicyDto
objectPerformance thresholds configuration.
Performance threshold is enabled (true
) or disabled (false
).
LoadingTimeThreshold
objectThe performance threshold rule.
Specify the event to which an ACTION threshold applies.
Specify the request to which an ACTION threshold applies.
The type of the threshold: total loading time or action loading time.
ACTION
TOTAL
Notify if monitor takes longer than X milliseconds to load.
OutageHandlingPolicy
objectOutage handling configuration.
When enabled (true
), generate a problem and send an alert when the monitor is unavailable at all configured locations.
When enabled (true
), generate a problem and send an alert when the monitor is unavailable for one or more consecutive runs at any location.
Local outage handling configuration.
Alert if affectedLocations of locations are unable to access the web application consecutiveRuns times consecutively.
Schedule retry if browser monitor execution results in a fail. For HTTP monitors this property is ignored.
GlobalOutagePolicy
objectGlobal outage handling configuration.
Alert if all locations are unable to access the web application X times consecutively.
LocalOutagePolicy
objectLocal outage handling configuration.
Alert if affectedLocations of locations are unable to access the web application consecutiveRuns times consecutively.
The number of affected locations to trigger an alert.
The number of consecutive fails to trigger an alert.
TagWithSourceInfo
objectTag with source of a Dynatrace entity.
The origin of the tag, such as AWS or Cloud Foundry.
Custom tags use the CONTEXTLESS
value.
AWS
AWS_GENERIC
AZURE
CLOUD_FOUNDRY
CONTEXTLESS
ENVIRONMENT
GOOGLE_CLOUD
KUBERNETES
The key of the tag.
Custom tags have the tag value here.
The source of the tag, such as USER, RULE_BASED or AUTO
AUTO
RULE_BASED
USER
The value of the tag.
Not applicable to custom tags.
This is a model of the request body, showing the possible elements. It has to be adjusted for usage in an actual request.
{"anomalyDetection": {"loadingTimeThresholds": {"enabled": true,"thresholds": [{"requestIndex": 1,"type": "TOTAL","valueMs": 100}]},"outageHandling": {"globalOutage": true,"localOutage": true,"localOutagePolicy": {"affectedLocations": 1,"consecutiveRuns": 3}}},"enabled": true,"events": [],"frequencyMin": 5,"keyPerformanceMetrics": {"loadActionKpm": "VISUALLY_COMPLETE","xhrActionKpm": "VISUALLY_COMPLETE"},"locations": ["GEOLOCATION-9999453BE4BDB3CD"],"manuallyAssignedApps": ["APPLICATION-4ADF0EF407C7C545"],"name": "Browser Monitor Example","script": {"configuration": {"device": {"deviceName": "Desktop","orientation": "landscape"}},"events": [{"description": "Loading of \"example.com\"","type": "navigate","url": "http://example.com","wait": {"waitFor": "page_complete"}}],"type": "availability","version": "1.0"},"tags": ["example"],"type": "BROWSER"}
Success. The new synthetic monitor has been created. The response contains the Dynatrace entity ID of the new monitor.
EntityIdDto
objectA DTO for entity ID.
Entity ID to be transferred
{"entityId": "string"}
In this example, the request creates a simple browser monitor that navigates to dynatrace.com.
The monitor is executed every 10 minutes from one location, which has the ID of GEOLOCATION-0A41430434C388A9. A problem will be raised if the website is unavailable for three consecutive runs. A notification is sent if the website takes longer than 500 milliseconds to load.
The API token is passed in the Authorization header.
The response contains the entity ID of the newly created monitor.
Since the request body is lengthy, it is truncated in this example Curl section. See the full body in the Request body section. You can download or copy the example request body to try it out on your own. Before using it, make sure that the location from the example is available in your environment. You can fetch the list of available locations with the GET all synthetic locations call. If the location is not available, replace it with any location you're using.
curl -X POST \https://mySampleEnv.live.dynatrace.com/api/v1/synthetic/monitors \-H 'Authorization: Api-Token dt0c01.abc123.abcdefjhij1234567890' \-H 'Content-Type: application/json' \-d '{<truncated - see the Request body section >}'
https://mySampleEnv.live.dynatrace.com/api/v1/synthetic/monitors
{"frequencyMin": 10,"anomalyDetection": {"outageHandling": {"globalOutage": true,"localOutage": false,"localOutagePolicy": {"affectedLocations": 1,"consecutiveRuns": 3}},"loadingTimeThresholds": {"enabled": true,"thresholds": [{"type": "total","valueMs": 500}]}},"type": "BROWSER","name": "restExample","locations": ["GEOLOCATION-0A41430434C388A9"],"enabled": true,"script": {"configuration": {"device": {"orientation": "landscape","deviceName": "Desktop"}},"type": "clickpath","version": "1.0","events": [{"type": "navigate","wait": {"waitFor": "page_complete"},"description": "navigate to main page ","url": "https://www.dynatrace.com"}]},"tags": ["restExample"]}
{"entityId": "SYNTHETIC_TEST-00000000000254E2"}
200