热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

存储结构之重做日志文件

重做日志文件,可分在线重做日志文件和归档重做日志文件。它是个数据库的事务日志。目的在于失败时恢复已提交的事务。你在oracle

重做日志文件,可分在线重做日志文件和归档重做日志文件。它是个数据库的事务日志。目的在于失败时恢复已提交的事务。你在oracle

重做日志文件,可分在线重做日志文件和归档重做日志文件。它是个数据库的事务日志。目的在于失败时恢复已提交的事务。你在Oracle中完成的每个操作几乎都会生成一定的redo信息,并写入在线重做日志文件。

当主机掉电时,你可借助在线重做日志文件,将系统恢复到掉电前的时刻;当磁盘损坏时,你可借助归档重做日志文件恢复到适当的时点;当你误删了某些重要的信息并且提交时,你同样可借助他们去帮你恢复到误删前的那个时刻。

“在重用重做日志之前,失败时应该不需要的重做日志文件的内容”,如果oracle不能肯定这一点,就会暂时挂起数据库,建立检查点,将缓冲区缓存内的redo保护的数据安全地写入磁盘。oracle并非把database_buffer_cache内修改的数据写入磁盘,相反地,它是把redo log buffer里的redo entry flush到在线重做日志文件中。只要修改的块,被缓存而未被写入磁盘,数据库失败时,就需要重做日志文件的内容,然则,却是不可以重用重做日志文件。比如,日志却的时候,填满日志1却换到日志2时,DBWn会建立检查点,把日志1所保护的所有脏块写入磁盘,在这之前,oracle不能重用这个日志文件。否则,在alert日志会报,检查点未完成。出现这个消息时,数据库会挂起,DBWn正忙于完成它建立的检查点。

每个oracle数据库,分散风险的做法是设置3路磁盘通道。每路在设置上该注意什么呢?主要是从高峰负载,平均恢复时间,大量用户修改相同块这几个因素入手。
1)日志组的数量?
太少会有等待事件
2)日志成员大小?
太小了,会频繁却换,产生检查点,性能低;太大了,不安全,数据都在一个地方存放
3)成员对称否?
成员应该设置成同样大小,镜像的数量也应该一致。否则,算法会有剧烈抖动。(注意了,这里是应该,而不是一定哦)

确定有多少个日志组?
SQL> select group# from v$log;

GROUP#
----------
1
2
3
有多少个镜像?
SQL> select member from v$logfile;

MEMBER
--------------------------------------------------------------------------------
/u01/app/oracle/oradata/ORCL/onlinelog/o1_mf_3_7xzskcdd_.log
/u01/app/oracle/flash_recovery_area/ORCL/onlinelog/o1_mf_3_7xzskh9o_.log
/u01/app/oracle/oradata/ORCL/onlinelog/o1_mf_2_7xzsk47l_.log
/u01/app/oracle/flash_recovery_area/ORCL/onlinelog/o1_mf_2_7xzsk7of_.log
/u01/app/oracle/oradata/ORCL/onlinelog/o1_mf_1_7xzsjx1g_.log
/u01/app/oracle/flash_recovery_area/ORCL/onlinelog/o1_mf_1_7xzsk0ph_.log

增加一个日志组?若使用OMF,则添加一个组后,oracle会自动为你添加成员。
alter database add logfile group 4(‘filename’,‘filename’) size 100;
如:
SQL> alter database add logfile group 4 size 100m;

Database altered.

SQL> select group# from v$log;

GROUP#
----------
1
2
3
4

删除时把add换成drop即可。current的重做日志文件不能删除,若要删除,,可以使用alter system switch logfile。删除后,操作系统的文件是仍然存在的(OMF除外),把操作系统上的文件一块删除才会比较干净的除去。

如何添加一个成员?
alter database add logfile member
'filename' to group 1,
'filename' to group 2,
'filename' to group 3;

刚加的组的状态是unused。
SQL> select group#,bytes/1024/1024 m from v$log;

GROUP# M
---------- ----------
1 50
2 50
3 50

SQL> alter database add logfile group 5 size 50m;

Database altered.

SQL> select group#,status from v$log;

GROUP# STATUS
---------- ----------------
1 INACTIVE
2 CURRENT
3 INACTIVE
5 UNUSED

日志成员有几个状态在此稍微说明一下:
active:被RBA指针覆盖的,但不在这里面写。RBA挪开,则是inactive。
current:被RBA指针覆盖的,但正在写。
inactive:表示实例恢复已不再需要这组重做日志文件了。
unused:表示oracle从没用过该重做日志文件组。
日志却会有active。

如果组内只有一个成员,则组与成员的概念没有区别。组就是成员,成员就是组。总之,组间却换,组内镜像。

server process负责把redo entry写到redo log buffer中,而LGWR则负责将redo entry flush到在线重做日志文件。那么LGWR什么时候会写呢?
1)每3秒
2)1/3满
3)1M redo entry
4)commit
5)DBWn写之前写

linux

推荐阅读
  • 一、Hadoop来历Hadoop的思想来源于Google在做搜索引擎的时候出现一个很大的问题就是这么多网页我如何才能以最快的速度来搜索到,由于这个问题Google发明 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • 本文介绍了adg架构设置在企业数据治理中的应用。随着信息技术的发展,企业IT系统的快速发展使得数据成为企业业务增长的新动力,但同时也带来了数据冗余、数据难发现、效率低下、资源消耗等问题。本文讨论了企业面临的几类尖锐问题,并提出了解决方案,包括确保库表结构与系统测试版本一致、避免数据冗余、快速定位问题等。此外,本文还探讨了adg架构在大版本升级、上云服务和微服务治理方面的应用。通过本文的介绍,读者可以了解到adg架构设置的重要性及其在企业数据治理中的应用。 ... [详细]
  • 生成对抗式网络GAN及其衍生CGAN、DCGAN、WGAN、LSGAN、BEGAN介绍
    一、GAN原理介绍学习GAN的第一篇论文当然由是IanGoodfellow于2014年发表的GenerativeAdversarialNetworks(论文下载链接arxiv:[h ... [详细]
  • 无线认证设置故障排除方法及注意事项
    本文介绍了解决无线认证设置故障的方法和注意事项,包括检查无线路由器工作状态、关闭手机休眠状态下的网络设置、重启路由器、更改认证类型、恢复出厂设置和手机网络设置等。通过这些方法,可以解决无线认证设置可能出现的问题,确保无线网络正常连接和上网。同时,还提供了一些注意事项,以便用户在进行无线认证设置时能够正确操作。 ... [详细]
  • 本文详细介绍了相机防抖的设置方法和使用技巧,包括索尼防抖设置、VR和Stabilizer档位的选择、机身菜单设置等。同时解释了相机防抖的原理,包括电子防抖和光学防抖的区别,以及它们对画质细节的影响。此外,还提到了一些运动相机的防抖方法,如大疆的Osmo Action的Rock Steady技术。通过本文,你将更好地理解相机防抖的重要性和使用技巧,提高拍摄体验。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 本文比较了eBPF和WebAssembly作为云原生VM的特点和应用领域。eBPF作为运行在Linux内核中的轻量级代码执行沙箱,适用于网络或安全相关的任务;而WebAssembly作为图灵完备的语言,在商业应用中具有优势。同时,介绍了WebAssembly在Linux内核中运行的尝试以及基于LLVM的云原生WebAssembly编译器WasmEdge Runtime的案例,展示了WebAssembly作为原生应用程序的潜力。 ... [详细]
  • 本文介绍了如何在MySQL中将零值替换为先前的非零值的方法,包括使用内联查询和更新查询。同时还提供了选择正确值的方法。 ... [详细]
  • 本文介绍了如何使用Power Design(PD)和SQL Server进行数据库反向工程的方法。通过创建数据源、选择要反向工程的数据表,PD可以生成物理模型,进而生成所需的概念模型。该方法适用于SQL Server数据库,对于其他数据库是否适用尚不确定。详细步骤和操作说明可参考本文内容。 ... [详细]
  • 在数据分析工作中,我们通常会遇到这样的问题,一个业务部门由若干业务组构成,需要筛选出每个业务组里业绩前N名的业务员。这其实是一个分组排序的 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • Oracle Database 10g许可授予信息及高级功能详解
    本文介绍了Oracle Database 10g许可授予信息及其中的高级功能,包括数据库优化数据包、SQL访问指导、SQL优化指导、SQL优化集和重组对象。同时提供了详细说明,指导用户在Oracle Database 10g中如何使用这些功能。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文详细介绍了MysqlDump和mysqldump进行全库备份的相关知识,包括备份命令的使用方法、my.cnf配置文件的设置、binlog日志的位置指定、增量恢复的方式以及适用于innodb引擎和myisam引擎的备份方法。对于需要进行数据库备份的用户来说,本文提供了一些有价值的参考内容。 ... [详细]
author-avatar
rongrong_102077
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有