175 lines
10 KiB
SQL
175 lines
10 KiB
SQL
----------------------------------------------------------------------------------------
|
|
--
|
|
-- File name: cs_load_sysmetric_per_pdb_mem.sql
|
|
--
|
|
-- Purpose: System Load as per V$CON_SYSMETRIC Views per PDB (text report)
|
|
--
|
|
-- Author: Carlos Sierra
|
|
--
|
|
-- Version: 2021/10/31
|
|
--
|
|
-- Usage: Execute connected to CDB and enter metric group [{1m_avg}|1h_avg|1h_max]
|
|
--
|
|
-- Example: $ sqlplus / as sysdba
|
|
-- SQL> @cs_load_sysmetric_per_pdb_mem.sql
|
|
--
|
|
-- Notes: Stand-alone script
|
|
--
|
|
-- Developed and tested on 19c.
|
|
--
|
|
-- Several columns are commented out simply to reduce report width.
|
|
--
|
|
---------------------------------------------------------------------------------------
|
|
--
|
|
DEF script_name = 'cs_load_sysmetric_per_pdb_mem';
|
|
--
|
|
COL cs_date NEW_V cs_date NOPRI;
|
|
COL cs_host NEW_V cs_host NOPRI;
|
|
COL cs_db NEW_V cs_db NOPRI;
|
|
COL cs_con_name NEW_V cs_con_name NOPRI;
|
|
SELECT TO_CHAR(SYSDATE, 'YYYY-MM-DD"T"HH24:MI:SS') AS cs_date, SYS_CONTEXT('USERENV','HOST') AS cs_host, UPPER(name) AS cs_db, SYS_CONTEXT('USERENV', 'CON_NAME') AS cs_con_name FROM v$database;
|
|
--
|
|
SET TERM ON HEA ON LIN 2490 PAGES 100 TAB OFF FEED OFF ECHO OFF VER OFF TRIMS ON TRIM ON TI OFF TIMI OFF LONG 240000 LONGC 2400 NUM 20 SERVEROUT OFF;
|
|
ALTER SESSION SET NLS_DATE_FORMAT = 'YYYY-MM-DD"T"HH24:MI:SS';
|
|
COL report_date_time NEW_V report_date_time NOPRI;
|
|
SELECT TO_CHAR(SYSDATE, 'YYYY-MM-DD"T"HH24.MI.SS"Z"') AS report_date_time FROM DUAL;
|
|
--
|
|
PRO Enter Metric Group: [{1m_avg}|1h_avg|1h_max]
|
|
DEF cs_metric_group = '&1.';
|
|
UNDEF 1;
|
|
COL cs_metric_group NEW_V cs_metric_group NOPRI;
|
|
SELECT CASE WHEN LOWER(TRIM('&&cs_metric_group.')) IN ('1m_avg' ,'1h_avg', '1h_max') THEN LOWER(TRIM('&&cs_metric_group.')) ELSE '1m_avg' END AS cs_metric_group FROM DUAL;
|
|
COL cs_hea NEW_V cs_hea NOPRI;
|
|
SELECT CASE '&&cs_metric_group.' WHEN '1m_avg' THEN '1m Avg' WHEN '1h_avg' THEN '1h Avg' WHEN '1h_max' THEN '1h Max' ELSE 'Error' END AS cs_hea FROM DUAL;
|
|
DEF cs_hea_ps = '&&cs_hea. Per Sec';
|
|
--
|
|
COL cs_begin_time NEW_V cs_begin_time NOPRI;
|
|
COL cs_end_time NEW_V cs_end_time NOPRI;
|
|
SELECT TO_CHAR(begin_time, 'YYYY-MM-DD"T"HH24:MI:SS') AS cs_begin_time, TO_CHAR(end_time, 'YYYY-MM-DD"T"HH24:MI:SS') AS cs_end_time FROM v$con_sysmetric WHERE '&&cs_metric_group.' = '1m_avg' AND group_id IN (2, 18) AND ROWNUM = 1;
|
|
SELECT TO_CHAR(begin_time, 'YYYY-MM-DD"T"HH24:MI:SS') AS cs_begin_time, TO_CHAR(end_time, 'YYYY-MM-DD"T"HH24:MI:SS') AS cs_end_time FROM v$con_sysmetric_summary WHERE '&&cs_metric_group.' IN ('1h_avg', '1h_max') AND group_id IN (2, 18) AND ROWNUM = 1;
|
|
--
|
|
DEF cs_format = 'FOR 999,999,999,990.0';
|
|
COL pdb_name FOR A30 HEA 'PDB Name' TRUNC;
|
|
COL db_cpu &&cs_format. HEA 'DB CPU(s)|&&cs_hea_ps.';
|
|
COL redo_size &&cs_format. HEA 'Redo size|(MB)|&&cs_hea_ps.';
|
|
COL logical_reads &&cs_format. HEA 'Logical read|(blocks)|&&cs_hea_ps.';
|
|
COL block_changes &&cs_format. HEA 'Block changes|&&cs_hea_ps.';
|
|
COL physical_reads &&cs_format. HEA 'Physical read|(blocks)|&&cs_hea_ps.';
|
|
COL physical_writes &&cs_format. HEA 'Physical write|(blocks)|&&cs_hea_ps.';
|
|
COL total_read_io &&cs_format. HEA 'Total read IO|(MB)|&&cs_hea_ps.';
|
|
COL total_write_io &&cs_format. HEA 'Total write IO|(MB)|&&cs_hea_ps.';
|
|
COL appl_read_io &&cs_format. HEA 'Appl read IO|(MB)|&&cs_hea_ps.';
|
|
COL appl_write_io &&cs_format. HEA 'Appl wite IO|(MB)|&&cs_hea_ps.';
|
|
COL network_traffic &&cs_format. HEA 'Network traffic|(MB)|&&cs_hea_ps.';
|
|
COL user_calls &&cs_format. HEA 'User calls|&&cs_hea_ps.';
|
|
COL parses &&cs_format. HEA 'Parses|(SQL)|&&cs_hea_ps.';
|
|
COL hard_parses &&cs_format. HEA 'Hard parses|(SQL)|&&cs_hea_ps.';
|
|
COL failed_parses &&cs_format. HEA 'Failed parses|(SQL)|&&cs_hea_ps.';
|
|
COL executes &&cs_format. HEA 'Executes|(SQL)|&&cs_hea_ps.';
|
|
COL logons &&cs_format. HEA 'Logons|&&cs_hea_ps.';
|
|
COL open_cursors &&cs_format. HEA 'Open cursors|&&cs_hea_ps.';
|
|
COL transactions &&cs_format. HEA 'Transactions|&&cs_hea_ps.';
|
|
COL commits &&cs_format. HEA 'Commits|&&cs_hea_ps.';
|
|
COL rollbacks &&cs_format. HEA 'Rollbacks|&&cs_hea_ps.';
|
|
COL logons_count &&cs_format. HEA 'Logons|Count|&&cs_hea.';
|
|
COL session_count &&cs_format. HEA 'Session|Count|&&cs_hea.';
|
|
COL aas &&cs_format. HEA 'Average Active|Sessions|&&cs_hea.';
|
|
COL ass &&cs_format. HEA 'Active Serial|Sessions|&&cs_hea.';
|
|
COL aps &&cs_format. HEA 'Active Parallel|Sessions|&&cs_hea.';
|
|
COL bs &&cs_format. HEA 'Background|Sessions|&&cs_hea.';
|
|
COL open_cursors_count &&cs_format. HEA 'Open Cursors|Count|&&cs_hea.';
|
|
--
|
|
BREAK ON REPORT;
|
|
COMPUTE SUM OF db_cpu redo_size logical_reads block_changes physical_reads physical_writes total_read_io total_write_io appl_read_io appl_write_io network_traffic user_calls parses hard_parses failed_parses executes logons open_cursors transactions commits rollbacks logons_count session_count aas ass aps bs open_cursors_count ON REPORT;
|
|
--
|
|
-- @@cs_internal/&&cs_set_container_to_cdb_root.
|
|
ALTER SESSION SET container = CDB$ROOT;
|
|
--
|
|
SPO /tmp/&&script_name._&&report_date_time..txt
|
|
PRO /tmp/&&script_name._&&report_date_time..txt
|
|
PRO
|
|
PRO Date : &&cs_date.
|
|
PRO Host : &&cs_host.
|
|
PRO Database : &&cs_db.
|
|
PRO Container: &&cs_con_name.
|
|
PRO Metric : &&cs_hea. : &&cs_begin_time. - &&cs_end_time.
|
|
PRO
|
|
PRO Load Profile (v$con_sysmetric for 1m_avg or v$con_sysmetric_summary for 1h_avg or 1h_max)
|
|
PRO ~~~~~~~~~~~~
|
|
WITH
|
|
sysmetric AS (
|
|
SELECT /*+ MATERIALIZE NO_MERGE */
|
|
con_id, metric_name, metric_unit, value
|
|
FROM v$con_sysmetric
|
|
WHERE group_id = 18
|
|
AND ROWNUM >= 1 /* MATERIALIZE */
|
|
),
|
|
sysmetric_summary AS (
|
|
SELECT /*+ MATERIALIZE NO_MERGE */
|
|
con_id, metric_name, average, maxval
|
|
FROM v$con_sysmetric_summary
|
|
WHERE group_id = 18
|
|
AND ROWNUM >= 1 /* MATERIALIZE */
|
|
),
|
|
sysmetric_norm AS (
|
|
SELECT /*+ MATERIALIZE NO_MERGE */
|
|
sm.con_id,
|
|
sm.metric_name,
|
|
CASE WHEN sm.metric_unit = 'CentiSeconds Per Second' THEN sm.value / 100 WHEN sm.metric_unit IN ('Bytes Per Second', 'bytes per sec', 'bytes', 'Bytes Per Txn') THEN sm.value / POWER(10, 6) ELSE sm.value END AS value_1m_avg,
|
|
CASE WHEN sm.metric_unit = 'CentiSeconds Per Second' THEN ss.average / 100 WHEN sm.metric_unit IN ('Bytes Per Second', 'bytes per sec', 'bytes', 'Bytes Per Txn') THEN ss.average / POWER(10, 6) ELSE ss.average END AS value_1h_avg,
|
|
CASE WHEN sm.metric_unit = 'CentiSeconds Per Second' THEN ss.maxval / 100 WHEN sm.metric_unit IN ('Bytes Per Second', 'bytes per sec', 'bytes', 'Bytes Per Txn') THEN ss.maxval / POWER(10, 6) ELSE ss.maxval END AS value_1h_max
|
|
FROM sysmetric sm,
|
|
sysmetric_summary ss
|
|
WHERE ss.con_id = sm.con_id
|
|
AND ss.metric_name = sm.metric_name
|
|
AND ROWNUM >= 1 /* MATERIALIZE */
|
|
)
|
|
SELECT /*+ MATERIALIZE NO_MERGE */
|
|
c.name AS pdb_name
|
|
, SUM(CASE s.metric_name WHEN 'CPU Usage Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS db_cpu
|
|
, SUM(CASE s.metric_name WHEN 'Redo Generated Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS redo_size
|
|
, SUM(CASE s.metric_name WHEN 'Logical Reads Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS logical_reads
|
|
-- , SUM(CASE s.metric_name WHEN 'DB Block Changes Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS block_changes
|
|
, SUM(CASE s.metric_name WHEN 'Physical Reads Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS physical_reads
|
|
, SUM(CASE s.metric_name WHEN 'Physical Writes Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS physical_writes
|
|
-- , SUM(CASE s.metric_name WHEN 'Physical Read Total Bytes Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS total_read_io
|
|
-- , SUM(CASE s.metric_name WHEN 'Physical Write Total Bytes Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS total_write_io
|
|
-- , SUM(CASE s.metric_name WHEN 'Physical Read Bytes Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS appl_read_io
|
|
-- , SUM(CASE s.metric_name WHEN 'Physical Write Bytes Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS appl_write_io
|
|
, SUM(CASE s.metric_name WHEN 'Network Traffic Volume Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS network_traffic
|
|
, SUM(CASE s.metric_name WHEN 'User Calls Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS user_calls
|
|
-- , SUM(CASE s.metric_name WHEN 'Total Parse Count Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS parses
|
|
-- , SUM(CASE s.metric_name WHEN 'Hard Parse Count Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS hard_parses
|
|
-- , SUM(CASE s.metric_name WHEN 'Parse Failure Count Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS failed_parses
|
|
, SUM(CASE s.metric_name WHEN 'Executions Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS executes
|
|
, SUM(CASE s.metric_name WHEN 'Logons Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS logons
|
|
-- , SUM(CASE s.metric_name WHEN 'Open Cursors Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS open_cursors
|
|
, SUM(CASE s.metric_name WHEN 'User Transaction Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS transactions
|
|
, SUM(CASE s.metric_name WHEN 'User Commits Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS commits
|
|
-- , SUM(CASE s.metric_name WHEN 'User Rollbacks Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS rollbacks
|
|
-- , SUM(CASE s.metric_name WHEN 'Current Logons Count' THEN s.value_&&cs_metric_group. ELSE 0 END) AS logons_count
|
|
, SUM(CASE s.metric_name WHEN 'Session Count' THEN s.value_&&cs_metric_group. ELSE 0 END) AS session_count
|
|
, SUM(CASE s.metric_name WHEN 'Average Active Sessions' THEN s.value_&&cs_metric_group. ELSE 0 END) AS aas
|
|
-- , SUM(CASE s.metric_name WHEN 'Active Serial Sessions' THEN s.value_&&cs_metric_group. ELSE 0 END) AS ass
|
|
, SUM(CASE s.metric_name WHEN 'Active Parallel Sessions' THEN s.value_&&cs_metric_group. ELSE 0 END) AS aps
|
|
-- , SUM(CASE s.metric_name WHEN 'Background Time Per Sec' THEN s.value_&&cs_metric_group. ELSE 0 END) AS bs
|
|
-- , SUM(CASE s.metric_name WHEN 'Current Open Cursors Count' THEN s.value_&&cs_metric_group. ELSE 0 END) AS open_cursors_count
|
|
FROM sysmetric_norm s,
|
|
v$containers c
|
|
WHERE c.con_id = s.con_id
|
|
AND ROWNUM >= 1
|
|
GROUP BY
|
|
c.name
|
|
ORDER BY
|
|
c.name
|
|
/
|
|
PRO
|
|
PRO SQL> @&&script_name..sql "&&cs_metric_group."
|
|
SPO OFF;
|
|
--
|
|
-- @@cs_internal/&&cs_set_container_to_curr_pdb.
|
|
ALTER SESSION SET CONTAINER = &&cs_con_name.;
|
|
--
|
|
PRO
|
|
PRO /tmp/&&script_name._&&report_date_time..txt
|
|
-- |