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/ ‘tail’命令来查看alert_ 如果发现任何新的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/ 4). 在提示下,使用 ‘TAIL’命令查看alert_ 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 (*) 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 (*)) < &&threshold) ORDER BY COUNT (*) DESC -★- spacebound.sql AS -- To identify space-bound objects. If all is well, no rows are returned. -- If any space-bound objects are found, look at value of NEXT extent size to figure out what happened. -- Then use coalesce (alter tablespace -- 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 dt.next_extent; BY segment_name, segment_type, dt.tablespace_name, 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, uniqueness FROM all_indexes WHERE index_name LIKE '&KNAME%' AND owner = '&OWNER' AND uniqueness = 'NONUNIQUE' UNION SELECT c.constraint_name, i.tablespace_name, i.uniqueness FROM all_constraints c, all_indexes i WHERE c.owner = UPPER ('&OWNER') AND i.uniqueness = '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 FROM [email=all_tab_columns@&my_db_link]all_tab_columns@&my_db_link[/email] -- second 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 user_objects MINUS SELECT object_name, object_type FROM [email=user_objects@&my_db_link]user_objects@&my_db_link[/email] 因篇幅问题不能全部显示,请点此查看更多更全内容
Copyright © 2019- jqkq.cn 版权所有 赣ICP备2024042794号-4
违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com
本站由北京市万商天勤律师事务所王兴未律师提供法律服务