Pythian Blog: Technical Track

OEM 13c Monitoring Features - Part 2, Extended Metrics

This is the second in a series of blog posts covering the most important topics you should know to completely monitor your IT infrastructure with Oracle Enterprise Manager Cloud Control 13c. In the previous post, Part 1, we covered how to set up basic monitoring.

Extended Metrics

As mentioned in the previous post, Oracle Enterprise Manager (OEM) monitoring capabilities are significantly extended with the use of Extended Metrics, which allows the administrator to create any number of metrics based on SQL. PL/SQL, shell scripts, and so on. It allows administrators to, for example, check the availability of a web site using simple Linux commands such as curl, or monitor business-related information such as non-authorized transactions or calls received per minute, based on database queries or PL/SQL blocks. These personalized scripts are integrated into OEM which will execute it at a defined interval and can raise alerts just like any other metrics, based on the specified thresholds. Saving historical data of such metrics will also allow the development of automated reports for analyzing trends and assisting with business decisions. This section shows how to create an extended metric and use its data as a basis for an automated report, showing how many "Pending Calls", exist on the system. Note: To simulate some business-related issues, I've created a simple "CALLS" table, which has an ID, a timestamp, a caller name, and a pending flag that could be either "Y" or "N". The metric will check the number of calls with "PENDING"='Y' existing on the table for the past 15 minutes and if the number is higher than the available threshold, it will trigger an alert. The structure of the table, and other objects used to populate it, are in the "Appendix A" To create a new metric, go to: Enterprise -> Monitoring -> Metric Extensions. Click the “Create” button and select “Metric extension”. In this scenario, the database side metric extension being created will collect pending calls from a transaction table, so select the options as presented below.

In this example, the metric is based on a simple query, but complex PL/SQL procedures, or even shell scripts, can also be used to gather data:

On the next screen, add one entry to the metric extension for each column returned by the query in the exact order that the columns are returned by the query. To do so, click on the “Add” button and select “New metric column". This example uses just one column, which is a data column used to trigger alerts. If using more than one column, each one will have its own definition. Below are the key aspects for each column according to the " Enterprise Manager Cloud Control Administrator's Guide": Column Type:

A column is either a Key column, or Data column. A Key column uniquely identifies a row in the table. For example, employee ID is a unique identifier of a table of employees. A Data column is any non-unique data in a row.

Value Type:

A value type is Number or String. This determines the alert comparison operators that are available, and how Enterprise Manager renders collection data for this metric column.

Note that the column order should match the order with which the adapter (SQL Query, OS script, etc.) returns the data.   Below is an example of a data column settings:

Choose the metric category in a way that will make it easier to manage with Monitoring Templates and Groups. In this scenario, it's set as “Business KPI” to make it easier to locate and handle the extended metrics created with business purposes. Next, choose which type of credentials are going to be used to gather data for this particular metric. I deem it easier to grant the required privileges to the monitoring users (dbsnmp or sysman), and then choose to use the “Default monitoring credentials”. Once everything is set, test the new metric to make sure everything works properly. Select a database, then click on “Run Test”. If everything is successful, click the “Finish” button to complete the creation, or click on “Next” to review all details before finishing.

After the metric is created it needs to be deployed to the desired targets. This metric should also be included in some incident rules so OEM knows how to handle such events. To create a new “Incident Rule”, go to: Setup -> Incidents -> Incident Rules. This example creates a new rule set, but it's also possible to add a new rule to an existing set: Chose the desired option: To keep a clean and easy to maintain setup, I deem it easier to individually select each metric to be handled by each rule so it's easier to identify which metric is treated by each rule, and keep a generic rule at the bottom of the rule set processing line to pick up all missed events and notify by e-mail so such events can be reviewed and added to one of the other rules, if required. This kind of configuration allied with the proper metrics and threshold settings at the target level will make it easier to maintain a healthy and adjustable OEM environment. Select the severity(ies) to which OEM should send notifications, as well as notifications about corrective actions that might be related to the metric (corrective actions will be covered later on this series). After setting all the details, this is what the new rule looks like: Select whether the event should be cleared after being processed by checking the “Clear permanently” box. This prevents the same event from being picked up by another rule down the line.

After configuring all the details, this is what the new rule looks like:

Now that the incident rule is set, the new metric must be deployed to all the desired targets. But since the metric is still in the “Draft” status, a couple of additional steps are necessary before this metric can be deployed to targets. Back in the “Metric Extensions” page, select the newly created metric, then go to “Actions -> Save as Deployable Draft”. Once this is done, select “Actions -> Publish Metric Extension”. After these steps, the metric will be ready for deployment. To deploy an extended metric, select the metric, go to “Actions -> Deploy to Targets”. Select the desired targets and submit. Once deployed, the agent will execute the SQL provided in the metric with the interval specified in the metric schedule. If at any given time the value of current pending calls exceeds the specified threshold, Oracle will raise an alert and will send an e-mail like the following:
This e-mail identifies the metric that generated the alert “ME$PENDING_CALLS” (All extended metrics are preceded by “ME$”), as well as the incident rule that handled the event: “Business Metrics, Business Metrics Events”. This information helps while troubleshooting issues with metrics / incident rules. The message displayed can be specified during the metric creation. It may be altered to use the built-in variables to get the actual values. All details on extended metrics variables are displayed during the metric creation. It’s recommended to review these details. Extended metrics can be used to monitor virtually anything, either on a DB or outside of it, given the possibility of including personalized server-side scripts into OEM regular monitoring, which can run from simple HTTP checks to monitor website availability to complex shell scripts running any number of checks and returning a status message that can be compared against regular expressions to determine whether an alert should be raised. Depending on the metric settings, historical data collection can be kept in the OEM repository for reporting purposes. Such reports can be created and automated directly thru OEM by using the “Information Publisher Reports” and the “MGMT” views existing inside the OEM repository database. Stay tuned for the next blog post which will cover how to create reports based on historical / current metric data.  

No Comments Yet

Let us know what you think

Subscribe by email