在Oracle中,對于數(shù)據(jù)庫的修改操作都會(huì)記錄redo,那么不同的操作會(huì)產(chǎn)生多少redo呢?可以通過以下一些方式來查詢來統(tǒng)計(jì)產(chǎn)生的redo日志量。
創(chuàng)新互聯(lián)公司成立十載來,這條路我們正越走越好,積累了技術(shù)與客戶資源,形成了良好的口碑。為客戶提供成都做網(wǎng)站、成都網(wǎng)站制作、成都外貿(mào)網(wǎng)站建設(shè)、網(wǎng)站策劃、網(wǎng)頁設(shè)計(jì)、域名申請、網(wǎng)絡(luò)營銷、VI設(shè)計(jì)、網(wǎng)站改版、漏洞修補(bǔ)等服務(wù)。網(wǎng)站是否美觀、功能強(qiáng)大、用戶體驗(yàn)好、性價(jià)比高、打開快等等,這些對于網(wǎng)站建設(shè)都非常重要,創(chuàng)新互聯(lián)公司通過對建站技術(shù)性的掌握、對創(chuàng)意設(shè)計(jì)的研究為客戶提供一站式互聯(lián)網(wǎng)解決方案,攜手廣大客戶,共同發(fā)展進(jìn)步。
(1)SQL*Plus中使用AUTOTRACE的使用。
當(dāng)在SQL*Plus中啟用autotrace跟蹤后,在執(zhí)行了特定的DML語句時(shí),Oracle會(huì)顯示該語句的統(tǒng)計(jì)信息,其中,redo Size一欄表示的就是該操作產(chǎn)生的redo的數(shù)量,其單位為Bytes:
SCOTT@seiang11g>set autotrace traceonly statistics
注意:如果在啟動(dòng)autotrace跟蹤的時(shí)候,出現(xiàn)如下報(bào)錯(cuò):SP2-0618:
Cannot find the Session Identifier.
Check PLUSTRACE role is enabled.
解決方法請參考另一篇博文:SP2-0618: Cannot find the Session Identifier.Check PLUSTRACE role is enabled
SCOTT@seiang11g>create table emp1 as select * from emp;
Table created.
SCOTT@seiang11g>
SCOTT@seiang11g>insert into emp1 select * from emp1;
14 rows created.
Statistics
----------------------------------------------------------
15 recursive calls
22 db block gets
33 consistent gets
5 physical reads
1872 redo size
834 bytes sent via SQL*Net to client
791 bytes received via SQL*Net from client
3 SQL*Net roundtrips to/from client
2 sorts (memory)
0 sorts (disk)
14 rows processed
(2)通過v$mystat查詢。
Oracle通過v$mystat視圖記錄當(dāng)前session的統(tǒng)計(jì)信息,我們也可以從該視圖中查詢得到session的redo生成情況:
SCOTT@seiang11g>set autot off
SCOTT@seiang11g>
SCOTT@seiang11g>select a.name,b.value from v$statname a,v$mystat b
2 where a.statistic# = b.statistic# and a.name='redo size';
NAME VALUE
---------------------------------------------------------------- ----------
redo size 29140
SCOTT@seiang11g>
SCOTT@seiang11g>insert into emp1 select * from emp1;
28 rows created.
SCOTT@seiang11g>
SCOTT@seiang11g>select a.name,b.value from v$statname a,v$mystat b
2 where a.statistic# = b.statistic# and a.name='redo size';
NAME VALUE
---------------------------------------------------------------- ----------
redo size 30708
SCOTT@seiang11g>
SCOTT@seiang11g>select 30708-29140 from dual;
30708-29140
-----------
1568
(3)通過v$sysstat查詢。
對于數(shù)據(jù)庫全局Redo的生成量,可以通過v$sysstat視圖來查詢得到:
SYS@seiang11g>select name,value from v$sysstat where name='redo size';
NAME VALUE
---------------------------------------------------------------- ----------
redo size 548518160
從v$sysstat視圖中得到的是自數(shù)據(jù)庫實(shí)例啟動(dòng)以來的累積日志生成量,可以根據(jù)實(shí)例啟動(dòng)時(shí)間大致估算每天數(shù)據(jù)庫的日志生成量:
SYS@seiang11g>alter session set nls_date_format='yyyy-mm-dd hh34:mi:ss';
Session altered.
SYS@seiang11g>
SYS@seiang11g>select
2 (select value/1024/1024/1024 from v$sysstat where name='redo size'
3 )/
4 (select round(sysdate-
5 (select startup_time from v$instance
6 )) from dual
7 ) redo_gb_per_day
8 from dual;
REDO_GB_PER_DAY
---------------
.102173401
如果數(shù)據(jù)庫運(yùn)行在歸檔模式下,由于其他因素的影響,以上Redo生成量并不代表歸檔日志的大小,但是可以通過一定的加權(quán)提供參考。
至于歸檔日志的生成量,可以通過v$archived_log視圖,根據(jù)一段時(shí)間的歸檔日志量進(jìn)行估算得到。該視圖中記錄了歸檔日志的主要信息:
SYS@seiang11g>select
name,completion_time,blocks*block_size/1024/1024 MB
2 from v$archived_log where status = 'A';
NAME COMPLETION_TIME MB
-------------------------------------------------- ------------------- ----------
/u01/app/oracle/arch/arch_1_949237404_8.log 2017-07-13 13:37:10 1.74072266
/u01/app/oracle/arch/arch_1_949237404_9.log 2017-09-13 17:09:40 35.9506836
/u01/app/oracle/arch/arch_1_949237404_10.log 2017-09-13 22:00:47 42.2592773
/u01/app/oracle/arch/arch_1_949237404_11.log 2017-09-14 05:00:33 36.9936523
/u01/app/oracle/arch/arch_1_949237404_12.log 2017-09-14 19:00:36 36.9335938
/u01/app/oracle/arch/arch_1_949237404_13.log 2017-09-15 01:06:21 35.8876953
/u01/app/oracle/arch/arch_1_949237404_14.log 2017-09-15 15:00:10 35.8935547
/u01/app/oracle/arch/arch_1_949237404_15.log 2017-09-15 22:00:37 37.5634766
/u01/app/oracle/arch/arch_1_949237404_16.log 2017-09-16 06:00:28 42.2397461
/u01/app/oracle/arch/arch_1_949237404_17.log 2017-09-16 14:00:16 43.9946289
/u01/app/oracle/arch/arch_1_949237404_18.log 2017-09-16 22:00:25 44.0483398
/u01/app/oracle/arch/arch_1_949237404_19.log 2017-09-17 06:00:25 40.4213867
/u01/app/oracle/arch/arch_1_949237404_20.log 2017-09-17 14:00:25 42.0063477
/u01/app/oracle/arch/arch_1_949237404_21.log 2017-09-17 22:00:28 42.7241211
/u01/app/oracle/arch/arch_1_949237404_22.log 2017-09-18 11:00:07 36.0229492
某日全天的日志生成可以通過如下查詢計(jì)算:
SYS@seiang11g>select trunc(completion_time),
2 sum(Mb)/1024 DAY_GB
3 from
4 (select name,
5 completion_time,
6 blocks*block_size/1024/1024 Mb
7 from v$archived_log
8 where completion_time between trunc(sysdate)-2 and trunc(sysdate)-1
9 )
10 group by trunc(completion_time);
TRUNC(COMPLETION_TI DAY_GB
------------------- ----------
2017-09-16 00:00:00 .127229214
最近日期的日志生成統(tǒng)計(jì):
SYS@seiang11g>select trunc(completion_time),
2 sum(mb)/1024 day_gb
3 from
4 (select name,
5 completion_time,
6 blocks*block_size/1024/1024 mb
7 from v$archived_log
8 )
9 group by trunc(completion_time);
TRUNC(COMPLETION_TI DAY_GB
------------------- ----------
2017-09-15 00:00:00 .10678196
2017-09-18 00:00:00 .035178661
2017-09-13 00:00:00 .076376915
2017-09-17 00:00:00 .122218609
2017-07-13 00:00:00 .065961361
2017-09-16 00:00:00 .127229214
2017-09-14 00:00:00 .072194576
根據(jù)每日歸檔的生成量,我們也可以反過來估計(jì)每日的數(shù)據(jù)庫活動(dòng)性及周期性,并決定空間分配等問題。
拓展:
(一)以下腳本可以用于列出最近Oracle數(shù)據(jù)庫每小時(shí)估算的redo重做日志產(chǎn)生量,因?yàn)楣浪銛?shù)據(jù)來源于archivelog的產(chǎn)生量和大小,所以數(shù)據(jù)是近似值,可供參考:
WITH times AS
(SELECT /*+ MATERIALIZE */
hour_end_time
FROM (SELECT (TRUNC(SYSDATE, 'HH') + (2 / 24)) - (ROWNUM / 24) hour_end_time
FROM DUAL
CONNECT BY ROWNUM <= (1 * 24) + 3),
v$database
WHERE log_mode = 'ARCHIVELOG')
SELECT hour_end_time, NVL(ROUND(SUM(size_mb), 3), 0) size_mb, i.instance_name
FROM(
SELECT hour_end_time, CASE WHEN(hour_end_time - (1 / 24)) > lag_next_time THEN(next_time + (1 / 24) - hour_end_time) * (size_mb / (next_time - lag_next_time)) ELSE 0 END + CASE WHEN hour_end_time < lead_next_time THEN(hour_end_time - next_time) * (lead_size_mb / (lead_next_time - next_time)) ELSE 0 END + CASE WHEN lag_next_time > (hour_end_time - (1 / 24)) THEN size_mb ELSE 0 END + CASE WHEN next_time IS NULL THEN(1 / 24) * LAST_VALUE(CASE WHEN next_time IS NOT NULL AND lag_next_time IS NULL THEN 0 ELSE(size_mb / (next_time - lag_next_time)) END IGNORE NULLS) OVER(
ORDER BY hour_end_time DESC, next_time DESC) ELSE 0 END size_mb
FROM(
SELECT t.hour_end_time, arc.next_time, arc.lag_next_time, LEAD(arc.next_time) OVER(
ORDER BY arc.next_time ASC) lead_next_time, arc.size_mb, LEAD(arc.size_mb) OVER(
ORDER BY arc.next_time ASC) lead_size_mb
FROM times t,(
SELECT next_time, size_mb, LAG(next_time) OVER(
ORDER BY next_time) lag_next_time
FROM(
SELECT next_time, SUM(size_mb) size_mb
FROM(
SELECT DISTINCT a.sequence#, a.next_time, ROUND(a.blocks * a.block_size / 1024 / 1024) size_mb
FROM v$archived_log a,(
SELECT /*+ no_merge */
CASE WHEN TO_NUMBER(pt.VALUE) = 0 THEN 1 ELSE TO_NUMBER(pt.VALUE) END VALUE
FROM v$parameter pt
WHERE pt.name = 'thread') pt
WHERE a.next_time > SYSDATE - 3 AND a.thread# = pt.VALUE AND ROUND(a.blocks * a.block_size / 1024 / 1024) > 0)
GROUP BY next_time)) arc
WHERE t.hour_end_time = (TRUNC(arc.next_time(+), 'HH') + (1 / 24)))
WHERE hour_end_time > TRUNC(SYSDATE, 'HH') - 1 - (1 / 24)), v$instance i
WHERE hour_end_time <= TRUNC(SYSDATE, 'HH')
GROUP BY hour_end_time, i.instance_name
ORDER BY hour_end_time
/
執(zhí)行結(jié)果:
HOUR_END_TIME SIZE_MB INSTANCE_NAME
------------------- ---------- ----------------
2017-09-17 14:00:00 5.25 seiang11g
2017-09-17 15:00:00 5.374 seiang11g
2017-09-17 16:00:00 5.374 seiang11g
2017-09-17 17:00:00 5.374 seiang11g
2017-09-17 18:00:00 5.374 seiang11g
2017-09-17 19:00:00 5.374 seiang11g
2017-09-17 20:00:00 5.374 seiang11g
2017-09-17 21:00:00 5.374 seiang11g
2017-09-17 22:00:00 5.374 seiang11g
2017-09-17 23:00:00 2.79 seiang11g
2017-09-18 00:00:00 2.77 seiang11g
2017-09-18 01:00:00 2.77 seiang11g
2017-09-18 02:00:00 2.77 seiang11g
2017-09-18 03:00:00 2.77 seiang11g
2017-09-18 04:00:00 2.77 seiang11g
2017-09-18 05:00:00 2.77 seiang11g
2017-09-18 06:00:00 2.77 seiang11g
2017-09-18 07:00:00 2.77 seiang11g
2017-09-18 08:00:00 2.77 seiang11g
2017-09-18 09:00:00 2.77 seiang11g
2017-09-18 10:00:00 2.77 seiang11g
2017-09-18 11:00:00 2.77 seiang11g
2017-09-18 12:00:00 .005 seiang11g
2017-09-18 13:00:00 0 seiang11g
2017-09-18 14:00:00 0 seiang11g
(二)Oracle查詢最近幾天每小時(shí)歸檔日志產(chǎn)生數(shù)量的腳本,腳本內(nèi)容如下所示:
SELECT SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH:MI:SS'),1,5) Day,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'00',1,0)) H00,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'01',1,0)) H01,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'02',1,0)) H02,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'03',1,0)) H03,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'04',1,0)) H04,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'05',1,0)) H05,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'06',1,0)) H06,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'07',1,0)) H07,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'08',1,0)) H08,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'09',1,0)) H09,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'10',1,0)) H10,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'11',1,0)) H11,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'12',1,0)) H12,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'13',1,0)) H13,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'14',1,0)) H14,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'15',1,0)) H15,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'16',1,0)) H16,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'17',1,0)) H17,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'18',1,0)) H18,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'19',1,0)) H19,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'20',1,0)) H20,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'21',1,0)) H21,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'22',1,0)) H22,
SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'23',1,0)) H23,
COUNT(*) TOTAL
FROM v$log_history a
WHERE first_time>=to_char(sysdate-10)
GROUP BY SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH:MI:SS'),1,5)
ORDER BY SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH:MI:SS'),1,5) DESC;
修改天數(shù),可以修改WHERE first_time>=to_char(sysdate-11)
執(zhí)行結(jié)果:
參考鏈接:
http://www.dbtan.com/2009/12/how-many-redo-has-produced.html
http://www.askmaclean.com/archives/script%E5%88%97%E5%87%BAoracle%E6%AF%8F%E5%B0%8F%E6%97%B6%E7%9A%84redo%E9%87%8D%E5%81%9A%E6%97%A5%E5%BF%97%E4%BA%A7%E7%94%9F%E9%87%8F.html
http://www.jb51.net/article/119200.htm
網(wǎng)頁題目:Oracle產(chǎn)生redo日志量大小統(tǒng)計(jì)
鏈接URL:http://aaarwkj.com/article18/pdeegp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供手機(jī)網(wǎng)站建設(shè)、微信小程序、自適應(yīng)網(wǎng)站、網(wǎng)站改版、網(wǎng)頁設(shè)計(jì)公司、品牌網(wǎng)站設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)