OracleDBA的日常工作OracleDBA的日常工作OracleDBA的日常工作V:1.0精细整理,仅供参考OracleDBA的日常工作日期:20xx年X月OracleDBA的日常工作 作者:ThomasB.Cox,withChristineChoi目的:这篇文档有很详细的资料记录着对一个甚至更多的ORACLE数据库每天的,每月的,每年的运行的状态的结果及检查的结果,在文档的附录中你将会看到所有检查,修改的SQL和PL/SQL代码。修改笔记:在SteveDeNunzio的''中所识别的类型 固定的类型 增加的GnuPublicLicense;在重建index中增加pctincr0 加了一个最新的观点,是从GEOCITIES的主页上得到的。 目录 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的运行情况 1.检查每个被管理机器的'DBSNMP'进程并将它们记录到日志中。 在UNIX中,在命令行中,键入ps-ef|grep dbsnmp,将回看到2个DBSNMP进程在运行。如果没有,重启DBSNMP。 D.查数据库备份是否成功 E.检查备份的磁带文档是否成功 F.检查对合理的性能来说是否有足够的资源 1.检查在表空间中有没有剩余空间。 对每一个实例来说,检查在表空间中是否存在有剩余空间来满足当天的预期的需要。当数据库中已有的数据是稳定的,数据日增长的平均数也是可以计算出来,最小的剩余空间至少要能满足每天数据的增长。 A)运行''来检查表空间的剩余空间。 B)运行''来检查表空间中的剩余空间百分率 2.检查回滚段 回滚段的状态一般是在线的,除了一些为复杂工作准备的专用段,它一般状态是离线的. a)每个数据库都有一个回滚段名字的列表。 b)你可以用V$ROLLSTAT来查询在线或是离线的回滚段的现在状态. c)对于所有回滚段的存储参数及名字,可用DBA_ROLLBACK_SEGS来查询。但是它不如V$ROLLSTAT准确。 3.识别出一些过分的增长 查看数据库中超出资源或是增长速度过大的段,这些段的存储参数需要调整 a)收集日数据大小的信息,可以用''。如果你收集的是每晚的信息,则可跳过这一步。 b)检查当前的范围,可用''。 c)查询当前表的大小信息。 d)查询当前索引大小的信息。 e)查询增长趋势。 4.确定空间的范围。 如果范围空间对象的NEXT_EXTENT比表空间所能提供的最大范围还要大,那么这将影响数据库的运行。如果我们找到了这个目标,可以用'ALTER TABLESPACECOALESCE'调查它的位置,或加另外的数据文件。 A)运行''。如果都是正常的,将不返回任何行。 5.回顾CPU,内存,网络,硬件资源论点的过程 A)检查CPU的利用情况,进到x:=>system metrics=>CPU利用页,CPU的最大限度为400,当CPU的占用保持在350以上有一段时间的话,我们就需要查看及研究出现的问题。 G.将存档日志复制到备用数据库中 如果有一个备用数据库,将适当的存档日志复制到备用数据库的期望位置,备用数据库中保存最近期的数据。 F.经常查阅DBA用户手册 如果有可能的话,要广泛的阅读,包括DBA手册,行业杂志,新闻组或是邮件列表。 二.晚间维护过程 大部分的数据库产品将受益于每晚确定的检查进程的运行。 A。收集VOLUMETRIC数据 1.分析计划和收集数据 更准确的分析计算并保存结果, a)如果你现在没有作这些的话,用'MK'来创建测定体积的表。 b)收集晚间数据大小的信息,用'ANALYZE'。 c)收集统计结果,用'POP'。 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)查看那些表没有主键,可用''。 b)查找那些主键是没有发挥作用的,可用''。 c)所有作索引的主键都要是唯一的,可用'NONUPK。SQL'来检查。 3所有的索引都要放到索引表空间中。运行'MKREBUILD_IDX。SQL' 4不同的环境之间的计划应该是同样的,特别是测试环境和成品环境之间的计划应该相同。 d)检查不同的2个运行环境中的数据类型是否一致,可用''。 e)在2个不同的实例中寻找对象的不同点,可用''. f)更好的做法是,使用一种工具,象寻求软件的计划管理器那样的工具。 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、日常程序 -- -- -- --Toverifyfreespaceintablespaces --Minimumamountoffreespace --documentyourthresholds: --=m -- SELECTtablespace_name,sum(blocks)asfree_blk,trunc( sum(bytes)/(1024*1024))asfree_m ,max(bytes)/(1024)asbig_chunk_k,count(*)as num_chunks FROMdba_free_space GROUPBYtablespace_name 1. -- -- -- --Tocheckfree,pct_free,andallocatedspacewithina tablespace -- --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,'')|| '%' 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. -- -- -- --Toanalyzetablesandindexesquickly,usinga5%sample size --(donotusethisscriptifyouareperformingtheovernight --collectionofvolumetricdata) -- --11/30/98 BEGIN ('&OWNER','ESTIMATE',NULL,5) ; END; / 3. -- -- -- --Tofindoutanyobjectreaching --extents,andmanuallyupgradeittoallowunlimited --max_extents(thusonlyobjectswe*expect*tobebig --areallowedtobecomebig) -- --11/30/98 SELECT,,,count(*)as nr_extents, ,to_char(sum()/(1024*1024),'999,') asMB FROMdba_extentse,dba_segmentss WHERE= GROUPBY,,, HAVINGcount(*)>&THRESHOLD OR((-count(*))<&&THRESHOLD) ORDERBYcount(*)desc 4. -- -- -- --Toidentifyspace-boundobjects.Ifalliswell,norows arereturned. --Ifanyspace-boundobjectsarefound,lookatvalueofNEXT extent --sizetofigureoutwhathappened. --Thenusecoalesce(altertablespacecoalesce. --Lastly,addanotherdatafiletothetablespaceifneeded. -- --11/30/98 SELECT,, FROMall_tablesa, (SELECTtablespace_name,max(bytes)asbig_chunk FROMdba_free_space GROUPBYtablespace_name)f WHERE= AND> B.每晚处理程序 1. -- --(onlyrunthisoncetosetitup;donotrun itnightly!) -- ----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. -- -- -- BEGIN ('&OWNER','COMPUTE'); END; / 3. -- -- -- insertintoutl_vol_facts selecttable_name ,NVL(num_rows,0)asnum_rows ,trunc(last_analyzed)asmeas_dt fromall_tables--orjustuser_tables whereownerin('&OWNER')--oracomma-separatedlistof owners / commit / C.每周处理程序 1. -- -- -- --Tofindtablesthatdon'tmatchthetablespacedefaultfor NEXTextent. --Theimplicitrulehereisthateverytableinagiven tablespaceshould --usetheexactsamevalueforNEXT,whichshouldalsobethe tablespace's --defaultvalueforNEXT. -- --ThistellsuswhatthesettingforNEXTisforthese objectstoday. -- --11/30/98 SELECTsegment_name,segment_type,as Actual_Next ,,asDefault_Next FROMdba_tablespacesdt,dba_segmentsds WHERE= AND!= AND=UPPER('&OWNER') ORDERBYtablespace_name,segment_type,segment_name 2. -- -- -- --Tocheckexistingextents -- --Thistellsushowmanyofeachobject'sextentsdifferin sizefrom --thetablespace'sdefaultsize.Ifthisreportshowsalot ofdifferent --sizedextents,yourfreespaceislikelytobecome fragmented.Ifso, --thistablespaceisacandidateforreorganizing. -- --12/15/98 SELECTsegment_name,segment_type ,count(*)asnr_exts ,sum(DECODE(,,0,1))as nr_illsized_exts ,,asdflt_ext_size FROMdba_tablespacesdt,dba_extentsdx WHERE= AND='&OWNER' GROUPBYsegment_name,segment_type,, 3. -- -- -- --TofindtableswithoutPKconstraint -- --11/2/98 SELECTtable_name FROMall_tables WHEREowner='&OWNER' MINUS SELECTtable_name FROMall_constraints WHEREowner='&&OWNER' ANDconstraint_type='P' 4. -- -- -- --Tofindoutwhichprimarykeysaredisabled -- --11/30/98 SELECTowner,constraint_name,table_name,status FROMall_constraints WHEREowner='&OWNER'ANDstatus='DISABLED'AND constraint_type='P' 5. -- -- -- --TofindtableswithnonuniquePKindexes.RequiresthatPK names --followanamingconvention.Analternativequeryfollows that --doesnothavethisrequirement,butrunsmoreslowly. -- --11/2/98 SELECTindex_name,table_name,uniqueness FROMall_indexes WHEREindex_namelike'&PKNAME%' ANDowner='&OWNER'ANDuniqueness='NONUNIQUE' SELECT,, FROMall_constraintsc,all_indexesi WHERE=UPPER('&OWNER')AND= 'NONUNIQUE' AND='P'AND= 6. -- -- -- --Rebuildindexestohavecorrectstorageparameters -- --11/2/98 SELECT'alterindex'||index_name||'rebuild' ,'tablespaceINDEXESstorage' ||'(initial256Knext256Kpctincrease0);' FROMall_indexes WHERE(tablespace_name!='INDEXES' ORnext_extent!=(256*1024) ) ANDowner='&OWNER' / 7. -- -- -- --Tocheckdatatypeconsistencybetweentwoenvironments -- --11/30/98 SELECT table_name, column_name, data_type, data_length, data_precision, data_scale, nullable FROMall_tab_columns--firstenvironment WHEREowner='&OWNER' MINUS SELECT table_name, column_name, data_type, data_length, data_precision, data_scale, nullable FROMall_tab_columns@&my_db_link--secondenvironment WHEREowner='&OWNER2' orderbytable_name,column_name 8. -- -- -- --Tofindoutanydifferenceinobjectsbetweentwoinstances -- --12/08/98 SELECTobject_name,object_type FROMuser_objects MINUS SELECTobject_name,object_type FROMuser_objects@&my_db_link 六、参考文献 1.Loney,KevinOracle8DBAHandbook 2.Cook,DavidDatabaseManagementfromCrisistoConfidence [ 3.Cox,ThomasB.TheDatabaseAdministrationMaturityModel