Oracle管理工作手册.docx
《Oracle管理工作手册.docx》由会员分享,可在线阅读,更多相关《Oracle管理工作手册.docx(68页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、编号:时间:2021年x月x日书山有路勤为径,学海无涯苦作舟页码:第68页 共68页ORACLE管理工作手册 EAS产品支持部 蒋俊 请注意:本文件只作为产品介绍之用,不属于您与金蝶签署的任何协议。本文件仅包括金蝶既定策略、产品及功能方面的信息,不能以本文件作为要求金蝶履行商务条款、产品策略以及开发义务的依据。本文件内容可能随时变更,恕不另行通知。前 言概述该文档主要目的是降低现场实施人员及用户Oracle数据库的管理难度,提高Oracle数据库技术能力,文档针对Oracle9i、10g两个版本提供了一套完整的Oracle数据库监控、管理的思路、方法步骤,依照该手册进行Oracle数据库的日常
2、工作,能有效地把握Oracle后台数据库的整体运行健康状况,通过收集相关重要信息分析,能很好地防范即将出现的系统风险,系统出现问题后尽快地定位问题,现场解决一部分常规数据库问题。对其它专业要求比较强的数据库问题,也能为后续Oracle专家深入分析、诊断问题提供规范、完整的信息。文档按问题处于的阶段分两部分事前阶段、事中阶段,事前阶段描述了每天、每周末、每月末针对数据库所需进行的管理工作,如:日常监控,包括有环境监控、数据库运行状况监控、性能监控;日常数据库管理,包括:系统运行快照采集、表空间管理、数据库备份恢复、表、索引统计分析、TOP会话、SQL执行计划信息查看等。涉及有相关图形化管理工具使
3、用方法、数据库自动脚本、命令使用方法。事中阶段描述了数据库发生问题时的处理思路,需要收集哪些相关信息。适用范围适于需求分析、设计、实现和测试、实施所有阶段。适于架构设计师、系统设计师、开发工程师和项目经理。适于EAS产品所有版本。约定符号约定在本文中可能出现下列标志,它们所代表的含义如下。符号说明表示有潜在风险,如果忽视这些文本,可能导致操作错误、数据丢失、设备性能降低或不可预知的结果。表示可以帮助您获取更多相关信息或提示您通过其它方式也可以获得相同结果。强调或补充说明所描述的信息。内容约定本处对文中通用信息作如下约定 l $EAS_HOME表示EAS服务器安装的根目录,即安装过程中输入的本地
4、路径。 l $BOS_HOME表示BOS工具的安装根目录,即安装过程中输入的本地路径。目 录概述2适用范围2约定21 事前阶段61.1 日常工作每天应做工作内容61.1.1 工作内容日常环境监控61.1.2 工作内容日常性能监控81.1.3 工作内容日常数据库管理181.2 日常工作每隔一周工作内容601.2.1 文件整理工作601.2.2 数据库全量备份601.2.3 根据一周数据增长率分析预留数据文件下一周所需增长空间611.2.4 索引使用情况及碎片分析641.2.5 对用户所有表、索引进行统计分析661.2.6 导出表、索引最新统计分析数据721.2.7 性能报告分析731.3 日常工
5、作每月应做工作内容731.3.1 性能全面分析731.3.2 备份数据转备731.4 日常工作数据库第一次安装部署后需做的工作731.4.1 Statspack系统快照采集工具初始化731.4.2 创建统计信息导出表741.4.3 运行EAS用户下所有表、索引统计分析,导出基准统计信息741.4.4 创建Oracle10g 逻辑备份dump文件存放目录752 事中阶段752.1 Oracle数据库出现问题时需掌握的相关信息752.1.1 问题症状描述752.1.2 问题在什么地方出现752.1.3 问题在什么时间出现762.1.4 问题在什么条件下出现762.1.5 问题涉及的范围762.1.
6、6 问题是否能重现772.1.7 数据库运行环境软、硬件基本信息772.1.8 Oracle性能相关772.2 Oracle数据库问题的解决途径771 事前阶段1.1 日常工作每天应做工作内容1.1.1 工作内容日常环境监控1) 系统运行环境监控查看Oracle 数据文件、控制文件、联机日志及归档日志存放的文件系统或裸设备空间使用情况。重点关注Oracle软件及数据文件所在卷空间使用率:su - oracleAIX、linux查看磁盘空间:df kv HP-UX查看磁盘空间:bdf检测操作系统CPU、内存、交换区、I/O配置状况AIX :CPU、内存、网络、IO、进程、页面交换:topasLi
7、nux、HP-UX :CPU、内存、网络、IO、进程、页面交换: top2) 数据库运行状况监控外部检查Oracle实例核心后台进程是否都存在、状态是否正常$ ps -ef|grep ora_查看数据库实例是否能正常连接、访问SQL select status from v$instance;监听是否正常$ lsnrctl status内部是否有表空间出现故障SQL select tablespace_name,status from dba_tablespaces;日志文件是否正常SQL Select * from v$log;SQL Select * from v$logfile;1.1.
8、2 工作内容日常性能监控1) 间隔一段时间使用操作系统top等工具监控系统资源动态运行状况CPU、内存、网络、IO、进程、页面交换等主要活动监控: top、topas、vmstat、iostat等2) 间隔一段时间对数据库性能进行监控Oracle 9i 图形工具Performance Manager监控顶层会话及顶层SQL1 打开OEM控制台,选中要监控的数据库。2 工具中选择 Diagnostic PackPerformance Manager,也可直接选中Top Session或Top SQL。Oracle9i 的Performance Manager工具监控内容主要有:内存的使用情况,I
9、O情况,Oracle数据库进程情况,sql语句运行情况等,主界面如下: 可以通过顶层会话下钻获取到相关SQL执行计划等信息,也可以直接查看TopSql选项获取当前执行最频繁、消耗资源最多的SQL语句:在数据页签下面列出了监控的选项列表,可以根据各类选项对SQL语句进行排序。选中相关SQL语句,单击右键选择“下钻”到“解释计划”查看执行计划: 执行计划显示如下:Oracle10g OEM工具监控顶层会话及获取SQL详细信息登录Oracle10g OEM,选择性能其它监视链接:顶级活动点击顶级会话中的会话ID 点击SQL ID,查看该顶级会话中SQL的详细信息点击计划标签,查看该SQL语句的详细执
10、行计划浏览该顶层会话对应SQL语句的详细信息字符界面下Sql语句及用户进程信息采集l 通过视图查看当前主要影响性能SQL语句语法模版SELECT * FROM (SELECT hash_value,address,substr(sql_text,1,40) sql, list of columns, list of derived values FROM V$SQL or V$SQLXS or V$SQLAREA WHERE list of threshold conditions for columns ORDER BY list of ordering columns DESC)WHERE
11、 rownum 100000 AND executions 10 ORDER BY buffer_gets DESC)WHERE rownum select sid,serial#,username from v$session;开始跟踪结束跟踪Exec dbms_system.set_ev(9,437,10046,8,用户名);Exec dbms_system.set_ev(9,437,10046,0,用户名);生成的跟踪文件在user_dump_dest目录下 tkprof工具输出跟踪报表信息tkprof /opt/oracle/admin/ytcw/udump/ytcw_ora_1026
12、.trc /opt/oracle/admin/ytcw/udump/ytcw_ora_1026.prf aggregate=yes sys=no sort=fchela1.1.3 工作内容日常数据库管理1) 一天内间隔一定时间运行检查警告日志文件中最新错误信息Linux、Unix系列平台:vi alertsid.log输入:“/ORA” 回车进行查找Windows平台下使用常用的文本编辑工具即可查看搜索警告日志文件中Oracle错误信息系统运行状况快照采集每天根据实际情况,在以下三个阶段手工运行Statspack快照采集,输出快照报表:l 正常工作压力下l 每天业务最高峰期l 特殊业务运行阶段
13、Oracle 9i自动化脚本方式快照采集创建当前时间点快照如需采集当前数据库运行状况快照,取20分钟时间间隔运行该脚本两次自动执行statspack快照脚本:statspack_auto_exec.sh#!/bin/sh# creator: james_jiang# function: produce statpack snapshotecho Auto Execute Statspack$ORACLE_HOME/bin/sqlplus /nolog EOFconnect perfstat/perfstatexec statspack.snapecho Auto execute statspa
14、ck successfully!exitEOF输出最近两个快照时间点之间的快照信息报表自动产生最近两个快照时间点统计信息快照脚本:statspack_auto_report.sh#!/bin/sh# creator: james_jiang# function:get statpack reportecho Auto create statspack snapshot!SQLPLUS=$ORACLE_HOME/bin/sqlplusLOGFILE=$ORACLE_HOME/spreport.logREPFILE=$ORACLE_HOME/spreport.lst$ORACLE_HOME/bin
15、/sqlplus -S perfstat/perfstat EOFSET ECHO OFFSET HEADING OFFSET FEEDBACK OFFSET PAGESIZE 0SET LINESIZE 1000SET TRIMSPOOL ONSPOOL $LOGFILEselect SNAP_ID from (select SNAP_ID from stats$snapshot where INSTANCE_NUMBER=1 order by SNAP_TIME desc) where rownum3;SPOOL OFF;set echo onset feedback onset head
16、ing onexitEOFline1=tail -1 $LOGFILEline2=head -1 $LOGFILEecho line1 is$line1echo line2 is$line2$ORACLE_HOME/bin/sqlplus -S perfstat/perfstat connect target sys/oraclermanconfigure controlfile autobackup on;rmanconfigure controlfile autobackup format for device type disk to f:rman_bak%F.ctl;rmanconfi
17、gure snapshot controlfile name to f:rman_baksnap_%F.ctl;Rman备份命令写到一个脚本中,在命令行中执行这个脚本RMAN TARGET / NOCATALOG sys/oracle CMDFILE f: backup_incre_1.rcv LOG f: backup_incre_1.log以下为增量备份脚本,备份同时删除一天前的所有归档日志。该命令可设置为crontab(unix/linux),bat批处理任务(Windows),每天在特定的时间点自动运行。增量备份脚本: backup_incre_1.rcvrun allocate ch
18、annel c1 type DISK ;backup incremental level = 1 format f:rman_bakincre_1_%d_%s_%p.bak(database include current controlfile);backup format f:rman_bakarch%u_%s_%p.bak(archivelog from time sysdate-1 all delete input);增量备份脚本: backup_incre_1.rcvrun allocate channel c1 type DISK ;backup incremental level
19、 = 1 format f:rman_bakincre_1_%d_%s_%p.bak(database include current controlfile);backup format f:rman_bakarch%u_%s_%p.bak(archivelog from time sysdate-1 all delete input);显示RMAN备份集信息:RMAN list backupset;手工删除闪回区归档日志oracle 归档日志满处理方法如下,通常 Oracle 或第三方备份软件备份完归档后都应该及时删除已经备份的归档日志,否则归档日志会占用大量磁盘空间#su - oracl
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Oracle 管理工作 手册
限制150内