0

0

Oracle数据库启动过程验证检查点SCN

php中文网

php中文网

发布时间:2016-06-07 16:43:00

|

1153人浏览过

|

来源于php中文网

原创

SCN(System Change Number,系统改变号)是Oracle数据库非常重要的机制。SCN在数据库启动,读一致性,数据的恢复,FLASHBACK操作

scn(system change number,系统改变号)是oracle数据库非常重要的机制。scn在数据库启动,读一致性,数据的恢复,flashback操作等情况下都会用到。

1.SCN号是重要的时间机制,两者之间可以相互的转换。

1).将时间转换为SCN号:
SQL> select timestamp_to_scn(sysdate) from dual;

TIMESTAMP_TO_SCN(SYSDATE)
-------------------------
                  920939

 2).将SCN号转换为具体时间:

SQL> select scn_to_timestamp(920000) from dual;

SCN_TO_TIMESTAMP(920000)
---------------------------------------------------------------------------
07-FEB-10 01.06.11.000000000 AM

3).查看当前数据库最新的SCN号:
SQL> select current_scn from v$database;

CURRENT_SCN
-----------
    920782
    当前最新的SCN号,该SCN号会不停的在内存中被刷新,Oracle 10g每隔3秒就会被刷新。

2.数据库启动过程对SCN号的验证。

    下面我们先来了解4种类型的SCN,这4种类型的SCN实际都是检查点SCN,都是由CKPT进程更新,存储在控制文件和数据文件头中,不同类型的SCN有不同的作用。

1).数据库检查点SCN:

 


SQL> select checkpoint_change# from v$database;

CHECKPOINT_CHANGE#
------------------
            920459

    数据库检查点SCN,每执行一次检查点,CKPT进程会更新控制文件中的数据库检查点SCN。

2).数据文件SCN:
 

SQL> select checkpoint_change# from v$datafile;

CHECKPOINT_CHANGE#
------------------
            920459
            920459
            920459
            920459
            920459
            920459
            920459
            920459
            920459
            920459
            920459

36 rows selected.

    数据文件SCN,每个数据文件都有一个数据文件SCN,每执行一次检查点,由CKPT进程都将更新位于控制文件中的数据文件SCN。

Magician
Magician

Figma插件,AI生成图标、图片和UX文案

下载

3).数据文件启动SCN:
 

SQL>  select checkpoint_change# from v$datafile_header;

CHECKPOINT_CHANGE#
------------------
            920459
            920459
            920459
            920459
            920459
            920459
            920459
            920459
            920459
            920459
            920459

36 rows selected.

    启动SCN,每个数据文件都有一个启动SCN,每执行一次检查点,CKPT进程都将更新数据文件头中的检查点SCN,这被叫做启动SCN。

4).数据文件终止SCN:
 

SQL> select last_change# from v$datafile;

LAST_CHANGE#
------------

36 rows selected.

    终止SCN,每个数据文件都有一个终止SCN,该SCN存储在控制文件中,当数据库被OPEN之后,该值即变成#ffffff无穷大。

数据库在启动过程中对SCN的验证分为两个阶段:
  第一阶段,检查控制文件和数据文件中数据文件的检查点次数是否一致(不同的数据文件检查点次数可能是不同的),如果不一致说明要么控制文件过旧,要么数据文件过旧,需要执行相应的恢复操作;如果一致继续执行下一步检查。

  第二阶段,检查数据文件的启动SCN和终止SCN是否一致,如果数据库关闭是非正常关闭,那么终止SCN肯定是无穷大,这个时候需要完成一个实例恢复的过程;如果启动SCN和终止SCN相同,那么数据库就可以OPEN了。

  另外,存储在控制文件中的数据库SCN、数据文件SCN和存储在数据文件头中的启动SCN实际都是在执行检查点时由CKPT进程对控制文件和数据文件头的更新,3者必定是相同的,在执行SHUTDOWN IMMEDIATE|NORMAL|TRANSANTIONAL关闭数据库时会再次触发检查点,这时前面3种类型的SCN和存储在控制文件中的终止SCN必定是相同的。

 下面我们通过对控制文件和数据文件头的转储来验证上面的说法:

1).正常关闭数据库的状态。

SQL> shutdown immediate
 Database closed.
 Database dismounted.
 ORACLE instance shut down.
 SQL> startup mount
 ORACLE instance started.

 Total System Global Area  599785472 bytes
 Fixed Size                  2022600 bytes
 Variable Size            230687544 bytes
 Database Buffers          360710144 bytes
 Redo Buffers                6365184 bytes
 Database mounted.
 SQL> @?/rdbms/admin/gettrace

 TRACE_FILE_NAME
 --------------------------------------------------------------------------------
 /u01/app/oracle1/admin/orcl/udump/orcl_ora_4132.trc

 SQL> alter session set events 'immediate trace name controlf level 8';

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

1

2026.01.29

java配置环境变量教程合集
java配置环境变量教程合集

本专题整合了java配置环境变量设置、步骤、安装jdk、避免冲突等等相关内容,阅读专题下面的文章了解更多详细操作。

2

2026.01.29

java成品学习网站推荐大全
java成品学习网站推荐大全

本专题整合了java成品网站、在线成品网站源码、源码入口等等相关内容,阅读专题下面的文章了解更多详细推荐内容。

0

2026.01.29

Java字符串处理使用教程合集
Java字符串处理使用教程合集

本专题整合了Java字符串截取、处理、使用、实战等等教程内容,阅读专题下面的文章了解详细操作教程。

0

2026.01.29

Java空对象相关教程合集
Java空对象相关教程合集

本专题整合了Java空对象相关教程,阅读专题下面的文章了解更多详细内容。

3

2026.01.29

clawdbot ai使用教程 保姆级clawdbot部署安装手册
clawdbot ai使用教程 保姆级clawdbot部署安装手册

Clawdbot是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

24

2026.01.29

clawdbot龙虾机器人官网入口 clawdbot ai官方网站地址
clawdbot龙虾机器人官网入口 clawdbot ai官方网站地址

clawdbot龙虾机器人官网入口:https://clawd.bot/,clawdbot ai是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

16

2026.01.29

Golang 网络安全与加密实战
Golang 网络安全与加密实战

本专题系统讲解 Golang 在网络安全与加密技术中的应用,包括对称加密与非对称加密(AES、RSA)、哈希与数字签名、JWT身份认证、SSL/TLS 安全通信、常见网络攻击防范(如SQL注入、XSS、CSRF)及其防护措施。通过实战案例,帮助学习者掌握 如何使用 Go 语言保障网络通信的安全性,保护用户数据与隐私。

8

2026.01.29

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

577

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
SQL 教程
SQL 教程

共61课时 | 3.6万人学习

Java 教程
Java 教程

共578课时 | 52.9万人学习

oracle知识库
oracle知识库

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号