OCA读书笔记(14) - 备份和恢复基本概念
备份恢复概念
如何判断数据库的一致性
在mount状态下,oracle如何判断数据库的一致性
scn:system change number,它是数据库时钟
如何查询当前系统的scn:
select current_scn from v$database;
几个特殊的scn,在控制文件和数据文件头
控制文件中有三个:
1. 系统检查点scn:
select checkpoint_change# from v$database;
CHECKPOINT_CHANGE#
------------------
1077050
2. 控制文件中为每个数据文件记录一个检查点scn:
ORA10G>select file#,checkpoint_change# from v$datafile;
FILE# CHECKPOINT_CHANGE#
---------- ------------------
1 1077050
2 1077050
3. 控制文件中还要记录每个文件的终止scn,数据库在正常运行的时候,它是无穷大的,只有在一致性关闭数据库
的时候才不为空:
select file#,last_change# from v$datafile;
FILE# LAST_CHANGE#
---------- ------------
1
2
shutdown immediate
startup mount
ORA10G>select file#,last_change# from v$datafile;
FILE# LAST_CHANGE#
---------- ------------
1 1079328
2 1079328
为什么一致性关闭就不为空?
因为一致性关闭的时候执行了检查点,检查点通知数据库写进程写脏块,然后更新控制文件和数据文件头的检查点scn
如果last_change#不为空,说明数据库是一致性关闭的,再次打开的时候不需要进行实例恢复
在数据文件的文件头也记录了数据文件的检查点scn,我们一般称它为启动scn
ORA10G>select file#,checkpoint_change# from v$datafile_header;
FILE# CHECKPOINT_CHANGE#
---------- ------------------
1 1079329
2 1079329
oracle通过以上的检查点scn来判断是否要进行恢复
数据库在mount状态下,当发出open命令的时候,他要安装下列顺序检查一致性:
首先启动scn与控制文件中记录的数据文件的检查点scn进行比较,如果一致,则继续,否则要执行恢复:
shutdown immediate
startup mount
ORA10G>select file#,checkpoint_change# from v$datafile_header;
FILE# CHECKPOINT_CHANGE#
---------- ------------------
1 1080854
2 1080854
ORA10G>select file#,checkpoint_change# from v$datafile;
FILE# CHECKPOINT_CHANGE#
---------- ------------------
1 1080854
2 1080854
如一致,则比较启动scn和终止scn:
ORA10G>select file#,checkpoint_change# from v$datafile_header;
FILE# CHECKPOINT_CHANGE#
---------- ------------------
1 1080854
2 1080854
ORA10G>select file#,last_change# from v$datafile;
FILE# LAST_CHANGE#
---------- ------------
1 1080854
2 1080854
如果一致,数据库就可以打开了,否则要就行恢复
select file#,checkpoint_change#,last_change# from v$datafile; -- 来自控制文件
select file#,checkpoint_change# from v$datafile_header; -- 来自数据文件文件头
shutdown immediate;
startup mount;
数据文件last_change# -- A
数据文件checkpoint_change# -- B
数据文件头checkpoint_change# -- C
C与A不同,需要实例恢复。
C与B不同,则需要介质恢复。
需要介质恢复时,决定使用哪个日志文件?比较C与日志文件中的first_change#
select group#, sequence#, first_change# from v$log;
MTTR(实例恢复)
show parameter fast_start_mttr_target;
介质故障
常规备份
多路复用控制文件
多路复用日志文件组
sqlplus / as sysdba;
select group#,member from v$logfile;
alter database add logfile member '/u01/app/oracle/oradata/orcl/redo0102.log' to group 1;
select group#,member from v$logfile;
alter database drop logfile member '/u01/app/oracle/oradata/orcl/redo0102.log';
select group#,member from v$logfile;
备份归档重做日志文件
快速闪回区
强烈建议配置快速闪回区
存储空间与数据文件分开
启动归档模式
archive log list;
shutdown immediate;
starup mount;
alter database archivelog;
alter database open;
mkdir -p /u01/app/oracle/archivelog
alter system set log_archive_dest_1='location=/u01/app/oracle/archivelog';
alter system switch logfile;
OCA读书笔记(14) - 备份和恢复基本概念的更多相关文章
- OCA读书笔记(16) - 执行数据库恢复
16. Performing Database Recovery 确定执行恢复的必要性访问不同接口(EM以及命令行)描述和使用可用选项,如RMAN和Data Recovery Advisor执行恢复- ...
- 涂抹mysql笔记-数据备份和恢复
<>物理备份和逻辑备份<>联机备份和脱机备份<>本地备份和远程备份<>完整备份和增量备份<>完整恢复和增量恢复<>复制表相关文件 ...
- 进入保护模式(二)——《x86汇编语言:从实模式到保护模式》读书笔记14
首先来段题外话:之前我发现我贴出的代码都没有行号,给讲解带来不便.所以从现在起,我要给代码加上行号.我写博客用的这个插入代码的插件,确实不支持自动插入行号.我真的没有找到什么好方法,无奈之下,只能按照 ...
- Oracle DB 备份和恢复的概念
• 确定Oracle DB 中可能发生的故障类型 • 说明优化实例恢复的方法 • 说明检查点.重做日志文件和归档日志文件的重要性 • 配置快速恢复区 • 配置ARCHIVELOG模式 部分工作内容 ...
- OCA读书笔记(15) - 执行数据库备份
物理备份 -- 数据文件,控制文件,日志文件,参数文件 数据库备份 冷备 -- 归档和非归档均可以 什么时候必须用冷备?1. 数据库的模式为非归档的2. 用于现场保护 冷备的过程:1. 首先查看备份文 ...
- OCA读书笔记(1) - 浏览Oracle数据库架构
Objectives: List the major architectural components of Oracle DatabaseExplain the memory structuresD ...
- OCP读书笔记(3) - 使用RMAN恢复目录
创建恢复目录 在hndx上创建恢复目录:[oracle@oracle admin]$ export ORACLE_SID=hndx[oracle@oracle admin]$ sqlplus / as ...
- OCA读书笔记(18) - 使用Support工具
调查和解决问题 问题:数据库中的任一严重的错误定义为一个问题,一般来说,这些错误包括大家熟悉的ORA-600错误和ORA-04031(共享池超出)错误,涉及数据库问题的所有元数据都存储在ADR中,每个 ...
- 『TCP/IP详解——卷一:协议』读书笔记——14
2013-08-25 11:32:06 第5章 RARP:逆地址解析协议 5.1 引言 具有本地磁盘的系统引导时,一般是从磁盘上的配置文件中读取IP地址.但是无盘机,如X终端或无盘工作站,则需要采用其 ...
随机推荐
- 前端面试题整理(html)
1.<!DOCTYPE>标签的定义与用法. <!DOCTYPE> 声明必须是 HTML 文档的第一行,位于 <html> 标签之前. <!DOCTYPE> ...
- hdoj 1286 找新朋友 【数论之欧拉函数】
找新朋友 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
- Windows Azure 安全最佳实践 - 第 3 部分:确定安全框架
构建云应用程序时,安全始终是计划和执行Windows Azure的首要核心因素.第 1 部分提出安全是一项共同责任,Windows Azure为您的应用程序提供超出内部部署应用程序需求的强大安全功能. ...
- 为什么必须是final的呢?
一个谜团 如果你用过类似guava这种“伪函数式编程”风格的library的话,那下面这种风格的代码对你来说应该不陌生: 1 2 3 4 5 6 7 8 9 public void tryUsingG ...
- window2003远程桌面“已达最大连接数”
使用命令行强制注销远程登录用户 Fri, 04/19/2013 - 09:29 - admin 来源地址: http://space.itpub.net/10067101/viewspace-6147 ...
- C 语言资源大全中文版
C 语言资源大全中文版 我想很多程序员应该记得 GitHub 上有一个 Awesome - XXX 系列的资源整理.awesome-c 是 koz.ross 发起维护的 C 语言资源列表,内容包括了: ...
- 【Demo 0007】Java基础-类扩展特性
本章学习要点: 1. 掌握static 修饰的类,方法以及变量的功能及用法; 2. 掌握代码块(静态,非静态)的作用以及注意事项: 3. 了解基本数据类 ...
- JavaScript快速入门(三)——JavaScript语句
JavaScript基本语句 基本概述 JavaScript是脚本语言,从上到下解释执行,最小单位为语句或语句块,每个语句以分号结尾,每个语句块以右大括号结尾. JavaScript可以将多条语句或语 ...
- gridView自己定义做时间排版
公司有需求要做一个时间排版,原型例如以下 由于要用的gridView,曾经就是它的排版非常多,最看是想用一个checkbox搞定. 后来证实功能可以达到.可是排版是乱的.还是老老实实多写点吧(直接上代 ...
- Nginx设置alias实现虚拟目录 alias与root的用法区别
Nginx 貌似没有虚拟目录的说法,因为它本来就是完完全全根据目录来设计并工作的.如果非要给nginx安上一个虚拟目录的说法,那就只有alias标签比较"像",干脆来说说alias ...