ORACLE归档模式与非归档模式
来源:互联网 发布:数据来源于天地图 编辑:程序博客网 时间:2024/05/01 19:02
一、 什么是ORACLE归档模式
ORACLE数据库有联机重做日志, 这个日志是记录对数据库所做的修改, 比如插入、删除、更新数据等, 对这些操作都会记录在联机重做日志里。一般数据库至少要有2个联机重做日志组。当一个联机重做日志组被写满的时候, 就会发生日志切换, 这时联机重做日志组2成为当前使用的日志, 当联机重做日志组2写满时候, 又会发生日志切换, 去写联机重做日志组1, 就这样反复进行。
如果数据库处于非归档模式, 联机日志在切换时就会丢弃, 而在归档模式下, 当发生日志切换的时候, 被切换的日志会进行归档。比如, 当前在使用联机重做日志1, 当1写满的时候, 发生日志切换, 开始写联机重做日志2, 这时联机重做日志1的内容会被拷贝到另外一个指定的目录下。这个目录叫做归档目录, 拷贝的文件叫归档重做日志。
数据库使用归档方式运行时候才可以进行灾难性恢复。
二、 归档模式与非归档模式的在备份上的区别
非归档模式只能做冷备份, 并且恢复时只能做完全备份, 最近一次完全备份到系统出错期间的数据不能恢复。
归档模式可以做热备份, 并且可以做增量备份, 可以做部分恢复。
三、 查看ORACLE数据库是否为归档模式
3.1 SQL代码
SELECT NAME, LOG_MODE FROM V$DATABASE ;
NAME LOG_MODE
COGNOS NOARCHIVELOG
3.2 使用ARCHIVE LOG LIST命令
DATABASE LOG MODE NO ARCHIVE MODE
AUTOMATIC ARCHIVAL DISABLED
ARCHIVE DESTINATION USE_DB_RECOVERY_FILE_DEST
OLDEST ONLINE LOG SEQUENCE (最早的联机日志序列) 81
CURRENT LOG SEQUENCE(当前的联机日志序列) 83
四、 配置数据库的归档模式
4.1 改变非归档模式到归档模式
SHUTDOWN IMMEDIATE ; 先关闭数据库
STARTUP MOUNT ; 启动数据库到装载状态, 但不要打开
ALTER DATABASE ARCHIVELOG ; 设置数据库为归档日志模式
ALTER DATABASE OPEN ; 打开数据库
ARCHIVE LOG LIST ; 确认数据库现在处于归档模式
ARCHIVE LOG ALL ; 将这个时间点的redo logs归档
做一次完全备份, 因为非归档日志模式下产生的备份日志对于归档模式已经不可用了, 这一步非常重要!!!
ALTR TABLESPACE USERS BEGIN BACKUP ;
4.2 改变归档模式到非归档模式
SHUTDOWN IMMEDIATE ; 先关闭数据库
STARTUP MOUNT ; 启动数据库到装载状态, 但不要打开
ALTER DATABASE NOARCHIVELOG ; 设置数据库为非归档模式
ALTER DATABASE OPEN ; 打开数据库
五、启动自动归档
先关闭数据库, 在PFILE中添加LOG_ARCHIVE_START=TRUE ; 重新启动数据库。
或者
ALTER SYSTEM ARCHIVE LOG START ;
归档模式下, 日志文件组不允许被覆盖(重写), 当日志文件写满以后, 如果没有进行手动归档, 那么系统将挂起,直到归档完成为止。这时只能读而不能写。
运行过程中关闭和重启归档日志进程
ARCHIVE LOG STOP ;
ARCHIVE LOG START ;
六、手动归档
LOG_ARCHIVE_START=FALSE ;
归档当前日志文件
ALTER SYSTEM ARCHIVE LOG CURRENT ;
归档序号为052的日志文件
ALTER SYSTEM ARCHIVE LOG SEQUENCE 052 ;
归档所有日志文件
ALTER SYSTEM ARCHIVE LOG ALL ;
改变归档日志目标
ALTER SYSTEM ARCHIVE LOG CURRENT TO '$PATH' ;
七、配置多个归档进程
什么时候需要使用多个归档进程?
如果归档过程会消耗大量的时间, 那么可以启动多个归档进程, 这个动态参数, 可以用ALTER SYSTEM动态修改。
ALTER SYSTEM SET LOG_ARCHIVE_MAX_PROCESSES=10 ;
ORACLE9i中最多可以指定10个归档进程, 与归档进程有关的动态性能视图: v$bgprocess, v$archive_processed
八、配置归档目标, 多归档目标, 远程归档目标, 归档日志格式
归档目标:
LOG_ARCHIVE_DEST_n
本地归档目标:
LOG_ARCHIVE_DEST_1 = "LOCATION=D:ORACLEARCHIVELOG" ;
远程归档目标:
LOG_ARCHIVE_DEST_2="SERVICE=STANDBY_DB1" ;
强制归档目标, 如果出错, 600秒后重试:
ALTER SYSTEM SET LOG_ARCHIVE_DEST_4="LOCATION=E:ORACLEARCHIVELOG MANDATORY REOPEN=600" ;
可选的归档目标, 如果出错, 放弃归档:
ALTER SYSTEM SET LOG_ARCHIVE_DEST_3="LOCATION=E:ORACLEARCHIVELOG OPTIONAL" ;
归档目标状态:
关闭归档目标:
ALTER SYSTEM SET LOG_ARCHIVE_DEST_STATE_1 = DEFER ;
打开归档目标:
ALTER SYSTEM SET LOG_ARCHIVE_DEST_STATE_2 = ENABLE ;
九、归档日志格式化
LOG_ARCHIVE_FORMAT 默认的是%t_%s_%r.dbf
其中%t代表thread number
%s代表log sequence number
%r代表重做日志id
十、与归档日志有关的几个视图:
V$ARCHIVED_LOG
V$ARCHIVE_DEST
V$LOG_HISTORY
V$DATABASE
V$ARCHIVE_PROCESSES
- Oracle归档模式与非归档模式
- Oracle归档模式与非归档模式
- ORACLE归档模式与非归档模式
- oracle 归档模式与非归档模式
- oracle 归档与非归档模式
- oracle 设置归档与非归档模式
- oracle 归档与非归档模式介绍
- 非归档与归档模式
- Oracle归档模式与非归档模式设置
- Oracle归档模式与非归档模式设置
- Oracle归档模式与非归档模式设置
- Oracle归档模式与非归档模式设置
- oracle归档模式与非归档模式的互换
- Oracle归档模式与非归档模式设置
- Oracle 归档模式与非归档模式的切换
- Oracle归档模式与非归档模式设置
- Oracle归档模式与非归档模式设置
- Oracle数据库的归档模式与非归档模式
- 001:操作系统概述
- Android数据库文件的导出
- Linux中的工作队列
- java中静态属性,静态方法和静态初始化器
- POI实现Servlet导出Excel
- ORACLE归档模式与非归档模式
- 暗黑三风格。Unity特效。牛叉哄哄的赶脚
- 黑马程序员——字节流
- Hibernate Session中flush、clear、evict方法的区别
- ubuntu搭建android 开发环境
- linux环境变量的学习
- JDBC更新10W级以上数据性能优化
- nginx开机自动启动脚本
- Android下动态链接库.so调用的简单例子