oracle日常维护巡检工作汇总由刀豆文库小编整理,希望给你工作、学习、生活带来方便,猜你可能喜欢“日常维护及巡检方案”。
oracle 日常维护工作内容
(1).每天对ORACLE数据库的运行状态,日志文件,备份情况,数据库的空间使用情况,系统资源的使用情况进行检查,发现并解决问题。
(2).每周对数据库对象的空间扩展情况,数据的增长情况进行监控,对数据库做健康检查,对数据库对象的状态做检查。
==================== 每天工作
==================== 1.(1).确认所有的INSTANCE状态正常.登陆到所有数据库或例程,检测ORACLE后台进程: $ps –-ef|grep ora(2).检查文件系统的使用(剩余空间)。如果文件系统的剩余空间小于20%,需删除不用的文件以释放空间。
对于业务交易生产系统和 数据库日志归档目录,当空间不足,请急时清理.$df-h(3).检查日志文件和trace文件记录alert和trace文件中的错误.连接到数据库服务器 cd 到bdump目录,通常是$ORACLE_BASE/admin//bdump „tail‟命令来查看alert_.log文件 如果发现任何新的ORA-错误,记录并解决
(4).检查数据文件的状态记录状态不是“online”的数据文件,并做恢复。
Select file_name from dba_data_files where status=’OFFLINE’
(5).检查表空间的使用情况
SELECT SUM(bytes)/(1024 * 1024)AS free_space, tablespace_name FROM dba_free_space GROUP BY tablespace_name;SELECT a.tablespace_name, a.bytes total, b.bytes used, c.bytes free,(b.bytes * 100)/ a.bytes “% USED ”,(c.bytes * 100)/ a.bytes “% FREE ”
FROM sys.sm$ts_avail a, sys.sm$ts_used b, sys.sm$ts_free c WHERE a.tablespace_name = b.tablespace_name AND a.tablespace_name = c.tablespace_name;(6).检查剩余表空间
SELECT tablespace_name, SUM(blocks)AS free_blk, TRUNC(SUM(BYTES)/(1024 * 1024))AS free_m, MAX(BYTES)/(1024)AS big_chunk_k, COUNT(*)AS num_chunks FROM dba_free_space GROUP BY tablespace_name;(7).检查数据库性能,记录数据库的cpu使用、IO、buffer命中率等等
使用vmstat,iostat,glance,top等命令 ==================== 每周工作
====================(1).监控数据库对象的空间扩展情况
根据本周每天的检查情况找到空间扩展很快的数据库对象,并采取相应的措施
alter tablespace 表空间名 add datafile '/u1/oradata/userdata_002.ora' size *m;(2).检查无效的数据库对象
SELECT owner, object_name, object_type FROM dba_objects WHERE status = 'invalid';(3).检查不起作用的约束
SELECT owner, constraint_name, table_name, constraint_type, status FROM dba_constraints WHERE status = 'DISABLED' AND constraint_type = 'P';(4).检查无效的trigger SELECT owner, trigger_name, table_name, status FROM dba_triggers WHERE status = 'DISABLED';
==================== 每月的工作
====================(1).检查表空间碎片
根据本月每周的检查分析数据库碎片情况,找到相应的解决方法
(2).寻找数据库性能调整的机会
比较每天对数据库性能的监控报告,确定是否有必要对数据库性能进行调整(3).数据库性能调整 如有必要,进行性能调整(4).提出下一步空间管理计划
根据每周的监控,提出空间管理的改进方法
====================================== ====================================== || ★★★Oracle DBA 日常管理★★★ || ====================================== ====================================== 目的:这篇文档有很详细的资料记录着对一个甚至更多的ORACLE 数据库每天的,每月的,每年的运行的状态的结果及检查的结果,在文档的附录中你将会看到所有检查,修改的SQL和PL/SQL 代码。-------------★目录 ★-------------1.日常维护程序
A. 查找一些新的警告日志 B. 检查数据库备份是否正确
C. 检查数据库的性能是否正常合理,是否有足够的空间和资源 D. 将文档日志复制到备份的数据库中 2.晚间维护程序
A.收集VOLUMETRIC 的数据 3.每周维护工作
A. 查找那些破坏规则的OBJECT B. 查找是否有违反安全策略的问题 C. 查看错误地方的SQL*NET 日志 D. 将所有的警告日志存档 4.月维护程序
A. 查看对数据库会产生危害的增长速度 B. 回顾以前数据库优化性能的调整 C. 查看I/O 的屏颈问题 D. 回顾FRAGMENTATION E. 将来的执行计划 F. 查看调整点和维护 5.附录
A. 月维护过程 B. 晚间维护过程 C. 周维护过程
================== 一.日维护过程
================== A.查找新的警告日志文件
1).联接操作管理系统
2).使用„TELNET‟或是可比较程序
3).对每一个管理实例,经常的执行$ORACLE_BASE//bdump 操作,并使其能回退到控制数据库的SID。
4).在提示下,使用 „TAIL‟命令查看alert_.log,或是用其他方式检查文件中最近时期的警告日志
5).如果以前出现过的一些ORA_ERRORS 又出现,将它记录到数据库恢复日志中并且仔细的研究它们,这个数据库恢复日志在〈FILE〉中 B.查数据库备份是否成功
C.检查对合理的性能来说是否有足够的资源
1).检查在表空间中有没有剩余空间。
对每一个实例来说,检查在表空间中是否存在有剩余空间来满足当天的预期的需要。当数据库中已有的数据是稳定的,数据日增长的平均
数也是可以计算出来,最小的剩余空间至少要能满足每天数据的增长。A)运行„FREE.SQL‟来检查表空间的剩余空间。B)运行„SPACE.SQL‟来检查表空间中的剩余空间百分率
3).识别出一些过分的增长
查看数据库中超出资源或是增长速度过大的段,这些段的存储参 数需要调整。
a)收集日数据大小的信息,可以用„ANALYZE5PCT.SQL‟。如果你收集的是每晚的信息,则可跳过这一步。
b)检查当前的范围,可用„NR.EXTENTS.SQL‟。
如果范围空间对象的NEXT_EXTENT 比表空间所能提供的最大范围还要大,那么这将影响数据库的运行。如果我们找到了这个目标,可以用„ALTER TABLESPACE COALESCE‟调查它的位置,或加另外 的数据文件。
A)运行„SPACEBOUND.SQL‟。如果都是正常的,将不返回任何行。5).回顾CPU,内存,网络,硬件资源论点的过程 A)检查CPU的利用情况,进到x:.htm =>system metrics=>CPU 利用页,CPU 的最大限度为400,当CPU 的占用保持在350 以上有一段时间的话,我们就需要查看及研究出现的问题。
G.将存档日志复制到备用数据库中如果有一个备用数据库,将适当的存档日志复制到备用数据库的期望位置,备用数据库中保存最近期的数据。==================== 二.晚间维护过程
==================== 大部分的数据库产品将受益于每晚确定的检查进程的运行。A.收集VOLUMETRIC 数据
1.分析计划和收集数据更准确的分析计算并保存结果。
a)如果你现在没有作这些的话,用„MK VOLFACT.SQL‟来创建测定体积的表。b)收集晚间数据大小的信息,用„ANALYZE COMP.SQL‟。c)收集统计结果,用„POP VOL.SQL‟。
d)在空闲的时候检查数据,可能的话,每周或每个月进行。==================== 三.每周维护过程
==================== A. 查找被破坏的目标
1.所有的索引都要放到索引表空间中。运行‘MKREBUILD_IDX.SQL’
B. 查看报错的SQL*NET 日志。1.客户端的日志。2.服务器端的日志。C.将所有的警告日志存档
※做好每天的记录,总结分析表空间的增长幅度※-★-Free.sql 查看剩余表空间
SELECT tablespace_name, SUM(blocks)AS free_blk, TRUNC(SUM(BYTES)/(1024 * 1024))AS free_m, MAX(BYTES)/(1024)AS big_chunk_k, COUNT(*)AS num_chunks FROM dba_free_space GROUP BY tablespace_name-★-Space.sql 查看表空间使用情况
SELECT tablespace_name, largest_free_chunk, nr_free_chunks, sum_alloc_blocks, sum_free_blocks, TO_CHAR(100 * sum_free_blocks / sum_alloc_blocks, '09.99')|| '%' AS pct_free FROM(SELECT tablespace_name, SUM(blocks)AS sum_alloc_blocks FROM dba_data_files GROUP BY tablespace_name),(SELECT tablespace_name AS fs_ts_name, MAX(blocks)AS largest_free_chunk, COUNT(blocks)AS nr_free_chunks, SUM(blocks)AS sum_free_blocks FROM dba_free_space GROUP BY tablespace_name)WHERE tablespace_name = fs_ts_name-★-analyze5pct.sql BEGIN dbms_utility.analyze_schema('&OWNER', 'ESTIMATE', NULL, 5);END;/-★-nr_extents.sql--To find out any object reaching;--extents, and manually upgrade it to allow unlimited max_extents(thus only objects we *expect* to be big are allowed to become big)/* Formatted on 2007/03/06 17:25(Formatter Plus v4.8.7)*/ SELECT e.owner, e.segment_type, e.segment_name, COUNT(*)AS nr_extents, s.max_extents, TO_CHAR(SUM(e.BYTES)/(1024 * 1024), '999,999.90')AS mb FROM dba_extents e, dba_segments s WHERE e.segment_name = s.segment_name GROUP BY e.owner, e.segment_type, e.segment_name, s.max_extents HAVING COUNT(*)> &threshold OR((s.max_extents-COUNT(*));coalesce.--Lastly, add another datafile to the tablespace if needed./* Formatted on 2007/03/06 17:26(Formatter Plus v4.8.7)*/ SELECT a.table_name, a.next_extent, a.tablespace_name FROM all_tables a,(SELECT tablespace_name, MAX(BYTES)AS big_chunk FROM dba_free_space GROUP BY tablespace_name)f WHERE f.tablespace_name = a.tablespace_name AND a.next_extent > f.big_chunk =================== ★B.每晚处理程序★
===================-★-mk_volfact.sql--mk_volfact.sql(only run this once to set it up;do not run it nightly!)--Table UTL_VOL_FACTS CREATE TABLE utl_vol_facts(table_name VARCHAR2(30), num_rows NUMBER, meas_dt DATE)TABLESPACE platab STORAGE(INITIAL 128k NEXT 128k PCTINCREASE 0 MINEXTENTS 1 MAXEXTENTS unlimited)/-★-Public Synonym CREATE PUBLIC SYNONYM utl_vol_facts FOR &OWNER..utl_vol_facts /-★-Grants for UTL_VOL_FACTS GRANT SELECT ON utl_vol_facts TO public /-★-analyze_comp.sql BEGIN sys.dbms_utility.analyze_schema('&OWNER','COMPUTE');END;/-★-pop_vol.sql /* Formatted on 2007/03/06 17:28(Formatter Plus v4.8.7)*/ INSERT INTO utl_vol_facts SELECT table_name, NVL(num_rows, 0)AS num_rows, TRUNC(last_analyzed)AS meas_dt FROM all_tables--or just user_tables WHERE owner IN('&OWNER');--or a comma-separated list of owners / commit;/ =================== ★C.每周处理程序★
=================== 1.nextext.sql--To find tables that don't match the tablespace default for NEXT extent.--The implicit rule here is that every table in a given tablespace should--use the exact same value for NEXT, which should also be the tablespace's--default value for NEXT.--This tells us what the setting for NEXT is for these objects today./* Formatted on 2007/03/06 17:30(Formatter Plus v4.8.7)*/ SELECT segment_name, segment_type, ds.next_extent AS actual_next, dt.tablespace_name, dt.next_extent AS default_next FROM dba_tablespaces dt, dba_segments ds WHERE dt.tablespace_name = ds.tablespace_name AND dt.next_extent!= ds.next_extent AND ds.owner = UPPER('&OWNER')ORDER BY tablespace_name, segment_type, segment_name 2.existext.sql--To check existing extents--This tells us how many of each object's extents differ in size from the tablespace's default size.If this report shows a lot of different sized extents, your free space is likely to become fragmented.If so,--this tablespace is a candidate for reorganizing./* Formatted on 2007/03/06 17:31(Formatter Plus v4.8.7)*/ SELECT segment_name, segment_type, COUNT(*)AS nr_exts, SUM(DECODE(dx.BYTES, dt.next_extent, 0, 1))AS nr_illsized_exts, dt.tablespace_name, dt.next_extent AS dflt_ext_size FROM dba_tablespaces dt, dba_extents dx WHERE dt.tablespace_name = dx.tablespace_name AND dx.owner = '&OWNER' GROUP BY segment_name, segment_type, dt.tablespace_name, dt.next_extent;3.No_pk.sql--To find tables without PK constraint /* Formatted on 2007/03/06 17:31(Formatter Plus v4.8.7)*/ SELECT table_name FROM all_tables WHERE owner = '&OWNER' MINUS SELECT table_name FROM all_constraints WHERE owner = '&&OWNER' AND constraint_type = 'P';4.disPK.sql--To find out which primary keys are disabled /* Formatted on 2007/03/06 17:32(Formatter Plus v4.8.7)*/ SELECT owner, constraint_name, table_name, status FROM all_constraints WHERE owner = '&OWNER' AND status = 'DISABLED' AND constraint_type = 'P' 5.nonuPK.sql--To find tables with nonunique PK indexes.Requires that PK names--follow a naming convention.An alternative query follows that--does not have this requirement, but runs more slowly./* Formatted on 2007/03/06 17:33(Formatter Plus v4.8.7)*/ SELECT index_name, table_name, uniquene FROM all_indexes WHERE index_name LIKE '&KNAME%' AND owner = '&OWNER' AND uniquene = 'NONUNIQUE' UNION SELECT c.constraint_name, i.tablespace_name, i.uniquene FROM all_constraints c, all_indexes i WHERE c.owner = UPPER('&OWNER')AND i.uniquene = 'NONUNIQUE' AND c.constraint_type = 'P' AND i.index_name = c.constraint_name 6.mkrebuild_idx.sql--Rebuild indexes to have correct storage parameters /* Formatted on 2007/03/06 17:33(Formatter Plus v4.8.7)*/ SELECT 'alter index ' || index_name || ' rebuild ', 'tablespace INDEXES storage ' || '(initial 256 K next 256 K pctincrease 0);' FROM all_indexes WHERE(tablespace_name!= 'INDEXES' OR next_extent!=(256 * 1024))AND owner = '&OWNER' / 7.datatype.sql--To check datatype consistency between two environments /* Formatted on 2007/03/06 17:34(Formatter Plus v4.8.7)*/ SELECT table_name, column_name, data_type, data_length, data_precision, data_scale, nullable FROM all_tab_columns--first environment WHERE owner = '&OWNER' MINUS SELECT table_name, column_name, data_type, data_length, data_precision, data_scale, nullable
[email=all_tab_columns@&my_db_link]all_tab_columns@&my_db_link[/email] environment WHERE owner = '&OWNER2' ORDER BY table_name, column_name;
8.obj_coord.sql--To find out any difference in objects between two instances /* Formatted on 2007/03/06 17:35(Formatter Plus v4.8.7)*/ SELECT object_name, object_type
FROM
--second FROM user_objects MINUS SELECT object_name, object_type FROM [email=user_objects@&my_db_link]user_objects@&my_db_link[/email]