首页 Oracle DBA的日常工作

Oracle DBA的日常工作

举报
开通vip

Oracle DBA的日常工作OracleDBA的日常工作OracleDBA的日常工作OracleDBA的日常工作V:1.0精细整理,仅供参考OracleDBA的日常工作日期:20xx年X月OracleDBA的日常工作 作者:ThomasB.Cox,withChristineChoi目的:这篇文档有很详细的资料记录着对一个甚至更多的ORACLE数据库每天的,每月的,每年的运行的状态的结果及检查的结果,在文档的附录中你将会看到所有检查,修改的SQL和PL/SQL代码。修改笔记:在SteveDeNunzio的''中所识别的类型...

Oracle DBA的日常工作
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
本文档为【Oracle DBA的日常工作】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
该文档来自用户分享,如有侵权行为请发邮件ishare@vip.sina.com联系网站客服,我们会及时删除。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。
本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。
网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
下载需要: 免费 已有0 人下载
最新资料
资料动态
专题动态
个人认证用户
哥只是个传说
工作认真,对数据非常敏感,,善于沟通
格式:doc
大小:61KB
软件:Word
页数:10
分类:企业经营
上传时间:2022-10-15
浏览量:1