首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >postgres的预写日志双RE有可能应用吗?

postgres的预写日志双RE有可能应用吗?
EN

Stack Overflow用户
提问于 2017-12-26 16:56:40
回答 1查看 575关注 0票数 1

我在这里找到了引号

PostgreSQL是依赖于预写日志(WAL)的数据库之一--所有更改都首先写入日志(更改流),然后才写入数据文件。这提供了持久性,因为在崩溃的情况下,数据库可能会使用WAL执行恢复-读取WAL中的更改并将它们重新应用于数据文件。

从本文中https://blog.2ndquadrant.com/basics-of-tuning-checkpoints/

假设有WAL文件,请继续进行以下查询

UPDATE page SET view_count = view_count + 1;

我可以想象,postgres已经将这个WAL应用于DB,但它在应用之后就崩溃了。

DB还没有更新最新的WAL位置,也没有删除WAL日志文件。

当DB启动时,它将进行恢复并再次应用这个WAL,不是吗?数据库中的这个最终值会变成view_count + 2吗?

请指教

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-12-26 17:23:49

这种情况称为部分页面写入。PostgreSQL具有防止此问题发生的配置选项,full_page_writes。默认情况下它是启用的:

当此参数打开时,PostgreSQL服务器将每个磁盘页的全部内容在检查点之后对该页进行第一次修改时写入WAL。这是必要的,因为在操作系统崩溃期间正在进行的页面写入可能只部分完成,从而导致磁盘上的页面包含新旧数据的混合。

通过还原页副本而不是重做更新来重放更改。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47981482

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档