Integrating IBM Cloud Logs alerts with Event Notifications and raising PagerDuty alerts
This tutorial shows you how to integrate IBM Cloud Logs alerts with Event Notifications and send PagerDuty Alerts.
IBM Cloud Logs is used to visualize and alert on events that are generated in your account. When an event of interest takes place in your IBM Cloud Logs instance, it communicates with a connected Event Notifications instance to raise an alert to the PagerDuty destination.
This tutorial shows you how to configure the following flow:
- 
            Creating a IBM Cloud Logs and an Event Notifications instance. 
- 
            Connecting an instance of IBM Cloud Logs with an Event Notifications instance. 
- 
            Configuring IBM Cloud Logs to send out notifications to PagerDuty as a destination. 
- 
            Configuring an alert in IBM Cloud Logs. 
- 
            Raising a PagerDuty alert when an alert is open in IBM Cloud Logs and automatically resolving it in PagerDuty when the alert is closed IBM Cloud Logs. 
Before you begin
You need an IBM Cloud® account. If you don't have an account, then Create an IBM Cloud account.
Create an Event Notifications service instance
- 
              Log in to your IBM Cloud® account. 
- 
              In the IBM Cloud catalog, search Event Notifications > Event Notifications. 
- 
              Select a Location from the list of supported locations and select a pricing plan. To know more about the pricing plans , refer here. 
- 
              Enter a service name. 
- 
              Select a resource group. 
- 
              Accept the license agreement terms and click Create. 
Create an IBM Cloud Logs service instance
- 
              In the IBM Cloud catalog, search Cloud Logs > Cloud Logs. 
- 
              Select a Location from the list of supported locations and select a pricing plan. 
- 
              Enter a service name. 
- 
              Select a resource group. 
- 
              Accept the license agreement terms and click Create. 
Enabling access in the instances and testing the connection
- 
              Navigate to the cloud logs instance which was selected as the source in the connection that was previously established by clicking on > Resource List > Logging and Monitoring > Your Cloud Logs instance. 
- 
              In your IBM Cloud Logs instance , select Dashboard. Now in your dashboard, click on and select Integrations > Outbound Integrations. 
- 
              Select Add under Event Notifications. 
- 
              Click on Add New. Since the authorization policy has been created, select next. 
- 
              Name your integration , select the Event Notifications instance that was used while authorization and set your endpoint type to Public. Click Save. 
- 
              Before moving to the Test step, we need to verify if a connection has been established between the Event Notifications instance and the IBM Cloud Logs instance. 
- 
              Navigate to your Event Notifications instance by clicking on > Resource List > Developer Tools > Your Event Notifications instance. 
- 
              Under Sources in your Event Notifications instance, you should see your IBM Cloud Logs instance as a source of the form IBM Cloud Logs - GUID of your Cloud Logs Instance. 
- 
              Go to Topics and click Create. Name your topic, and select your Cloud Logs instance as the Source. To learn more about creating a topic and providing filters that can be used in your instance , see Creating an Event Notifications topic. Click Create. 
- 
              Navigate to Destinations and click Create. Name your destination and select destination type as PagerDuty. Provide the Routing key, then click Add. See here for process to generate the Routing key. 
- 
              Create a template for your PagerDuty alert by navigating to Templates > Create. Name your template, select the template type as PagerDuty Notification and provide your template. Example Template: { "payload": { "summary": "{{ data.alert_definition.name}}", "timestamp": "{{time}}", {{#equal data.alert_definition.severity "Critical"}} "severity": "critical", {{/equal}} {{#equal data.alert_definition.severity "Error"}} "severity": "error", {{/equal}} {{#equal data.alert_definition.severity "Info"}} "severity": "info", {{/equal}} {{#equal data.alert_definition.severity "Warning"}} "severity": "warning", {{/equal}} "source": "{{ source }}", "custom_details": { "Alert ID": "{{ data.alert_definition.id }}", "Alert description": "{{ data.alert_definition.description }}", "Alert name": "{{ data.alert_definition.name }}", {{#equal data.alert_definition.alert_type "StandardLessThanAlertEvent"}} "Condition": { "LessThan": { "Threshold": "{{ data.alert_definition.condition.LessThan.condition_threshold }}", "Timeframe": "{{ data.alert_definition.condition.LessThan.condition_timeframe }}" } }, {{/equal}} "Log Example": "{{#if data.log_example_truncated}}{{data.log_example}} [logs truncated]{{else}}{{#if data.log_example}}{{#each data.log_example}}{{this}} {{/each}}{{else}}No matching lines found{{/if}}{{/if}}", "Query statement": "{{ data.alert_definition.query_statement }}" } }, "dedup_key": "{{ data.alert_definition.id }}", "links": [ { "href": "{{ data.links.edit_alert }}", "text": "Edit Alert" }, { "href": "{{ data.links.view_alert }}", "text": "View Alert" } ], {{#equal data.status "triggered"}} "event_action": "trigger" {{/equal}} {{#equal data.status "resolved"}} "event_action": "resolve" {{/equal}} {{#equal data.status "acknowledged"}} "event_action": "acknowledge" {{/equal}} "client": "IBM Cloud Logs" }To learn more about the fields that can be used to construct the template block, see here. 
- 
              To create a Subscription, navigate to Subscriptions > Create. Name your subscription, select the topic ,the PagerDuty destination, and the template that were previously created. Click Create. 
Creating an IBM Cloud Logs alert
- 
              Navigate to your IBM Cloud Logs instance and click on Dashboard. 
- 
              Click on > Alerts > Alert Management. 
- 
              Create a New Alert. 
- 
              Provide the Alert Name and Severity. Select the desired alert type and provide the query to filter the logs, along with the severity and conditions for the alert to be raised. 
- 
              Set the time period and schedule for the alert notifications and specify the notification content. 
- 
              Verify the alert and click create. 
Verifying that the connection was succesfully established
- 
              Navigate to your IBM Cloud Logs Dashboard and click on Test. If the connection was succesfully established, you will receive a PagerDuty alert. 
- 
              You can set the time period and frequency of the Alert Notifications in the next step and select alerts to attach to the webhook. 
- 
              Select Done. 
The process of integration is completed. You should start receiving PagerDuty alerts according to the criteria that was set when unusual activity is observed.