Event Orchestration Examples

Event Orchestration is a highly customizable suite of features and capabilities. The examples on this page are taken from real-world customer use cases, which you're welcome to replicate in your own PagerDuty account.

We have included the following examples to assist you with your own orchestrations:

If Events Match Certain Conditions

In this example, we will create a routing rule that routes events to a service when matching conditions are met.

  1. Create a routing rule and, under When should events be routed here?, select If events match certain conditions.
  2. Indicate the event conditions that you would like the orchestration to match using one of the following methods:
MethodDescription
Base conditions on incoming JSONDepending on your account's activity, you may have recent events appear on the right side of the screen if events have been sent to the incoming event source. View these events to determine which values to use.
Events sent through the APIYou will use the JSON field names directly (e.g., summary). For nested fields, separate names with a dot (.) (e.g., payload.taskid). If you are sending data through additional fields, enter them exactly as they are sent to PagerDuty. For example, if your events have a tags field, enter that field name in your rule condition as tags.
Events sent through emailNote: The following functionality will only work when you send emails to a global email integration address. It will not work for emails sent directly to a service-level email integration.

Rules may be based on the content of an email by entering the appropriate email field as custom details in the event field. The email subject will be used as a default deduplication key. In other words, emails with the same subject line will automatically be deduplicated. To change this behavior, add a custom deduplication key with an orchestration rule action.

The most common email fields are:

-event.custom_details.from[0](the from address).*

- event.custom_details.subject (the subject line)**
- event.custom_details.plain_body (the email body)


*The [0] refers to the 1st position in a list of emails. If you would like to generally search through a list of emails (either in the to field or the from field), please enter event.custom_details.from or event.custom_details.to.

**For email-generated events, the field event.summary is populated with the same value as event.custom_details.subject (the email subject) by default. However, these are separate fields and their values may differ based on customer-specified configurations.
Configure routing rule

Configure routing rule

  1. In the middle dropdown, select how the event should be filtered.
Filter OptionsDescription
- matches part

- does not match part
The field contains/does not contain a value.
- matches

- does not match
The field equals/does not equal a value (this operation requires the field to be passed in as a string).
- exists

- does not exist
The field exists/does not exist.
- matches regex

- does not match regex
The field matches/does not match a regular expression. Regular expressions must use RE2 syntax.

📘

Negative Operations

Rules with negative operations, such as does not contain or does not equal, will match events that do not contain your specified value and events that do not contain the field at all. As an example:

  • severity field does not equal critical
    • This will match events where the severity field does not equal critical and events that do not contain a severity field at all.

If you'd like to avoid this, you must add an additional condition that matches only when the field exists. For example:

When all conditions are true:

  • severity field exists
  • severity field does not equal critical

Note: You must select all conditions must be true for the rule to match.

  1. In the second value field, input the value that should be met from the payload. This can be a string or regular expression.

📘

Case Sensitivity

Condition values in Event Orchestrations are case-insensitive.

For example, if a condition is set with Summary matches part DOWN, this will match if the Summary contains Down, down and other variations of the word.

  1. When additional conditions should be added, use the following options:
  • + And: Additional conditions should be met.
  • + New Condition: Create another set of conditions that should be met. A new condition block creates an OR operator of conditions that will also be evaluated alongside other blocks.
  1. Click Save to save your configuration.

📘

Condition Limits

You can create up to 25 condition blocks within a rule, and you can have up to 64 operators (i.e., AND, OR), or a maximum of 2048 bytes (e.g., if you're using PCL) in a single condition block.

On a Recurring Weekly Schedule

📘

Availability

Scheduled conditions are available with Advanced Event Orchestration.

In this example, we will create a routing rule that routes events to a service on a weekly recurring schedule.

  1. Create a routing rule and, under When should events be routed here?, select On a recurring weekly schedule.
  2. Enter appropriate times for Start and End, select your preferred Days of the week, and pick your Timezone.
  3. Click Save.

Advanced Configuration with the and Operator

📘

Availability

Scheduled and threshold conditions are available with Advanced Event Orchestration.

This example details how to edit PCL to create an advanced condition that the UI does not natively allow for.

If you select one of the following options for When should events be routed here?, the UI does not offer a way to set an and condition:

  • On a recurring weekly schedule
  • During a scheduled date range
  • Depends on event frequency

You can work around this, however, by directly editing the PagerDuty Condition Language (PCL).

Say you'd like to route events to a service when the following conditions are met:

  • The event's source matches mainframe.
  • It is Wednesday or Sunday between 11:00 a.m. and 12:00 p.m. Eastern.

The following PCL statement will meet these conditions: event.source matches 'mainframe' and now in Wed,Sun 11:00:00 to 12:00:00 America/New_York.

Capture Unrouted Trigger Events

Orchestration service routes include a catch all rule for events that do not match the configured rules. The default behavior creates a suppressed alert from unrouted trigger events, however, you have the ability to route these events to a specific service instead. It is important to note that in order to support event deduplication across all services, the ability to resolve any open alert previously created by the orchestration when a matching dedup_key exists, regardless of what service the open alert belongs to.

In this example, we will create a routing rule that uses these trigger events to create incidents on a catch all service.

  1. Create a routing rule and, under What service should events route to?, select the service you’d like to use as a catch all for these events.
  2. Under When should events be routed here?, select If events match certain conditions. Configure the following condition:
    • If event.event_action matches part (contains) trigger
  3. Click Save.
  4. If necessary, reorder the rule so that it is directly above the default catch all rule.
Routing rule for trigger events

Routing rule for trigger events

This configuration can raise the visibility for trigger events that do not match the existing routing rules while also preserving the default resolve behavior described above.

Standardized Triage

📘

Availability

Global Orchestrations, incident suppression and variables are available with Advanced Event Orchestration.

Use Global Orchestration rules to standardize the triage process across your entire organization.

  1. Create a Global Orchestration. You will send your events to the orchestration’s integration.
  2. Create an Event Count Cache Variable. You can use this to count the number of specific events received within a designated timeframe.
  3. Create a rule with an event condition to suppress any known false positive events:
    1. Under When should events be routed here?, select If events match certain conditions.
    2. Define a condition that will match to your false positive events. E.g., If event.summary matches part (contains) [No error]. Then click Next.
    3. Under What action(s) should be applied?, select Suppress incident and notifications.
    4. Click Save.
  4. Create an Else rule with an event condition to evaluate the current cache variable count.
    1. Under When should events be routed here?, select If events match certain conditions.
    2. In the field selector, choose Cache Variable and add your cache variable’s name. Configure your desired threshold for when an incident should be created. E.g., If cache_var.myEventCount is greater than or equal 2. Then click Next.
    3. Under What action(s) should be applied?, you can choose your desired priority and/or severity level for these incidents.
    4. Click Save.
  5. Create a final Else rule to set a lower priority and/or severity for incidents that do not pass the event count threshold set in the previous rule:
    1. Under When should events be routed here?, select Always (for all events) and click Next.
    2. Under What action(s) should be applied?, you can choose your desired priority and/or severity level for these incidents.
    3. Click Save.
Standardized triage example

Standardized triage example

With this configuration in place, any event sent to the global orchestration will be evaluated by these rules. If the event is a false positive and matches the condition you set in step 3, it will automatically be suppressed and will not create an incident.

If the event does not meet that condition, it will increment the cache variable count, be routed to a service, and then create an incident on that service. The current event count for the cache variable will determine whether the incident has a high or low priority and/or severity.

Notification Management for Specific Incidents

📘

Availability

Dynamic Escalation Policy Assignment is available with Advanced Event Orchestration.

Leverage Dynamic Escalation Policy Assignment to notify a Subject Matter Expert (SME) instead of the current on-call user when an incident requires a special skill set to resolve.

  1. Create an escalation policy with the SME user in the first level.
    1. If the SME should be on-call 24/7, you can add them as a user target. Otherwise, you can create a schedule to define what hours the user should be on-call for.
  2. In your global orchestration, create the following rule:
    1. Under When should events be routed here?, select If events match certain conditions.
    2. Define a condition that will match to events that indicate a specific SME should be notified instead of the current on-call user. E.g., If event.summary matches part (contains) Database error. Then click Next.
  3. Under What action(s) should be applied?, locate Override service's assigned escalation policy with this policy and select your desired escalation policy from the dropdown.
  4. Click Save.
Override escalation policy with SME

Override escalation policy with SME

When the orchestration receives an event that matches the condition, the escalation policy chosen will be used for the incident, regardless of which service the event is routed to.

Route Alerts with Dynamic Service Routes

📘

Availability

Dynamic routing, dynamic field enrichment and extraction and variables are available with Advanced Event Orchestration.

Utilize the powers of Global Orchestrations to standardize the event format in order to automatically route events to the correct service with a dynamic routing rule.

An orchestration’s dynamic routing rule evaluates all events and does not have conditions. Rather, dynamic routing rules are able to route events to services based on the Service name or Service ID included within the payload. If service details are not included in your initial payload, you can update the payload with dynamic field enrichment and extraction.

  1. In your global orchestration, create a rule with the following actions:
    1. Create a rule variable and use regex to extract the desired value from an event field.
    2. Create an event field (e.g., custom_details.service_route) and use the rule variable you created to set the value.
  2. In your global orchestration, navigate to the Service Routes tab.
  3. Create a new dynamic route and enter the event field you created in step 1.
Dynamic routing rule

Dynamic routing rule

When the orchestration receives an event with a valid service name in the event field, it will automatically route it to that service. The event can be processed further by the service’s orchestration rules if desired.

Automated Remediation for Specific Incidents

📘

Availability

This example utilizes Automation Actions, which are available for Business, Enterprise for Incident Management and Digital Operations (Legacy) plans that meet the following criteria:

  • Business Plans: Accounts must have the PagerDuty AIOps and PagerDuty Automation Actions add-ons, as well as Advanced Event Orchestration.
  • Enterprise for Incident Management and Digital Operations (Legacy) Plans: Accounts must have the PagerDuty Automation Actions add-on and Advanced Event Orchestration.

Please contact our Sales team if you are interested in PagerDuty AIOps, and you may fill out this form if you are interested in Automation Actions.

You can pause notifications and suspend alerts for a set duration and simultaneously trigger a remediation automation with an Automation Action. If the automation successfully resolves the issue, an incident will not trigger. If the pause duration expires without a resolution, the incident will trigger as normal. You can configure this within a service orchestration by following the steps below.

  1. In your service orchestration, create a rule with your desired conditions.
  2. Under Basic Event, enable Pause notifications. Enter a value (in seconds) for Suspend alert for ___ seconds before triggering an incident. We recommend setting a pause duration that is long enough for your entire automation to complete.
  3. Under Automation Automation Actions, enable Use Automation Actions if an event reaches this rule.
  4. For When should we run this Action?, select Automatically when Alert is suspended/paused.
  5. For Automated Action, select your configured Automation Action .
Configured actions for auto remediation

Configured actions for auto remediation

Disable System Auto Resolve for High Priority Incidents

Ensure a human and not an automated system event is responsible for resolving all high priority incidents by automatically blocking resolve events for specific incidents.

  1. Create a Custom Field. which will use event data in the incident workflow.
  2. Create a Cache Variable in your desired orchestration.
    1. For the Type, choose External Data.
    2. For Data Format, choose Text String.
  3. Within your orchestration, create a new rule with the following:
    1. In Step 1: When should this rule be applied?, select If events match certain conditions.
      1. Using the Cache Variable you created, create the following condition using the Advanced PCL condition editor: not cache_var.your_new_cache_variable matches part event.dedup_key
    2. In Step 2: What action(s) should be applied?, select Custom Fields Add Custom Incident Field.
      1. Under Custom field to set, select the Custom Field you created earlier. For Replace with value, enter event.dedup_key.
    3. Click Save.
  4. Create an ELSE rule with the following:
    1. In Step 1: When should this rule be applied?, select Always (for all events).
    2. In Step 2: What action(s) should be applied?, select Alert Data. Enable the Always trigger an alert option.
    3. Click Save.
  5. Create an Incident Workflow which will prevent auto resolves for matching incidents.
    1. Click Add Trigger and select Conditional trigger. Configure the trigger as follows:
      1. When should this Workflow start?: Select When conditions are met.
      2. Create the following condition using the Advanced PCL condition editor: incident.priority matches 'P1' and not incident.custom_fields.your_custom_field == ''
      3. Click Save.
    2. Click Add Action. Select Append to a Cache Variable value and follow the steps in our Workflow Actions article to configure this action.
      1. Enter your custom field in the Value field for this action.
  6. Create a second Incident Workflow which will remove the Cache Variable's current value once the incident is resolved:
    1. Click Add Trigger and select Conditional trigger. Configure the trigger as follows:
      1. When should this Workflow start?: Select When conditions are met.
      2. All of the following conditions must be met: Create two conditions:
        1. Status matches Resolved and
        2. Resolve Reason Does not match merge
      3. Click Save.
    2. Click Add Action. Select Remove from a Cache Variable value and follow the steps in our Workflow Actions article to configure this action.
      1. Enter your custom field in the Value field for this action.

Track Event Spikes with Cache Variables

📘

Availability

Cache Variables and threshold conditions are available with Advanced Event Orchestration.

Use Cache Variables to count events over a rolling time window and an event orchestration rule to trigger an incident when the count exceeds your defined threshold.

Step 1: Create a Cache Variable

  1. In your orchestration, click View Cache Variables.
  2. In the Cache Variables side panel, click + Variable.
  3. For Variable Type, select Event Count.
  4. Enter a descriptive Name, for example: event_spike_threshold.
  5. For Count matching events over the last, enter the window you want to count events with a maximum of 86400( 24 hours). Choose a duration that reflects your normal event cadence.
  6. For When should this variable be updated?, select Always (for all events).
  7. Click Save.

👍

Tips

  • Shorter windows (e.g., 60–300 seconds) help detect bursty spikes; longer windows (e.g., 1800–3600 seconds) help detect sustained increases.
  • You can create multiple Event Count variables per service (e.g., 5-minute and 1-hour windows) to differentiate burst vs. sustained noise.

Step 2: Create the Orchestration Rule

  1. In your orchestration, add a new rule in a position where it will be evaluated and not accidentally suppressed by a subsequent rule. If you use suppression rules, place the spike detection rule before them or ensure your suppression logic won’t catch spike events.
  2. Under When should this rule be applied?, select If events match certain conditions.
  3. In the field selector, choose Cache Variable and add your variable (e.g., cache_var.event_spike_threshold).
  4. In the operator dropdown, select is greater than.
  5. Enter the spike Threshold value — the number of events within your window that should trigger an incident (maximum 999). Pick a value aligned to your normal event volume and the duration you defined.
  6. Click Next.
  7. Under What action(s) should be applied?, select your desired actions. Common choices include:
    • Always trigger an alert to ensure an incident is created.
    • Priority and/or Severity to elevate visibility (e.g., P2 and critical).
    • Custom Fields or Tags (e.g., spike_detected: true, window_seconds: 300, threshold: 50).
  8. Click Save.

With this configuration in place, generate test traffic or replay sample events to verify that the count crosses your threshold as expected. Review the resulting incidents and Event Analytics to confirm the rule’s usefulness. Then adjust the time span and threshold to balance sensitivity and noise.

🚧

Important

  • If you use additional rules that suppress alerts, double-check ordering so the spike detection rule is not negated by later suppression.
  • Thresholds should be tuned to reduce false positives; start higher and step down as you observe behavior.

Track Heartbeat Events with Cache Variables

Event Orchestration can use Cache Variables and webhooks to track heartbeat events for AIOps customers. If an orchestration doesn’t receive a heartbeat within the user-defined window (maximum 23 hours, 59 minutes), it creates an incident.

This flow works as follows:

  • First event = create + suspend →
  • Next event on time = resolve previous, save new key as cache variable →
  • Missed event = resume alert, open incident, don’t auto-resolve.

In order to track heartbeat events, you will need to create two cache variables, an orchestration rule to resolve alerts, and an if/else rule to capture your first heartbeat event.

Step 1: Create Two Cache Variables

  1. Create an Event Data Cache Variable
    1. Create a Cache Variable using Event Data (CEF) and name it accordingly.
    2. Extract the dedup_key field from the current event.
    3. Set the condition for events where event.event_action matches trigger.
  2. Create an Event Count Cache Variable
    1. Create a Cache Variable using Event Count and name it accordingly.
    2. Set the duration for your desired heartbeat time window (e.g. 300 seconds).
    3. Set the condition for events where event.event_action matches trigger.

Step 2: Create an Orchestration Rule to Resolve Alerts

  1. Add Conditions
    1. Set the Event Data Cache Variable to exists; and
    2. Set the Event Count Cache Variable >= 1; and
    3. Set event.event_action matches trigger.
  2. Add Action
    1. Suspend Alert for the desired heartbeat time window + 5 seconds (e.g. 305 seconds).
      Note: The additional time is a buffer to allow the webhook to resolve the previous alert.
    2. Create a webhook
      1. In Automation > Webhook Actions, trigger a webhook Automatically when Alert is suspended/paused.
      2. Name your action.
      3. Add the webhook URL: https://events.pagerduty.com/v2/enqueue
      4. Add Body fields:
        • Routing_key: COPY INTEGRATION KEY FROM EO
        • Dedup_key : {{EVENT DATA CACHE VARIABLE NAME}}
        • Event_action: “resolve”
        • Additional Fields
          Please note: Depending on the Routing Rules within the Event Orchestration, more fields may be required so that the event lands on the correct service to resolve the alert. This is not required if the Event Orchestration has Global Dedup configured.

Step 3: Create an If/Else Rule to Capture the First Heartbeat Event

  1. Add Conditions
    1. Set event.event_action matches trigger; and
    2. Set the Event Count Cache Variable < 1.
  2. Add Action
    1. Suspend Alert for the desired Heartbeat time window + 5 seconds (e.g. 305 seconds).

Summary

On the first heartbeat, there’s no alert to resolve, so we suspend the alert and store its dedup_key in the Event Data Cache. For each subsequent heartbeat that arrives within the time window, we resolve the previous alert via webhook using the last dedup_key, then save the new dedup_key to the cache variable. If a heartbeat is missed, the previously suspended alert resumes and opens an incident, and the Event Count Cache ensures that this incident isn’t auto-resolved by any later “missed” events.