今天開發(fā)說一個(gè)測試庫里的表空間滿了需要清理,連上測試庫一看,確實(shí)已經(jīng)使用99.98%了。
成都創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的鄒城網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
TABLESPACE_NAME SIZE_G FREE_G USED_PCT ------------------------------ --------------- --------------- ---------- E2TEST 96.00 0.02 99.98%
通過與開發(fā)溝通確定了刪除策略,先刪除了一些歷史表但是清理效果不大,直接通過DBA_SEGMENTS視圖查看ESOP2TEST表空間中bytes最大的表為E_CONT,占了28G。打算清理直接這張表。
OWNER SEGMENT_NAME SUM(BYTES)/1024/1024 ------------------------------ ------------------ -------------------- E2TEST E_CONT 28983.3125
開發(fā)要求保留最近一個(gè)月的數(shù)據(jù),所以打算建一張臨時(shí)表把最近一個(gè)月的數(shù)據(jù)導(dǎo)進(jìn)去,刪除原表,再把臨時(shí)表重命名為原表。過程其實(shí)很簡單,步驟也不復(fù)雜,但是在做完全部步驟后發(fā)現(xiàn)表空間使用率依然很高,清理沒有效果。
TABLESPACE_NAME SIZE_G FREE_G USED_PCT ------------------------------ --------------- --------------- ---------- E2TEST 96.00 0.89 99.07%
再次查看通過DBA_SEGMENTS查看空間占用情況。
SQL> select * from (select owner,segment_name,sum(bytes)/1024/1024 from dba_segments where tablespace_name='E2TEST' group by owner,segment_name order by 3 desc ) where rownum < 50; OWNER SEGMENT_NAME SUM(BYTES)/1024/1024 ------------------------------ ------------------------------ -------------------- E2TEST 20.962 28981
segment_name居然變?yōu)榱藬?shù)字。。。
查看這個(gè)段的類型為TEMPORARY
SQL> select * from (select owner,segment_name,segment_type,sum(bytes)/1024/1024 from dba_segments where tablespace_name='E2TEST' group by owner,segment_name,segment_type order by 4 desc ) where rownum < 50; OWNER SEGMENT_NAME SEGMENT_TYPE SUM(BYTES)/1024/1024 ------------------------------ ------------------------------ ------------------ -------------------- E2TEST 20.962 TEMPORARY 28981
在網(wǎng)上查資料,先看到惜分飛的一篇blog,介紹type為TEMPORARY,name為file#.block#對象重現(xiàn)和清理
http://www.xifenfei.com/2015/12/type%E4%B8%BAtemporaryname%E4%B8%BAfile-block%E5%AF%B9%E8%B1%A1%E9%87%8D%E7%8E%B0%E5%92%8C%E6%B8%85%E7%90%86.html
跟他里邊描述的不太一樣,按他寫的方法無法進(jìn)行清理。
繼續(xù)查發(fā)現(xiàn)一篇文章介紹的情況跟我的比較相似,http://blog.chinaunix.net/uid-22948773-id-3758510.html
重啟數(shù)據(jù)庫或用下面的方法清理:
alter session set events 'immediate trace name DROP_SEGMENTS level TS#+1';
level - tablespace number+1. If the value is 2147483647 then
temp segments in ALL tablespaces are dropped, otherwise, only
segments in a tablespace whose number is equal to the LEVEL
specification are dropped.
1、查詢所在表空間的編號
SQL> select ts# from v$tablespace where name='E2TEST'; TS# ---------- 5
2、使用上述方法清理
SQL> alter session set events 'immediate trace name DROP_SEGMENTS level 6'; Session altered.
3、再次查看最大的TEMPORY段已經(jīng)沒有了,表空間也徹底被釋放了
SQL> select * from (select owner,segment_name,segment_type,sum(bytes)/1024/1024 from dba_segments where tablespace_name='E2TEST' group by owner,segment_name,segment_type order by 4 desc ) where rownum < 50; OWNER SEGMENT_NAME SEGMENT_TYPE SUM(BYTES)/1024/1024 ------------------------------ --------------------------------------------------------------------------------- ------------------ -------------------- E2TEST T_CONT TABLE 12332 E2TEST SYS_LOB0000017851C00008$$ LOBSEGMENT 9834 E2TEST ERMSGLOG TABLE 5974 TABLESPACE_NAME SIZE_G FREE_G USED_PCT ------------------------------ --------------- --------------- ---------- E2TEST 96.00 31.68 67.00%