1. 程式人生 > 實用技巧 >TEMP表空間持續增高問題根結

TEMP表空間持續增高問題根結

生產系統,業務反饋只要他們一跑某程式,就報TEMP表空間不足。我們的使用者在建立某表的時候,需要指定自己的臨時表空間,其他使用者均沒有問題,就這個使用者有問題。
抓取資料庫內部等待事件,沒有temp相關的等待事件,先查一下temp表空間的利用率看看有沒有頭緒。
SELECT d.tablespace_name "Name",
TO_CHAR( NVL(a.bytes / 1024 / 1024, 0),'99,999,990.900' ) "Size (M)",
TO_CHAR( NVL(t.hwm, 0 )/1024/ 1024,'99999999.999' ) "HWM (M)",

TO_CHAR( NVL(t.hwm / a.bytes 100 , 0), '990.00') "HWM % " ,
TO_CHAR( NVL(t.bytes/1024 /1024, 0),'99999999.999' ) "Using (M)",
TO_CHAR( NVL(t.bytes / a.bytes
100 , 0), '990.00') "Using %"
FROM sys.dba_tablespaces d,
( select tablespace_name, sum (bytes) bytes from dba_temp_files group by tablespace_name) a,
( select tablespace_name, sum (bytes_cached) hwm, sum(bytes_used) bytes from gv$temp_extent_pool group by tablespace_name) t
WHERE d.tablespace_name = a.tablespace_name(+)
AND d.tablespace_name = t.tablespace_name(+)
AND d.extent_management like 'LOCAL'
AND d.contents like 'TEMPORARY'
/

為了避免業務影響,隨即先採取應急手段,對temp表空間進行resize擴容,上條SQL執行完成後結果30G的temp表空間,已經用掉了59%。

TEMP表空間持續增高問題根結
繼續往下檢視temp到底卡在哪裡
SELECT vt.inst_id,
vs.sid,
vs.serial#,
vs.username,
vs.osuser,
vs.machine,
vs.saddr,
vs.client_info,
vs.program,
vs.module,
vs.logon_time,
vt.tempseg_usage,
vt.segtype
FROM gv$session vs,
(SELECT inst_id,
username,
session_addr,
segtype,
ROUND(SUM(blocks) * 8192 / 1024 / 1024 / 1024, 2) tempseg_usage
FROM gv$tempseg_usage
GROUP BY inst_id, username, session_addr, segtype
ORDER BY 4 DESC) vt
WHERE vs.inst_id = vt.inst_id
AND vs.saddr = vt.session_addr
order by tempseg_usage desc;

TEMP表空間持續增高問題根結

隨即檢視SQL對應的表,DESC表結構,沒有CLOB欄位啊,難道發生了轉換?詢問開發後得知,他們確實有wmsys.wm_concat物件實現行列轉換的語句,拿到語句
TEMP表空間持續增高問題根結

這種方法不被Oracle所推薦,因為WMSYS使用者用於Workspace Manager,其函式物件可能因版本而不同體現出來。原本WM_CONCAT函式返回值為VARCHAR2變更為CLOB。這一變化導致了很多程式的異常。建議開發使用listagg的方式進行轉換。wm有bug只能用逗號,如果用其他符合需要配合replace
wm_concat有時取出來的欄位不完整。有興趣的可以試試10046抓一下sql執行的時候,到底是怎麼走的
1,alter session set events '10046 trace name context forever,level 12';

2,select
wmsys.wm_concat(xxxx) as CODE
from xxx_TYPE pe
LEFT JOIN
yyyy_MCC mcc on xxx.TYPE=xxxpe.CODE
where VALID='1' and pe.VALID='1'

3,關閉10046 alter session set events '10046 trace name context off';

4,獲取trc檔案位置

select
d.value||'/'||lower(rtrim(i.instance, chr(0)))||'ora'||p.spid||'.trc' trace_file_name
from
( select p.spid
from sys.v$mystat m,sys.v$session s,sys.v$process p
where m.statistic# = 1 and s.sid = m.sid and p.addr = s.paddr) p,
( select t.instance from sys.v$thread t,sys.v$parameter v
where v.name = 'thread' and (v.value = 0 or t.thread# = to_number(v.value))) i,
( select value from sys.v$parameter where name = 'user_dump_dest') d
/

TEMP表空間持續增高問題根結

隨即當晚緊急變更,反饋臨時表空間暫無異常。

轉載於:https://blog.51cto.com/yangjunfeng/2114697