﻿---
title: Create monitors in the Synthetics UI
description: You can create synthetic monitors directly in the UI by opening an Observability project and navigating to Synthetics. This is one of two approaches you...
url: https://www.elastic.co/elastic/docs-builder/docs/3028/solutions/observability/synthetics/create-monitors-ui
products:
  - Elastic Cloud Serverless
  - Elastic Observability
applies_to:
  - Elastic Cloud Serverless: Generally available
  - Elastic Stack: Generally available
---

# Create monitors in the Synthetics UI
You can create synthetic monitors directly in the UI by opening an Observability project and navigating to **Synthetics**.
![Diagram showing which pieces of software are used to configure monitors](https://www.elastic.co/elastic/docs-builder/docs/3028/solutions/images/observability-synthetics-get-started-ui.png)

This is one of [two approaches](https://www.elastic.co/elastic/docs-builder/docs/3028/solutions/observability/synthetics/get-started) you can use to set up a synthetic monitor.

## Prerequisites

For **serverless Observability projects**, you must be signed in as a user with [Editor](https://www.elastic.co/elastic/docs-builder/docs/3028/solutions/observability/synthetics/grant-access-to-secured-resources) access.
For **Elastic Stack deployments**, you must be signed into Kibana as a user with at least [synthetics write permissions](https://www.elastic.co/elastic/docs-builder/docs/3028/solutions/observability/synthetics/writer-role), and Monitor Management must be enabled by an administrator as described in [Setup role](https://www.elastic.co/elastic/docs-builder/docs/3028/solutions/observability/synthetics/setup-role).
You should decide where you want to run the monitors before getting started. You can run monitors on one or both of the following:
- **Elastic’s global managed testing infrastructure**: With Elastic’s global managed testing infrastructure, you can create and run monitors in multiple locations without having to manage your own infrastructure. Elastic takes care of software updates and capacity planning for you.
- **Private Locations**: Private Locations allow you to run monitors from your own premises. To use Private Locations you must create a Private Location before continuing. For step-by-step instructions, refer to [Monitor resources on private networks](https://www.elastic.co/elastic/docs-builder/docs/3028/solutions/observability/synthetics/monitor-resources-on-private-networks).

Executing synthetic tests on Elastic’s global managed testing infrastructure incurs an additional charge. Tests are charged under one of two new billing dimensions depending on the monitor type. For *browser monitor* usage, there is a fee per test run. For *lightweight monitor* usage, there is a fee per region in which you run any monitors regardless of the number of test runs. For more details, refer to the [Elastic Observability Serverless pricing page](https://www.elastic.co/pricing/serverless-observability).

## Add a lightweight monitor

To use the UI to add a lightweight monitor:
1. Find `Synthetics` in the [global search field](https://www.elastic.co/elastic/docs-builder/docs/3028/explore-analyze/find-and-organize/find-apps-and-objects).
2. Click **Create monitor**.
3. Set the monitor type to **HTTP Ping**, **TCP Ping**, or **ICMP Ping**.
4. In *Locations*, select one or more locations.
   <note>
   If you don’t see any locations listed, refer to the [troubleshooting guide](/elastic/docs-builder/docs/3028/troubleshoot/observability/troubleshooting-synthetics#synthetics-troubleshooting-no-locations) for guidance.
   </note>
   <note>
   If you’ve [added a Private Location](https://www.elastic.co/elastic/docs-builder/docs/3028/solutions/observability/synthetics/monitor-resources-on-private-networks), you’ll see your the Private Location in the list of *Locations*.
   ![Screenshot of Monitor locations options including a Private Location](https://www.elastic.co/elastic/docs-builder/docs/3028/solutions/images/serverless-private-locations-monitor-locations.png)
   </note>
5. Set the *Frequency*, and configure the monitor as needed.
6. Click **Advanced options** to see more ways to configure your monitor.
   <applies-to>Elastic Stack: Generally available since 9.1</applies-to> In **Advanced options**, use **Spaces** to select which [Kibana spaces](https://www.elastic.co/elastic/docs-builder/docs/3028/deploy-manage/manage-spaces) the monitor will be visible in. You can select multiple spaces or choose to make the monitor visible in all spaces.
7. (Optional) Click **Run test** to verify that the test is valid.
8. Click **Create monitor**.
   ![Synthetics Create monitor UI](https://www.elastic.co/elastic/docs-builder/docs/3028/solutions/images/observability-synthetics-get-started-ui-lightweight.png)


## Add a browser monitor

You can also create a browser monitor in the UI using an **Inline script**.
An inline script contains a single journey that you manage individually. Inline scripts can be quick to set up, but can also be more difficult to manage. Each browser monitor configured using an inline script can contain only *one* journey, which must be maintained directly in the UI.
If you depend on external packages, have your journeys next to your code repository, or want to embed and manage more than one journey from a single monitor configuration, use a [Synthetics project](https://www.elastic.co/elastic/docs-builder/docs/3028/solutions/observability/synthetics/create-monitors-with-projects) instead.
To use the UI to add a browser monitor:
1. Click **Create monitor**.
2. Set the monitor type to **Multistep**.
3. In *Locations*, select one or more locations.
   <note>
   If you don’t see any locations listed, refer to the [troubleshooting guide](/elastic/docs-builder/docs/3028/troubleshoot/observability/troubleshooting-synthetics#synthetics-troubleshooting-no-locations) for guidance.
   </note>
4. Set the *Frequency*.
5. Add steps to the **Script editor** code block directly. The `journey` keyword isn’t required, and variables like `page` and `params` will be part of your script’s scope. You cannot `import` any dependencies when using inline browser monitors.
   ![Configure a synthetic monitor using an inline script in Elastic Fleet](https://www.elastic.co/elastic/docs-builder/docs/3028/solutions/images/observability-synthetics-ui-inline-script.png)
   <note>
   Alternatively, you can use the **Script recorder** option. You can use the Elastic Synthetics Recorder to interact with a web page, export journey code that reflects all the actions you took, and upload the results in the UI. For more information, refer to [Use the Synthetics Recorder](https://www.elastic.co/elastic/docs-builder/docs/3028/solutions/observability/synthetics/use-synthetics-recorder).
   </note>
6. Click **Advanced options** to see more ways to configure your monitor.
   - Use **Data options** to add context to the data coming from your monitors.
- Use **Maintenance windows** to prevent alerts from being triggered during scheduled downtime.
- Use the **Synthetics agent options** to provide fine-tuned configuration for the synthetics agent. Read more about available options in [Use the Synthetics CLI](https://www.elastic.co/elastic/docs-builder/docs/3028/solutions/observability/synthetics/cli).
- <applies-to>Elastic Stack: Generally available since 9.1</applies-to> Use **Spaces** to select which [Kibana spaces](https://www.elastic.co/elastic/docs-builder/docs/3028/deploy-manage/manage-spaces) the monitor will be visible in. You can select multiple spaces or choose to make the monitor visible in all spaces.
7. (Optional) Click **Run test** to verify that the test is valid.
8. Click **Create monitor**.


## View in your Observability project

Navigate to **Synthetics**, where you can see screenshots of each run, set up alerts in case of test failures, and more.
If a test does fail (shown as `down` in the Synthetics UI), you’ll be able to view the step script that failed, any errors, and a stack trace. For more information, refer to [Analyze data from synthetic monitors](/elastic/docs-builder/docs/3028/solutions/observability/synthetics/analyze-data#synthetics-analyze-journeys).
<note>
  When a monitor is created or updated, the first run might not occur immediately, but the time it takes for the first run to occur will be less than the monitor’s configured frequency. For example, if you create a monitor and configure it to run every 10 minutes, the first run will occur within 10 minutes of being created. After the first run, the monitor will begin running regularly based on the configured frequency. You can run a manual test if you want to see the results more quickly.
</note>


## Next steps

Learn more about:
- [Writing user journeys](https://www.elastic.co/elastic/docs-builder/docs/3028/solutions/observability/synthetics/write-synthetic-test) to use as inline scripts
- Using the [Synthetics Recorder](https://www.elastic.co/elastic/docs-builder/docs/3028/solutions/observability/synthetics/use-synthetics-recorder)
- [Configuring lightweight monitors](https://www.elastic.co/elastic/docs-builder/docs/3028/solutions/observability/synthetics/configure-lightweight-monitors)