没有合适的资源?快使用搜索试试~ 我知道了~
资源推荐
资源详情
资源评论
Oracle 数据库日常维护
本文档包含以下内容:
1.
Oracle 数据库日常维护
2.
Oracle DBA 常用管理脚本
3.
Oracle DB 常用 SQL 语句
在 Oracle 数据库运行期间,DBA 应该对数据库的运行日志及表空间的使用
情况进行监控,及早发现数据库中存在的问题。
一、Oracle 警告日志文件监控
Oracle 在运行过程中,会在警告日志文件(alert_SID.log)中记录数据库的一
些运行情况:
数据库的启动、关闭,启动时的非缺省参数;
数据库的重做日志切换情况,记录每次切换的时间,及如果因为检查点
(checkpoint)操作没有执行完成造成不能切换,会记录不能切换的原因;
对数据库进行的某些操作,如创建或删除表空间、增加数据文件;
数据库发生的错误,如表空间不够、出现坏块、数据库内部错误(ORA
-600)
DBA 应该定期检查日志文件,根据日志中发现的问题及时进行处理
问题
处理
启动参数不对
检查初始化参数文件
因为检查点操作或归档操作没
有完成造成重做日志不能切换
如果经常发生这样的情况,可以考虑增
加重做日志文件组;想办法提高检查点
或归档操作的效率;
有人未经授权删除了表空间
检查数据库的安全问题,是否密码太简
单;如有必要,撤消某些用户的系统权
限
出现坏块
检查是否是硬件问题(如磁盘本生有坏
块),如果不是,检查是那个数据库对象
出现了坏块,对这个对象进行重建
表空间不够
增加数据文件到相应的表空间
出现 ORA-600
根据日志文件的内容查看相应的
TRC
文件,如果是 Oracle 的 bug,要及时打
上相应的补丁
二、数据库表空间使用情况监控(字典管理表空间)
数据库运行了一段时间后,由于不断的在表空间上创建和删除对象,会在
表空间上产生大量的碎片,DBA 应该及时了解表空间的碎片和可用空间情况,
以决定是否要对碎片进行整理或为表空间增加数据文件。
select tablespace_name,
count(*) chunks ,
max(bytes/1024/1024) max_chunk
from dba_free_space
group by tablespace_name;
上面的 SQL 列出了数据库中每个表空间的空闲块情况,如下所示:
TABLESPACE_NAME CHUNKS MAX_CHUNK
INDX
1
57.9921875
RBS
3
490.992188
RMAN_TS
1
16.515625
SYSTEM
1
207.296875
TEMP
20
70.8046875
TOOLS
1
11.8359375
USERS
67
71.3671875
其中,
CHUNKS
列表示表空间中有多少可用的空闲块(每个空闲块是由一些
连续的 Oracle 数据块组成),如果这样的空闲块过多,比如平均到每个数据
文件上超过了 100 个,那么该表空间的碎片状况就比较严重了,可以尝试用以
下的 SQL 命令进行表空间相邻碎片的接合:
alter tablespace 表空间名 cascade;
此处是有误吧,coalesce;
然后再执行查看表空间碎片的 SQL 语句,看表空间的碎片有没有减少。如
果没有效果,并且表空间的碎片已经严重影响到了数据库的运行,则考虑对该
表空间进行重建。
MAX_CHUNK 列的结果是表空间上最大的可用块大小,如果该表空间上
的 对 象 所 需 分 配 的 空 间 (NEXT
值 ) 大于可用块的大小的话, 就会提示
ORA-1652、ORA-1653、ORA-1654 的错误信息,DBA 应该及时对表空间的空
间进行扩充,以避免这些错误发生。
对表空间的扩充对表空间的数据文件大小进行扩展,或向表空间增加数据
文件,具体操作见“存储管理”部份。
三、查看数据库的连接情况
DBA 要定时对数据库的连接情况进行检查,看与数据库建立的会话数目是
不是正常,如果建立了过多的连接,会消耗数据库的资源。同时,对一些“挂
死”的连接,可能会需要 DBA 手工进行清理。
以下的 SQL 语句列出当前数据库建立的会话情况:
select sid,serial#,username,program,machine,status
from v$session;
输出结果为:
SID SERIAL# USERNAME PROGRAM MACHINE STATUS
1
1
ORACLE.EXE
WORK3
ACTIVE
2
1
ORACLE.EXE
WORK3
ACTIVE
3
1
ORACLE.EXE
WORK3
ACTIVE
4
1
ORACLE.EXE
WORK3
ACTIVE
5
3
ORACLE.EXE
WORK3
ACTIVE
6
1
ORACLE.EXE
WORK3
ACTIVE
7
1
ORACLE.EXE
WORK3
ACTIVE
8
27
SYS
SQLPLUS.EXE
WORKGROUP\WORK3
ACTIVE
11
5
DBSNMP
dbsnmp.exe
WORKGROUP\WORK3
INACTIVE
其中,
SID 会话(session)的 ID 号;
SERIAL# 会话的序列号,和 SID 一起用来唯一标识一个会话;
USERNAME 建立该会话的用户名;
剩余73页未读,继续阅读
资源评论
小小哭包
- 粉丝: 1899
- 资源: 3854
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功