Unlike other automation programs, you generally don't need pre-built "recipes" or "playbooks" to use Method5. Good DBAs already have loads of useful SQL and PL/SQL statements, it's usually trivial to use them in Method5.
But it can still be useful to see some simple examples of common tasks.
And the advanced examples show the full power of Method5. When the data gathering becomes trivial then advanced analytics become much easier.
Advanced Examples
- Snare - Configuration Comparison.sql
- Compare Everything Everywhere.sql
- ASM Forecast.sql
- Active Sessions.sql
- Compare Parameters.sql
- Space Treemap.sql
- Synchronize DBA Users Job.sql
Simple Examples
- Account Maintenance.sql
- Email Active DBA Users Job.sql
- Global Database Statistics.sql
- Load OEM data into M5_DATABASE.sql
Snare lets you quickly gather and compare Oracle database configuration information over time.
The default configuration contains information about components, crontab, invalid objects, last patch time, miscellaneous database settings, M5_DATABASE, and V$PARAMETER. For example, if someone modifies a system parameter Snare will let you easily find out when it was changed.
By default the job is installed but disabled. See the first section of the SQL file for simple instructions to enable the jobs.
Below are examples of how to call Snare. These simple queries are enough to replace expensive enterprise solutions.
--Compare configuration snapshots and display a summary.
select snare.compare_summary(
p_snapshot_before => 'EVERYTHING_20180710',
p_snapshot_after => 'EVERYTHING_20180712'
)
from dual;
--Compare configuration snapshots and display details.
select * from table(snare.compare_details(
p_snapshot_before => 'EVERYTHING_20180710',
p_snapshot_after => 'EVERYTHING_20180712'
));
With a few clicks you can compare schemas between an unlimited number of databases, and see all the results in a single view. This is an easy way to check if a large number of environments are synchronized.
The screenshot shows the output exported to a spreadsheet. The dense output may look cryptic at first but eventually it will allow you to rapidly identify schema differences. The letters refer to different versions of the same object. The columns on the right-hand side contain the entire DDL if you click on the cell.
data:image/s3,"s3://crabby-images/520ec/520ecb646bbe840a04a1ca3c4b7882c4b62472d9" alt=""
Storage alerts should be based on forecasts, not simple thresholds. Some databases are designed to be at 99.9% capacity. Others are in trouble if the capacity quickly reaches 50%.
Now that collecting all the V$ASM_DISKGROUP data is trivial you can focus on more intelligent forecasts. This script uses ordinary-least-squares regression to predict the capacity in 30 days based on three different forecasts, using data from 2, 7, and 30 days in the past.
This first chart shows a clear problem. The diskgroup is only 50% full but it only took 15 days for all that growth.
data:image/s3,"s3://crabby-images/564f8/564f840ad4b26dc4f356f01fcec3696b03b13b99" alt=""
This second chart shows a database at 99.9% capacity. But don't freak out - it hasn't grown at all in the past 30 days so you probably don't need to add space.
data:image/s3,"s3://crabby-images/7378c/7378c2bc90bca3ace898433cc4607a0a242ad77d" alt=""
Why tune one database when you can tune them all at the same time? If you've built a query against a view like GV$ACTIVE_SESSION_HISTORY you can easily run it against hundreds of databases.
This chart was created to solve the most painful performance problem - when connections "randomly" fail. Is there a pattern?
When I aggregated session counts for 400 databases, for 60 hosts, it became obvious that activity spiked at the hour mark. Drilling down it was clear the spikes were caused by AWR starting at the same time, and needed to be staggered.
data:image/s3,"s3://crabby-images/28796/2879674cdeaedf2500d43100bd11de15650003e6" alt=""
This report makes it trivial to compare all database parameters, for any set of databases, at one time.
data:image/s3,"s3://crabby-images/c9d90/c9d900ebac81052abaaf9fca5d3cb175ff10f8a3" alt=""
These treemap visualizations help you discover exactly where your space is being used.
data:image/s3,"s3://crabby-images/e86da/e86daea1bb6b8f06efd988f91dc04f480eee50e5" alt=""
Automatically synchronize DBA accounts, privileges, profiles, status, and profiles across all databases.
Activities like creating accounts, locking accounts, and synchronizing passwords across all databases can be done in one line of code.
Once it's trivial to gather data you can spend more time looking at potential access issues, such as a list of users with the DBA role. No need to manage hundreds of crontabs or scheduler jobs.
Convey the complexity of your environment through a few simple statistics, such as database count, schema count, object count, physical I/O per day, connections per day, queries per day, and segment size.
Populate the main configuration table M5_DATABASE with data from Oracle Enterprise Manager (OEM).