Oracle DBA 日常管理.docx
《Oracle DBA 日常管理.docx》由会员分享,可在线阅读,更多相关《Oracle DBA 日常管理.docx(15页珍藏版)》请在冰豆网上搜索。
OracleDBA日常管理
OracleDBA日常管理
目的:
这篇文档有很详细的资料记录着对一个甚至更多的ORACLE数据库每天的,每月的,
每年的运行的状态的结果及检查的结果,在文档的附录中你将会看到所有检查,修改的SQL
和PL/SQL代码。
目录
1.日常维护程序
A.检查已起的所有实例
B.查找一些新的警告日志
C.检查DBSNMP是否在运行
D.检查数据库备份是否正确
E.检查备份到磁带中的文件是否正确
F.检查数据库的性能是否正常合理,是否有足够的空间和资源
G.将文档日志复制到备份的数据库中
H.要常看DBA用户手册
2.晚间维护程序
A.收集VOLUMETRIC的数据
3.每周维护工作
A.查找那些破坏规则的OBJECT
B.查找是否有违反安全策略的问题
C.查看错误地方的SQL*NET日志
D.将所有的警告日志存档
E.经常访问供应商的主页
4.月维护程序
A.查看对数据库会产生危害的增长速度
B.回顾以前数据库优化性能的调整
C.查看I/O的屏颈问题
D.回顾FRAGMENTATION
E.将来的执行计划
F.查看调整点和维护
5.附录
A.月维护过程
B.晚间维护过程
C.周维护过程
6.参考文献
----------------------------------------------------------------
一.日维护过程
A.查看所有的实例是否已起
确定数据库是可用的,把每个实例写入日志并且运行日报告或是运行测试
文件。
当然有一些操作我们是希望它能自动运行的。
可选择执行:
用ORACLE管理器中的‘PROBE’事件来查看
B.查找新的警告日志文件
1.联接每一个操作管理系统
2.使用‘TELNET’或是可比较程序
3.对每一个管理实例,经常的执行$ORACLE_BASE//bdump操
作,并使其能回退到控制数据库的SID。
4.在提示下,使用UNIX中的‘TAIL’命令查看alert_.log,或是
用其他方式检查文件中最近时期的警告日志
5.如果以前出现过的一些ORA_ERRORS又出现,将它记录到数据库
恢复日志中并且仔细的研究它们,这个数据库恢复日志在〈FILE〉中
C.查看DBSNMP的运行情况
检查每个被管理机器的‘DBSNMP’进程并将它们记录到日志中。
在UNIX中,在命令行中,键入ps–ef|grepdbsnmp,将回看到2个
DBSNMP进程在运行。
如果没有,重启DBSNMP。
D.查数据库备份是否成功
E.检查备份的磁带文档是否成功
F.检查对合理的性能来说是否有足够的资源
1.检查在表空间中有没有剩余空间。
对每一个实例来说,检查在表空间中是否存在有剩余空间来满足当天
的预期的需要。
当数据库中已有的数据是稳定的,数据日增长的平均
数也是可以计算出来,最小的剩余空间至少要能满足每天数据的增
长。
A)运行‘FREE.SQL’来检查表空间的剩余空间。
B)运行‘SPACE.SQL’来检查表空间中的剩余空间百分率
2.检查回滚段
回滚段的状态一般是在线的,除了一些为复杂工作准备的专用
段,它一般状态是离线的。
a)每个数据库都有一个回滚段名字的列表。
b)你可以用V$ROLLSTAT来查询在线或是离线的回滚段的现在状
态.
c)对于所有回滚段的存储参数及名字,可用
DBA_ROLLBACK_SEGS来查询。
但是它不如V$ROLLSTAT
准确。
3.识别出一些过分的增长
查看数据库中超出资源或是增长速度过大的段,这些段的存储参
数需要调整。
a)收集日数据大小的信息,可以用
‘ANALYZE5PCT.SQL’。
如果你收集的是每晚的信息,
则可跳过这一步。
b)检查当前的范围,可用‘NR.EXTENTS.SQL’。
c)查询当前表的大小信息。
d)查询当前索引大小的信息。
e)查询增长趋势。
4.确定空间的范围。
如果范围空间对象的NEXT_EXTENT比表空间所能提供的最大范
围还要大,那么这将影响数据库的运行。
如果我们找到了这个目标,可
以用‘ALTERTABLESPACECOALESCE’调查它的位置,或加另外
的数据文件。
A)运行‘SPACEBOUND.SQL’。
如果都是正常的,将不返回任何行。
5.回顾CPU,内存,网络,硬件资源论点的过程
A)检查CPU的利用情况,进到x:
webphase2default.htm=>system
metrics=>CPU利用页,CPU的最大限度为400,当CPU的占用保持
在350以上有一段时间的话,我们就需要查看及研究出现的问题。
G.将存档日志复制到备用数据库中
如果有一个备用数据库,将适当的存档日志复制到备用数据库的期望
位置,备用数据库中保存最近期的数据。
H.经常查阅DBA用户手册
如果有可能的话,要广泛的阅读,包括DBA手册,行业杂志,新闻
组或是邮件列表。
-------------------------------------------------------------
二.晚间维护过程
大部分的数据库产品将受益于每晚确定的检查进程的运行。
A.收集VOLUMETRIC数据
1.分析计划和收集数据
更准确的分析计算并保存结果。
a)如果你现在没有作这些的话,用‘MKVOLFACT.SQL’来创建测定体积的
表。
b)收集晚间数据大小的信息,用‘ANALYZECOMP.SQL’。
c)收集统计结果,用‘POPVOL.SQL’。
d)在空闲的时候检查数据,可能的话,每周或每个月进行。
我是用MSEXCEL和ODBC的联接来检查数据和图表的增长
-------------------------------------------------------------
三.每周维护过程
A.查找被破坏的目标
1.对于每个给定表空间的对象来说,NEXT_EXTENT的大小是相同的,如
12/14/98,缺省的NEXT_EXTENT的DATAHI为1G,DATALO为500MB,
INDEXES为256MB。
A)检查NEXT_EXTENT的设置,可用‘NEXTEXT。
SQL’。
B)检查已有的EXTENTS,可用‘EXISTEXT。
SQL’。
2.所有的表都应该有唯一的主键
a)查看那些表没有主键,可用‘NO_PK.SQL’。
b)查找那些主键是没有发挥作用的,可用‘DIS_PK.SQL’。
c)所有作索引的主键都要是唯一的,可用‘NONUPK。
SQL’来检
查。
3.所有的索引都要放到索引表空间中。
运行‘MKREBUILD_IDX。
SQL’
4.不同的环境之间的计划应该是同样的,特别是测试环境和成品环境之间的
计划应该相同。
a)检查不同的2个运行环境中的数据类型是否一致,可用
‘DATATYPE.SQL’。
b)在2个不同的实例中寻找对象的不同点,可用
‘OBJ_COORD.SQL’。
c)更好的做法是,使用一种工具,象寻求软件的计划管理器那样的
工具。
B.查看是否有危害到安全策略的问题。
C.查看报错的SQL*NET日志。
1.客户端的日志。
2.服务器端的日志。
D..将所有的警告日志存档
E..供应商的主页
1.ORACLE供应商
2.QuestSoftware
3.SunMicrosystems
----------------------------------------------------------------
四.月维护过程
A.查看对数据库会产生危害的增长速度
1.从以前的记录或报告中回顾段增长的变化以此来确定段增长带来危害
B.回顾以前数据库优化性能的调整
1.回顾一般ORACLE数据库的调整点,比较以前的报告来确定有害的发展
趋势。
C.查看I/O的屏颈问题
1.查看前期数据库文件的活动性,比较以前的输出来判断有可能导致屏颈
问题的趋势。
D.回顾FRAGMENTATION
E.计划数据库将来的性能
1.比较ORACLE和操作系统的CPU,内存,网络,及硬盘的利用率以此
来确定在近期将会有的一些资源争夺的趋势
2.当系统将超出范围时要把性能趋势当作服务水平的协议来看
F.完成调整和维护工作
1.使修改满足避免系统资源的争夺的需要,这里面包括增加新资源或使预期
的停工。
----------------------------------------------------------------
五.附录
A.日常程序
--
--free.sql
--
--Toverifyfreespaceintablespaces
--Minimumamountoffreespace
--documentyourthresholds:
--=m
--
SELECTtablespace_name,sum(blocks)asfree_blk,trunc(sum(bytes)/
(1024*1024))asfree_m,max(bytes)/(1024)asbig_chunk_k,count(*)asnum_chunks
FROMdba_free_space
GROUPBYtablespace_name
1.Space.sql
--
--space.sql
--
--Tocheckfree,pct_free,andallocatedspacewithinatablespace
--
--11/24/98
SELECTtablespace_name,largest_free_chunk
nr_free_chunks,sum_alloc_blocks,sum_free_blocks
to_char(100*sum_free_blocks/sum_alloc_blocks,'09.99')||'%'
ASpct_free
FROM(SELECTtablespace_name
sum(blocks)ASsum_alloc_blocks
FROMdba_data_files
GROUPBYtablespace_name
)
(SELECTtablespace_nameASfs_ts_name
max(blocks)ASlargest_free_chunk
count(blocks)ASnr_free_chunks
sum(blocks)ASsum_free_blocks
FROMdba_free_space
GROUPBYtablespace_name)
WHEREtablespace_name=fs_ts_name
2.analyze5pct.sql
--
--analyze5pct.sql
--
--Toanalyzetablesandindexesquickly,usinga5%samplesize
--(donotusethisscriptifyouareperformingtheovernight
--collectionofvolumetricdata)
--
--11/30/98
BEGIN
dbms_utility.analyze_schema('&OWNER','ESTIMATE',NULL,5);
END;
/
3.nr_extents.sql
--
--nr_extents.sql
--
--Tofindoutanyobjectreaching
--extents,andmanuallyupgradeittoallowunlimited
--max_extents(thusonlyobjectswe*expect*tobebig
--areallowedtobecomebig)
--
--11/30/98
SELECTe.owner,e.segment_type,e.segment_name,count(*)asnr_extents,
s.max_extents
to_char(sum(e.bytes)/(1024*1024),'999,999.90')asMB
FROMdba_extentse,dba_segmentss
WHEREe.segment_name=s.segment_name
GROUPBYe.owner,e.segment_type,e.segment_name,s.max_extents
HAVINGcount(*)>&THRESHOLD
OR((s.max_extents-count(*))<&&THRESHOLD)
ORDERBYcount(*)desc
4.spacebound.sql
--
--spacebound.sql
--
--Toidentifyspace-boundobjects.Ifalliswell,norowsarereturned.
--Ifanyspace-boundobjectsarefound,lookatvalueofNEXTextent
--sizetofigureoutwhathappened.
--Thenusecoalesce(altertablespacecoalesce.
--Lastly,addanotherdatafiletothetablespaceifneeded.
--
--11/30/98
SELECTa.table_name,a.next_extent,a.tablespace_name
FROMall_tablesa,
(SELECTtablespace_name,max(bytes)asbig_chunk
FROMdba_free_space
GROUPBYtablespace_name)f
WHEREf.tablespace_name=a.tablespace_name
ANDa.next_extent>f.big_chunk
B.每晚处理程序
1.mk_volfact.sql
--
--mk_volfact.sql(onlyrunthisoncetosetitup;donotrunitnightly!
)
--
----TableUTL_VOL_FACTS
CREATETABLEutl_vol_facts
(
table_nameVARCHAR2(30),
num_rowsNUMBER,
meas_dtDATE
)
TABLESPACEplatab
STORAGE(
INITIAL128k
NEXT128k
PCTINCREASE0
MINEXTENTS1
MAXEXTENTSunlimited
)
/
--PublicSynonym
CREATEPUBLICSYNONYMutl_vol_factsFOR&OWNER..utl_vol_facts
/
--GrantsforUTL_VOL_FACTS
GRANTSELECTONutl_vol_factsTOpublic
/
2.analyze_comp.sql
--
--analyze_comp.sql
--
BEGIN
sys.dbms_utility.analyze_schema('&OWNER','COMPUTE');
END;
/
3.pop_vol.sql
--
--pop_vol.sql
--
insertintoutl_vol_facts
selecttable_name
NVL(num_rows,0)asnum_rows
trunc(last_analyzed)asmeas_dt
fromall_tables--orjustuser_tables
whereownerin('&OWNER')--oracomma-separatedlistofowners
/
commit
/
C.每周处理程序
1.nextext.sql
--
--nextext.sql
--
--Tofindtablesthatdon'tmatchthetablespacedefaultforNEXTextent.
--Theimplicitrulehereisthateverytableinagiventablespaceshould
--usetheexactsamevalueforNEXT,whichshouldalsobethetablespace's
--defaultvalueforNEXT.
--
--ThistellsuswhatthesettingforNEXTisfortheseobjectstoday.
--
--11/30/98
SELECTsegment_name,segment_type,ds.next_extentasActual_Next
dt.tablespace_name,dt.next_extentasDefault_Next
FROMdba_tablespacesdt,dba_segmentsds
WHEREdt.tablespace_name=ds.tablespace_name
ANDdt.next_extent!
=ds.next_extent
ANDds.owner=UPPER('&OWNER')
ORDERBYtablespace_name,segment_type,segment_name
2.existext.sql
--
--existext.sql
--
--Tocheckexistingextents
--
--Thistellsushowmanyofeachobject'sextentsdifferinsizefrom
--thetablespace'sdefaultsize.Ifthisreportshowsalotofdifferent
--sizedextents,yourfreespaceislikelytobecomefragmented.Ifso,
--thistablespaceisacandidateforreorganizing.
--
--12/15/98
SELECTsegment_name,segment_type
count(*)asnr_exts
sum(DECODE(dx.bytes,dt.next_extent,0,1))asnr_illsized_exts
dt.tablespace_name,dt.next_extentasdflt_ext_size
FROMdba_tablespacesdt,dba_extentsdx
WHEREdt.tablespace_name=dx.tablespace_name
ANDdx.owner='&OWNER'
GROUPBYsegment_name,segment_type,dt.tablespace_name,dt.next_extent
3.No_pk.sql
--
--no_pk.sql
--
--TofindtableswithoutPKconstraint
--
--11/2/98
SELECTtable_name
FROMall_tables
WHEREowner='&OWNER'
MINUS
SELECTtable_name
FROMall_constraints
WHEREowner='&&OWNER'
ANDconstraint_type='P'
4.disPK.sql
--
--disPK.sql
--
--Tofindoutwhichprimarykeysaredisabled
--
--11/30/98
SELECTowner,constraint_name,table_name,status
FROMall_constraints
WHEREowner='&OWNER'ANDstatus='DISABLED’ANDconstraint_type='P'
5.nonuPK.sql
--
--nonuPK.sql
--
--TofindtableswithnonuniquePKindexes.Requiresth