iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >常用 PostgreSQL 预防数据丢失解决方案
  • 1017
分享到

常用 PostgreSQL 预防数据丢失解决方案

2024-04-02 19:04:59 1017人浏览 八月长安
摘要

目录预防数据丢失方案DDL 操作事件触发器回收站DML 操作流复制延迟恢复备份恢复总结作者:张连壮 postgresql 研发负责人 从事多年 Postgresql 数据库内核开发,

作者:张连壮 postgresql 研发负责人

从事多年 Postgresql 数据库内核开发,对 Citus 有非常深入的研究。

PostgreSQL是一种特性非常齐全的自由软件的对象-关系型数据库管理系统(ORDBMS),是以加州大学计算机系开发的POSTGRES,4.2版本为基础的对象关系型数据库管理系统。POSTGRES的许多领先概念只是在比较迟的时候才出现在商业网站数据库中。PostgreSQL支持大部分的SQL标准并且提供了很多其他现代特性,如复杂查询、外键、触发器、视图、事务完整性、多版本并发控制等。同样,PostgreSQL也可以用许多方法扩展,例如通过增加新的数据类型、函数、操作符、聚集函数、索引方法、过程语言等。另外,因为许可证的灵活,任何人都可以以任何目的免费使用、修改和分发PostgreSQL。下面看下常用 PostgreSQL 预防数据丢失解决方案。

PostgreSQL 本身不具备数据闪回和数据误删除保护功能,但在不同场景下也有对应的解决方案。

本文由作者在 2021 PCC 大会的演讲主题《PostgreSQL 数据找回》整理而来,上一篇《盘点 | 常用 PG 数据恢复方案概览》介绍了 PostgreSQL 常见的 数据恢复方案。本篇将介绍 预防数据丢失方案的实现原理及使用示例。

预防数据丢失方案

前文提到数据丢失的主要操作为 DDL 和 DML 。

本篇主要介绍关于 DDL 和 DML 操作,如何预防数据丢失的方案。

DDL 操作

事件触发器

当事件以其定义的方式在数据库中相关的发生时,触发事件触发器。主要可预防以下四种 DDL 事件。

事件说明
ddl_command_startDDL 执行前执行
ddl_command_endDDL 执行后执行, 通过 pg_event_trigger_ddl_commands() 可以获取操作的对象
sql_dropDDL 执行后执行, 通过 pg_event_trigger_dropped_objects() 可以获取所有被删除的对象
table_rewriteDDL 执行前执行, 例如 ALTER TABLE、ALTER TYPE 等

当表被删除后,可以通过 ddl_command_start 事件组织删除操作。

CREATE OR REPLACE FUNCTioN disable_drops()
    RETURNS event_trigger LANGUAGE plpgsql AS $$
BEGIN
     RaiSE EXCEPTION 'drop table denied';
END
$$; -- 创建事件触发器函数
 
CREATE EVENT TRIGGER event_trigger_disable_drops
    ON ddl_command_start WHEN TAG in('drop table')
    EXECUTE PROCEDURE disable_drops(); -- 创建事件触发器,禁止drop table操作

事件触发器,无法修改 drop 的任何行为,因此只能拒绝,来确保数据不被删除,由其他拥有更高权限的数据库管理员删除。

test=# \dy
                                        事件触发器列表
            名称             |       Event       | 拥有者  | 使能 |     函数      |    标签    
-----------------------------+-------------------+---------+------+---------------+------------
 event_trigger_disable_drops | ddl_command_start | lzzhang | 启用 | disable_drops | DROP TABLE
(1 行记录)
 
test=# drop table lzzhang;
ERROR:  drop table denied
CONTEXT:  PL/pgSQL function disable_drops() line 3 at RAISE

删除表的操作由拥有更高级权限的数据库管理员操作。

BEGIN;
ALTER EVENT TRIGGER event_trigger_disable_drops DISABLE;
DROP TABLE lzzhang;
ALTER EVENT TRIGGER event_trigger_disable_drops ENABLE;
COMMIT;

回收站

DDL 会将文件从操作系统中完全删除,因此唯一的办法是将删除改为换一个"位置",类似 windows 中回收站。

pgtanshscan[1] 便是一种回收站工具,并且只能通过插件采用 hook 的方式来实现。

if (nodeTag(parsetree) == T_DropStmt)
{
                if (stmt->removeType == OBJECT_TABLE)
{
AlterObjectSchemaStmt *newstmt = makeNode(AlterObjectSchemaStmt);
newstmt->newschema = pstrdup(trashcan_nspname);

通过其代码示例可以看出, DROP TABLE 操作被转换成了 ALTER 操作。

由于 pgtrashcan 代码陈旧,已经有 8 年未更新,不适配新版本 PG。且仅支持移动功能,并不支持彻底清除功能。由此,pgtrashcan 做了很多优化

  • 支持新版本 PG 14/13/12
  • 通过插件的 depend 功能,依赖 pg_cron
  • 自动设置 pg_cron 将其回收站中超过 1 天的数据清除

DML 操作

通过参数 vacuum_defer_cleanup_age 来调整 Dead 元组在数据库中的量,以便恢复误操作的数据。接下来将根据 流复制延迟恢复和 备份恢复两种设计方案来具体介绍:

流复制延迟恢复

PostgreSQL 流复制时可以通过 recovery_min_apply_delay 设置相应的延迟时间。例如设置 5 小时,备库可以延迟应用最近 5 小时的日志,提供最多 5 小时的数据恢复窗口,延迟的应用日志的同时并不影响日志的接受,源库的日志仍然是实时的被延迟恢复节点接受。

找回数据的具体操作步骤如下:

  • 暂停延迟恢复 pg_wal_replay_pause()
  • 通过 pg_dump 或 copy 操作将其需要的数据找出来;
  • 通过 psql、copy、pg_restore 等操作将数据导入源库中;
  • 继续延迟 pg_wal_replay_resume()

备份恢复

从备份模式的角度来说,备份主要包括以下两种:

  • 逻辑备份

不能进行实时备份,因此不太适用于数据找回,会丢失很多数据。

  • 物理备份

物理备份拥有与源集群完全一致的数据,因此可以持续使用源集群的 WAL 日志,达到数据找回的目标,原理上也是延迟恢复。

物理备份与 PITR 结合,可恢复数据到任意时间点。可选用工具有很多,如下几种是常用的恢复工具。

  • pg_basebackup[2]
  • pg_probackup[3]
  • pgbackrest[4]
  • barman[5]
  • pg_rman[6]

总结

  • 注意权限划分。危险操作或是 DDL 等影响大的操作,一定要由第二个数据库管理员操作。
  • 提前做好数据找回和数据安全的方案规划。
  • 流复制延迟恢复,同样需要设置 recovery_target_xid 、recovery_target_time 或recovery_target_lsn 来精准的定位到完整的数据集。
  • pg_waldump 是数据找回必备的一个功能。
  • 如果方案是重型的,轻型的插件有时会是更好的选择。
  • 若无任何准备,且不能安装任何插件,可第一时间将数据库关机!!!防止 Dead 元组被清理,拷贝整个集群,使用拷贝后的集群用 pg_resetwal 进行数据恢复。

参考引用

[1] :pgtrashcan:https://GitHub.com/petere/pgtrashcan

[2]:pg_basebackup:Https://www.postgresql.org/docs/10/app-pgbasebackup.html

[3]:pg_probackup:https://github.com/postgrespro/pg_probackup

[4]:pgbackrest:https://github.com/pgbackrest/pgbackrest

[5]:barman:https://github.com/EnterpriseDB/barman

[6]:pg_rman:https://github.com/ossc-db/pg_rman

到此这篇关于常用 PostgreSQL 预防数据丢失方案的文章就介绍到这了,更多相关PostgreSQL数据丢失内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 常用 PostgreSQL 预防数据丢失解决方案

本文链接: https://www.lsjlt.com/news/162912.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 常用 PostgreSQL 预防数据丢失解决方案
    目录预防数据丢失方案DDL 操作事件触发器回收站DML 操作流复制延迟恢复备份恢复总结作者:张连壮 PostgreSQL 研发负责人 从事多年 PostgreSQL 数据库内核开发,...
    99+
    2024-04-02
  • 云VPS如何预防数据丢失
    云VPS预防数据丢失的方法:1、需要做好云VPS安全维护方面的工作,降低云VPS被攻击的风险;2、在使用云VPS过程中,不要访问不良网站和下载不明链接,降低云VPS中毒的风险;3、定期对云VPS数据做好数据备份操作,避免云VPS数据丢失无法...
    99+
    2024-04-02
  • 服务器如何预防数据丢失
    服务器预防数据丢失的方法:1、采用Raid磁盘阵列存储,加强服务器硬盘的容错功能;2、注意服务器硬盘的运行状况,检查硬盘设备是否正常;3、备份重要的数据,选用磁带机配合专业备份软件,定期做相对完善的备份方案;4、如果数据误删除或格式化,在网...
    99+
    2024-04-02
  • 服务器怎么预防数据丢失
    服务器预防数据丢失的方法有很多种,下面列举几种常见的方法: 定期备份数据:定期将服务器上的重要数据进行备份,可以使用外部存储设备或...
    99+
    2024-05-10
    服务器
  • 厦门服务器怎么预防数据丢失
    厦门服务器预防数据丢失的方法:1、采用Raid磁盘阵列存储,加强服务器硬盘的容错功能;2、注意硬盘的运行状况,检查硬盘设备是否正常;3、备份重要的数据,选用磁带机配合专业备份软件,定期做相对完善的备份方案;4、如果数据误删除或格式化,在网上...
    99+
    2024-04-02
  • PHP参数丢失问题的解决方案
    PHP参数丢失问题的解决方案 在开发PHP程序的过程中,经常会遇到参数丢失的问题,这可能是由于前端传递的参数不完整、后端接收参数的方式不正确等原因造成的。在本文中,我们将针对PHP参数...
    99+
    2024-03-11
    数据恢复 解析错误 参数处理 表单提交
  • Redis主从集群切换数据丢失的解决方案
    一、数据丢失的情况 异步复制同步丢失 集群产生脑裂数据丢失 1.异步复制丢失 对于Redis主节点与从节点之间的数据复制,是异步复制的,当客户端发送写请求给master节点的时候,客...
    99+
    2024-04-02
  • 解决vuex数据丢失问题
    目录数据丢失的原因方法1:使用第三方库 vuex-persistedstate01 store / index.js 之 localStorage02 store / index.j...
    99+
    2023-02-02
    vuex 数据丢失
  • 虚拟机bootMgr丢失的解决方案
    虚拟机bootMgr丢失的解决方案: 先上图: 出现这张图片估计你就懵了!尤其是你的虚拟机中有重要的文件,你会更懵!甚至抓狂!别担心!数据丢不了!只要你不莽撞行事!如果你一气之下,把电脑砸了我也没办法啦!我相信上帝也帮不了你!_ 下面是解...
    99+
    2023-08-17
    linux java 运维
  • mq丢失数据怎么解决
    当MQ(消息队列)丢失数据时,可以采取以下几个方法来解决: 检查MQ配置:首先,确保MQ的配置是正确的,包括消息的持久化配置和重...
    99+
    2023-10-26
    mq
  • Redis数据丢失如何解决
    这篇文章将为大家详细讲解有关Redis数据丢失如何解决,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。什么是 AOF 日志?AOF(Append Only F...
    99+
    2024-04-02
  • 香港服务器如何有效预防网站数据丢失
    香港服务器有效预防网站数据丢失的方法:1、在租用香港服务器时,需选择带有raid阵列的香港服务器,从而有效防止网站的数据丢失;2、需要养成正确操作香港服务器的习惯,避免出现人为操作失误导致数据丢失;3、需要给香港服务器做好专业的安全措施,防...
    99+
    2024-04-02
  • 购买幻兽帕鲁服务器怎么预防数据丢失
    要预防幻兽帕鲁服务器数据丢失,可以采取以下措施: 定期备份数据:定期备份服务器中的数据,确保在数据丢失时可以恢复至最近的备份点。备...
    99+
    2024-04-09
    服务器 幻兽帕鲁服务器
  • JS数字精度丢失的原因及解决方案
    目录前言精度丢失原因如何将整数从十进制转换为二进制将小数从十进制转换为二进制解决方案第三方库Decimalbignumber变成整数总结前言 在JavaScript中计算两个十进制数...
    99+
    2024-04-02
  • php redis数据丢失如何解决
    本文小编为大家详细介绍“php redis数据丢失如何解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“php redis数据丢失如何解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。php redis数据丢失...
    99+
    2023-07-04
  • sql数据库丢失如何解决
    当发生SQL数据库丢失时,可以尝试以下解决方法:1. 恢复备份:如果有数据库备份,可以通过将备份文件恢复到原来的数据库中来解决丢失的...
    99+
    2023-09-22
    sql数据库
  • Golang 编程中常见的精度丢失情况及解决方案
    精度丢失在编程中属于一个普遍问题,尤其在使用 Golang 这样的语言时更为突出。Golang 是一种静态类型、编译型语言,其对精度要求非常高,因此开发者需要格外留意精度丢失的问题。本...
    99+
    2024-02-23
    解决方案 golang 精度丢失
  • Kafka保证零数据丢失的配置方案
    本篇内容介绍了“Kafka保证零数据丢失的配置方案”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!如果要想保证Kafka数据不丢, 要从Kaf...
    99+
    2023-06-02
  • MySQL数据库丢失root密码的解决方法
    这篇文章主要介绍了MySQL数据库丢失root密码的解决方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。  MySQL数据库丢失root密...
    99+
    2024-04-02
  • Feign远程调用参数里面内容丢失的解决方案
    目录Feign远程调用参数里面内容丢失举个例子解决方法Feign远程调用细节--丢失数据同步调用异步调用Feign远程调用参数里面内容丢失 举个例子 服务A提供了如下接口(注意这里的...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作