博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
oracle数据库的归档方式
阅读量:6084 次
发布时间:2019-06-20

本文共 1812 字,大约阅读时间需要 6 分钟。

hot3.png

数据库可运行在两种不同方式下:NOARCHIVELOG方式(介质恢复无效)或ARCHIVELOG方式(介质恢复有效)。数据库的运行方式对数据库的
策略具有重要的影响。归档日志对数据库备份和恢复有下列用处:数据库后备以及联机和归档日志文件,在操作系统和磁盘故障中可保证全部提交的事务可被恢复。
        在数据库打开和正常系统使用下,如果归档日志是永久保存,联机后备可以进行和使用。
       
1.NOARCHIVELOG方式
        数据库在NOARCHIVELOG方式下使用时,不能进行联机重做日志的归档。控制文件中的信息指出不需要对已经填满的成员进行归档,因此只要填满的成员变为不活动的,那么LGWR进程就可以重新使用这个日志组中的成员。NOARCHIVELOG方式只能保护数据库免受实例故障的影响,而不能免于介质故障。只有最近的存储于联机重做日志组的中的数据库的修改才可以用于实例或崩溃恢复。这些修改都足够用于进行崩溃恢复和实例恢复,因为Oracle不会覆盖联机重做日志文件,直到它的修 改被写到了数据文件中。然而它不可能通过使用归档重做日志进行介质恢复。
       
2.ARCHIVELOG方式
        如果数据库在ARCHIVELOG方式下运行,可实施联机重做日志的归档。控制文件中的信息指出一个已经填满的日志组成员不能被LGWR进程重写,直到这个成员被归档。
        ARCHIVELOG方式下允许从磁盘故障和实例故障下的完全恢复,因为所有对数据库的修改已经被永久的保存到归档重做日志中了。
        数据库在ARCHIVELOG方式下运行,可以设置为自动归档(AutomaticArchiving)或手工归档(ManualArchiving),下面分别介绍这两种工作方式:
        1
.
自动归档和归档后台进程
        在Oracle系统中,可以给Oracle实例配置一个附加的后台进程,归档进程(ARCn),它在每个组的联机重做日志文件变为不活动重做日志后进行自动归档。自动归档使系统管理员不必手动的跟踪、归档已填满的日志组成员。因为自动归档的便利性,自动归档已经是数据库
        系统工作在ARCHIVELOG方式下的最主要的选择了。在负荷比较重的情况下,比如大块数        据的取出,可以配置多个归档进程,配置多个归档进程一般是通过设置初始化参数LOG_ARCHIVE_MAX_PROCESSES。
        如果需要在实例启动时就进行自动归档,那么需要设置初始化参数LOG_ARCHIVE_START,那么Oracle系统在实例启动时会根据 LOG_ARCHIVE_MAX_PROCESSES确定的值,启动相应的ARCn进程的数量。否则ARCn进程在实例启动时不会启动。
        另外还可以通过交互式的方式在任何时候启动或停止自动归档,如果没有设置在实例启动的时候自动归档启动,而且随后想启动自动归档,那么Oracle会创建ARCn后台进程。ARCn在整个
存在,即使自动归档备临时关闭和打开。ARCn进程的数量通过使用ALTER SYSTEM命令设置LOG_ARCHIVE_MAX_PROCESSES的值可以动态改变。归档进程通常按照重做日志组的顺序进行归档,从最小的日志序列号开始。当已经填满
        的日志组变为不活动状态时归档进程自动归档。
        2
.
手工归档
        当数据库工作在ARCHIVELOG方式下时,无论是否设置了自动归档,都可以手动归档已填满的不活动联机重做日志文件,如果没有设置自动归档,那么必须手动归档已填满的日志组成员。
        对于大多数数据库系统,自动归档都是最好的,因为它不需要观察日志组是否变为不活动状态以及是否可以进行归档。而且如果不能进行自动归档并且手动归档进行的不够快,数据库的运行可能会被临时挂起,因为写日志进程被迫要等待一个不活动的组变为重新可用。
        手动归档进程用于:当自动归档因为出现某些问题(例如用于存储归档重做日志的脱机存储设备出现故障或已经填满时)而停止时,手动归档一个日志组。在一个非标准方式下归档一个日志组(例如归档一个组到一个脱机存储设备,下一个组到不同的存储设备等等)。如果最初归档的版本丢失或受到损坏时,重新归档一个日志组。
        当一个日志组采用手动归档时,发出归档日志组命令的用户进程进行日志组的归档。即 使在与其相关的实例出现了归档后台进程,还是由用户进程归档联机重做日志文件组。

转载于:https://my.oschina.net/javaEasy/blog/68576

你可能感兴趣的文章
一步一步学习SignalR进行实时通信_7_非代理
查看>>
AOL重组为两大业务部门 全球裁员500人
查看>>
字符设备与块设备的区别
查看>>
为什么我弃用GNOME转向KDE(2)
查看>>
Redis学习记录初篇
查看>>
爬虫案例若干-爬取CSDN博文,糗事百科段子以及淘宝的图片
查看>>
Web实时通信技术
查看>>
第三章 计算机及服务器硬件组成结合企业运维场景 总结
查看>>
IntelliJ IDEA解决Tomcal启动报错
查看>>
默认虚拟主机设置
查看>>
php中的短标签 太坑人了
查看>>
[译] 可维护的 ETL:使管道更容易支持和扩展的技巧
查看>>
### 继承 ###
查看>>
数组扩展方法之求和
查看>>
astah-professional-7_2_0安装
查看>>
函数是对象-有属性有方法
查看>>
uva 10107 - What is the Median?
查看>>
Linux下基本栈溢出攻击【转】
查看>>
c# 连等算式都在做什么
查看>>
使用c:forEach 控制5个换行
查看>>