DB2的日志

news2025/1/13 15:56:30

在DB2中,该机制使用日志功能实现。所谓日志,可以被认为在一条事务被落实之前,能够保证其记录被写入永久存储系统的一种方法。

那么为什么需要日志呢?直接把变化的数据写入磁盘不是更好?之所以需要日志,主要是从性能考虑。通常情况下,每一个事务包含若干条数据更改语句,每个更改可能需要操作大量的数据。如果将这些数据直接写入磁盘才返回给应用端,那么将严重影响写的性能,因此,DB2采用写日志优先算法,即先写日志,再写数据,而写数据的过程使异步的。

 如图所示日志原理,当插入\更改\删除数据时,该条记录并不会直接写到数据盘,而是首先写到日志文件。而缓存池数据什么时候写到数据盘,是个异步过程。这样即使某一时刻突然宕机,数据没有从缓存池内存写到数据盘也没有关系,因为数据已经记到日志文件里了。当重新开机进行恢复的时候,DB2将日志文件的内容重写到数据盘,保证数据库的一致性
 

DB2的日志理解难点

在DB2中最早的recovery时间点,是由minBuffLsn 和 lowTranLsn 的最小值决定的。

minBuffLsn: represents the oldest change to a page in the buffer pool that has not been written and persisted to disk yet.

lowTranLsn: represents the oldest active uncommitted transaction (specifically the LSN of the first log record it wrote).

在DB2和ORACLE数据库都还有一个约定,从buffer pool中写数据到磁盘之前其对应的redo log必须先从log buffer pool中写到磁盘中。

注意:这里的log buffer pool中的redo log没有要求是已经committed的。

所以,在数据库中,还没有被提交的数据被写到磁盘中是很正常的事情,只要这块数据所对应的redo log已经被写入到磁盘中,对于这个交易是否已经提交,不关紧要。

那么在recovery的时候就会出现这样的情况:

minBuffLsn < lowTranLsn : 有已经提交的交易(commit动作会触发数据库将对应的redo log写入到磁盘)数据还有没有被从buffer pool中写入到磁盘,所以recovery时从minBuffLsn对应的log开始,redo后面那些已经提交的或者未提交的交易,重建transaction table。

lowTranLsn > minBuffLsn : 有还没有提交的交易(但是redo log是已经写入到磁盘中的)的数据已经被写入到磁盘中,所以recovery时将从lowTranLsn对应的log开始,这部分数据已经被写入到磁盘中的redo log只是读取一下,创建transaction table。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/917186.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

芯科科技宣布推出下一代暨第三代无线开发平台,打造更智能、更高效的物联网

第三代平台中的人工智能/机器学习引擎可将性能提升100倍以上 Simplicity Studio 6软件开发工具包通过新的开发环境将开发人员带向第三代平台 中国&#xff0c;北京 - 2023年8月22日 – 致力于以安全、智能无线连接技术&#xff0c;建立更互联世界的全球领导厂商Silicon Labs&…

基于IDEA使用maven创建hibernate项目

1、创建maven项目 2、导入hibernate需要的jar包 <!--hibernate核心依赖--><dependency><groupId>org.hibernate</groupId><artifactId>hibernate-core</artifactId><version>5.4.1.Final</version></dependency><!--…

微信小程序:页面有内容却不显示原因

先检查&#xff0c;app.json中这两项路径是否正确 如果正确的话&#xff0c;不显示的那个页面的。js文件中需要Page({})&#xff0c;初始化&#xff0c;这个必须有&#xff1b; 如果还是不出现&#xff0c;可以先把路径删掉&#xff0c;然后刷新一下&#xff0c;这个时候会提示…

ctfshow web入门 web103-web107

1.web103 和102一样 payload: v2115044383959474e6864434171594473&v3php://filter/writeconvert.base64-decode/resource1.php post v1hex2bin2.web104 值只要一样就可以了 payload: v21 post v113.web105 考查的是$$变量覆盖,die可以带出数据,输出一条消息&#xf…

C++信息学奥赛1133:输出亲朋字符串

#include <iostream> #include <string> using namespace std;int main() {string n;cin >> n; // 输入字符串for (int i 0; i < n.length(); i){char Front n[i]; // 当前字符char rear n[i 1]; // 下一个字符if (i n.length() - 1){rear n[0];…

激进的现货白银技巧

在现货白银投资中&#xff0c;我们有保守的交易技巧&#xff0c;也有激进的交易技巧&#xff0c;这给了投资者有进退的选择。其实很多投资者认为贵金属的投资只能长期持有&#xff0c;等待升值&#xff0c;确实有部分投资者是这么做的。但是其实现货白银投资还是有非常激进的一…

这样处理 Python 日志,优雅

迷途小书童的Note 读完需要 4分钟 速读仅需 2 分钟 1 loguru 简介 loguru 是 Python 的一个第三方日志模块&#xff0c;相较于标准库 logging 模块&#xff0c;它提供了更简洁易用的 API&#xff0c;内置丰富的格式化、过滤、文件输出等高级功能。loguru 让 Python 日志记录变得…

HTML5岗位技能实训室建设方案

一 、系统概述 HTML5岗位技能技术是计算机类专业重要的核心课程&#xff0c;课程所包含的教学内容多&#xff0c;实践性强&#xff0c;并且相关技术更新快。传统的课堂讲授模式以教师为中心&#xff0c;学生被动式接收&#xff0c;难以调动学生学习的积极性和主动性。混合式教学…

Maven生命周期、阶段与目标

生命周期 对于Java项目来说&#xff0c;一个项目的生命周期可能会有创建项目、编译、打包、运行、部署等&#xff0c;而maven将项目的生命周期进行了标准化。 Maven默认支持的生命周期有clean、site、default&#xff0c;其中 site这个生命周期几乎用不到&#xff0c;最常用的…

Unity 图片资源的适配

前言 最近小编做Unity项目时&#xff0c;发现在资源处理这方面和Android有所不同&#xff1b;例如&#xff1a;Android的资源文件夹res下会有着mipmap-mdpi&#xff0c;mipmap-hdpi&#xff0c;mipmap-xhdpi&#xff0c;mipmap-xxhdpi&#xff0c;mipmap-xxxhdpi这五个文件夹&a…

java八股文面试[java基础]——Object类有哪些方法

通过IDEA打开Object类就可以看到 &#xff08;1&#xff09;clone方法 保护方法&#xff0c;实现对象的浅复制&#xff0c;只有实现了Cloneable接口才可以调用该方法&#xff0c;否则抛出CloneNotSupportedException异常。 主要是JAVA里除了8种基本类型传参数是值传递&#xf…

什么是缓存雪崩,什么是缓存穿透,什么是缓存击穿,如何解决 ?

目录 1. 什么是缓存雪崩&#xff1f;如何解决 &#xff1f; 2. 什么是缓存穿透&#xff1f;如何解决 &#xff1f; 3. 什么是缓存击穿&#xff1f;如何解决 &#xff1f; 1. 什么是缓存雪崩&#xff1f;如何解决 &#xff1f; 缓存雪崩是指在短时间内&#xff0c;有大量的缓存…

3D姿态相关的损失函数

loss_mpjpe: 计算预测3D关键点与真值之间的平均距离误差(MPJPE)。 loss_n_mpjpe: 计算去除尺度后预测3D关键点误差(N-MPJPE),评估结构误差。 loss_velocity: 计算3D关键点的速度/移动的误差,评估运动的平滑程度。 loss_limb_var: 计算肢体长度的方差,引导生成合理的肢体长度…

SpeedBI数据可视化工具:丰富图表,提高报表易读性

数据可视化工具一大作用就是能把复杂数据可视化、直观化&#xff0c;更容易看懂&#xff0c;也就更容易实现以数据驱动业务管理升级&#xff0c;因此一般的数据可视化工具都会提供大量图形化的数据可视化图表&#xff0c;以提高报表的易懂性&#xff0c;更好地服务企业运营决策…

AUTBUS全球首发,东土与您相约工博会

2023年中国国际工业博览会将于9月19日至9月23日在上海盛大举办。作为工博会重点参展企业之一&#xff0c;东土科技将重磅亮相6.1号馆工业自动化展&#xff08;展位号&#xff1a;6.1H-D137&#xff09;。 值得一提的是&#xff0c;AUTBUS 国际标准作为全球第一个基于时间敏感网…

微信开发之一键修改群公告的技术实现

简要描述&#xff1a; 设置群公告 请求URL&#xff1a; http://域名地址/setChatRoomAnnouncement 请求方式&#xff1a; POST 请求头Headers&#xff1a; Content-Type&#xff1a;application/jsonAuthorization&#xff1a;login接口返回 参数&#xff1a; 参数名必…

新华三重磅发布新一代智慧存储新品

8月22日&#xff0c;紫光股份旗下新华三集团以“重构 进化 启新境”为主题&#xff0c;成功举办新一代智慧存储新品发布会&#xff0c;重磅发布H3C/HPE Alletra MP全局解耦NVMe智能全闪存储、H3C UniStor X10000 G6系列分布式融合存储&#xff0c;基于全新技术架构打造强劲性能…

low-ui-vue前置解读|实现一个动态列的表格组件

最近另一个团队正式在项目中推广内部开发的low-ui组件库了&#xff0c;当然 还在内部阶段&#xff0c;但是太慢了。作为架子的设计者和部分功能的开发者&#xff0c;我决定先把常见的功能通过模仿的形式公开出来。避免大家搜索无果或者使用一些框架增加学习成本。 所谓动态列的…

剑指 Offer 40. 最小的k个数(C++实现)

剑指 Offer 40. 最小的k个数https://leetcode.cn/problems/zui-xiao-de-kge-shu-lcof/ 法1&#xff1a;二叉堆 通过最小堆&#xff0c;直接筛选出最小的k个数 vector<int> getLeastNumbers(vector<int>& arr, int k) {priority_queue<int, vector<int>…

在Eclipse中创建javaweb工程

新建动态web工程 点击project或other之后&#xff0c;如何快速找到Dynamic Web Project 填写工程名等详细信息 也许会出现下面的对话框 项目结构图