12cR2中,引入了两个参数MAX_IOPS和MAX_MBPS来限度PDB的物理IO。这两个参数只作用于PDB,不对CDB和非多租户环境失效。另外,这两个参数不限度redo log的写入(LGWR过程)和buffer cache脏块写入磁盘(DBWR过程)。

    IO对数据库性能至关重要。如果某个PDB产生了大量的IO,那可能导致CDB中的其它PDB也受影响。MAX_IOPS参数限度每秒IO操作次数,MAX_MBPS参数限度每秒IO吞吐,如果这两个参数同时在pdb中设置,都会失效起作用。如果在CDB$ROOT中设置这两个值,那么以后CDB中每个PDB都采取此作为默认值。

    默认状况下,这两个参数都为0。如果在PDB中这两个参数为0,CDB$ROOT中也为0,那对于PDB来讲,没有IO限度。

有些状况下,尽管物理IO限度曾经达到,然而一些要害IO依然容许,比方:对管制文件的拜访或对口令文件的拜访,然而这些要害IO也是计入到IO数统计里的。

    能够应用DBA_HIST_RSRC_PDB_METRIC来计算一个PDB正当的IO限度。当计算IO限度值时,能够参考以下列:IOPS、IOMBPS、IOPS_THROTTLE_EXEMPT和IOMBPS_THROTTLE_EXEMPT。不举荐设置MAX_IOPS的值小于100,MAX_MBPS的值小于25。

set linesize 400

col PDB_NAME for a10

col BEGIN_TIME for a30

col END_TIME for a30

SELECT R.SNAP_ID,

       R.CON_ID,

       P.PDB_NAME,

       TO_CHAR(R.BEGIN_TIME, 'YYYY-MM-D HH24:MI') AS BEGIN_TIME,

       TO_CHAR(END_TIME, 'YYYY-MM-D HH24:MI') AS END_TIME,

       R.IOPS,

       R.IOMBPS,

       R.IOPS_THROTTLE_EXEMPT,

       R.IOMBPS_THROTTLE_EXEMPT,

       R.AVG_IO_THROTTLE

  FROM DBA_HIST_RSRC_PDB_METRIC R, CDB_PDBS P

 WHERE R.CON_ID = P.CON_ID

 ORDER BY R.BEGIN_TIME;

 

ALTER SYSTEM SET MAX_IOPS = 1000 SCOPE = BOTH;

ALTER SYSTEM SET MAX_MBPS = 50 SCOPE = BOTH;

    上面在同一数据库中,设置不同的max_iops和max_mbps查问雷同的语句所须要的工夫,能够看出max_iops和max_mbps对IO的限度是起作用的。

MAX_IOPSMAX_MBPSElapsed(1)Elapsed(2)Elapsed(3)Avg elapsed time
0000:27.1600:27.5500:26.9427.22
100000:26.8700:26.9000:27.2527.01
10000:37.1300:34.2300:36.4335.93
8000:46.2400:44.9900:48.3346.52
6001:13.9201:11.2901:01.0801:08.75
4001:39.1601:41.3101:38.9101:39:80
2003:53.8203:41.9503:52.0103:49:26
1008:04.7808:38.8510:07.7908::57:14
0105:50.6805:54.0305:52.3205:52:34
01000:33.5100:33.3800:33.4800:33.46
02000:29.7100:27.0600:28.3700:28.38

 

    当零碎呈现resmgr: I/O rate limit期待事件时,能够通过如下视图查问以后IO过载影响到的sql,p1值标示以后pdb_id呈现此期待事件就须要调整max_iops 和max_mbps正当值,防止影响到关键性业务。

SELECT H.EVENT,

       H.P1 AS PDB_ID,

       C.PDB_NAME,

       H.SQL_ID,

       TO_CHAR(H.SAMPLE_TIME, 'YYYY-MM-D HH24:MI') AS SAMPLE_TIME,

       H.INSTANCE_NUMBER

  FROM DBA_HIST_ACTIVE_SESS_HISTORY H

  JOIN CDB_PDBS C

    ON C.PDB_ID = H.P1

   AND H.EVENT = 'resmgr: I/O rate limit'

 ORDER BY 4;