PostgreSQL基于归档日志的持续恢复测试

测试环境:

os: linux 

PG: 17.4

src ip: 192.168.100.51

dst ip: 192.168.100.138

src: PGDATA=/home/postgres174/pgdata

dst: PGDATA=/data/174/pgdata_standby

归档路径: 192.168.100.138 /data/174/archivedir

测试流程:

1. 主库(51)设置archive_command参数,将归档日志放到138的/data174/archivedir目录中

archive_command= 'sshpass -p 123456 scp -o StrictHostKeyChecking=no %p postgres174@192.168.100.138:/data/174/archivedir/%f'

2. 目标机器(138)制作基础备份

pg_basebackup -h 192.168.100.51 -U postgres -p 15432 -D pgdata_standby/ -P -R
Password:
16498542/16498542 kB (100%), 2/2 tablespaces

3. 修改pgdata_standby的postgresql.auto.conf

注释掉: primary_conninfo和archive_command两个参数

增加restore_command和archive_clean_up参数

restore_command='cp /data/174/archivedir/%f %p'
archive_cleanup_command = 'pg_archivecleanup /data/174/archivedir %r'

4. 启动备库

5. 测试

51
postgres=# select count(*) from test123;count
----------20000000postgres=# delete from test123;
DELETE 20000000备库:postgres=# select count(*) from test123;
WARNING:  database "postgres" has a collation version mismatch
DETAIL:  The database was created using collation version 2.28, but the operating system provides version 2.17.
HINT:  Rebuild all objects in this database that use the default collation and run ALTER DATABASE postgres REFRESH COLLATION VERSION, or build PostgreSQL with the right library version.
WARNING:  database "postgres" has a collation version mismatch
DETAIL:  The database was created using collation version 2.28, but the operating system provides version 2.17.
HINT:  Rebuild all objects in this database that use the default collation and run ALTER DATABASE postgres REFRESH COLLATION VERSION, or build PostgreSQL with the right library version.count
----------20000000
(1 row)备库上依然还是2000w行记录,是因为包含commit日志的记录还没有归档,所以并没有同步过来,我们在51上手动切换下日志,就可以了51
postgres=# select pg_switch_wal();pg_switch_wal
---------------CEB/F92F17B0
(1 row)138上查询
postgres=# select count(*) from test123;count
-------0
(1 row)注释:手动切换只是测试为目的,实际可以通过设置archive_timeout参数来强制归档,即使日志没有满,这样就可以实现备库自动的最终一致性。

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

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

相关文章

Linux——内核——网络协议

Linux网络协议栈是Linux内核中实现网络通信的核心组件,其设计遵循分层架构,支持多种网络协议和功能。以下从协议栈的分层结构、关键组件、工作流程、数据包处理机制、优化与调试等方面进行详尽阐述: 一、协议栈的分层结构 Linux网络协议栈基…

vue | 插件 | 移动文件的插件 —— move-file-cli 插件 的安装与使用

问题:想将打包生成的 dist 文件下的样式相关文件,进行移动。 解决:在 npm 上找写好的兼容操作系统的包 move-file-cli 插件 ,用于移动文件 move-file-cli 插件的安装与使用 安装:npm install move-file-cli --save-d…

多个单片机简单通讯框架

文章目录 一、场景描述二、框架搭建设计思路通信协议设计2号单片机通讯框架框架优化建议 三、2号单片机的通讯框架如何处理消息丢失和重传?消息丢失与重传机制设计改进的通信协议重传机制实现关键机制说明优化建议 一、场景描述 有3个单片机进行通讯,分…

如何在服务区已有预装镜像的情况下管理自己的包

你的需求非常明确:希望利用 NGC 镜像预装的主环境包(如 PyTorch、CUDA),同时能独立管理自己额外安装的包,避免直接污染主环境。以下是几种解决方案,按推荐度排序: 方案 1:虚拟环境复…

JavaWeb之Servlet(2)RequestResponse..

文章目录 1 Request和Response的概述2 Request对象2.1 Request继承体系2.2 Request获取请求数据2.2.1 获取请求行数据2.2.2 获取请求头数据2.2.3 获取请求体数据1-3小结2.2.4 获取请求参数的通用方式请求参数和请求数据的区别问题案例分析问题解决 2.3 IDEA快速创建Servlet2.4 …

将 h264+g711a存为 mp4文件,记录

将 h264g711a存为 mp4文件,记录 📌 关键问题:MP4 不原生支持 G.711A MP4 容器格式 不原生支持 G.711(包括 A-law,也就是 G.711A)音频,所以不能直接将 G.711A 音频封装进 MP4 文件中。常见的做法…

【Elasticsearch】全文检索 组合检索

全文检索 1.全文检索1.1 准备测试数据1.2 案例分析1.2.1 match(分词检索)1.2.2 match_phrase(短语检索)1.2.3 match_phrase_prefix(短语前缀匹配)1.2.4 multi_match(多字段匹配)1.2.…

信号处理学习——文献精读与code复现之TFN——嵌入时频变换的可解释神经网络(上)

​​​​​​​​​​​​​​TFN: An interpretable neural network with time-frequency transform embedded for intelligent fault diagnosis - ScienceDirecthttps://www.sciencedirect.com/science/article/abs/pii/S0888327023008609?via%3Dihub (看看玲娜贝…

Panda3D实战:从入门到精通

Panda3D基础实例 创建一个简单的Panda3D场景,加载一个模型并显示: from direct.showbase.ShowBase import ShowBaseclass MyApp(ShowBase):def __init__(self):ShowBase.__init__(self)self.scene = self.loader.loadModel("models/environment")self.scene.repa…

Galera集群:高可用MySQL同步复制方案

目录 Galera Cluster 概述 核心架构与组件 WSREP API Group Communication System (GCP) 同步复制机制 复制流程详解 冲突检测算法 关键特性 多主架构实现 强一致性保障 自动成员管理 性能优化策略 并行复制实现 流控机制详解 批处理与压缩 部署与监控 详细配…

MybatisPlus-03.快速入门-常用注解

一.MP的原理 mp究竟是如何知道我们需要对哪个表进行操作,并且又是如何知道要操作哪些字段的呢?这是因为mp使用到了反射机制,我们在定义mapper接口时使其继承了BaseMapper接口,并指定了BaseMapper接口泛型为User,因此m…

ABAP+记录一个BDC的BUG修改过程

问题背景: 业务顾问反馈在使用BDC 进行MEQ1进行供应商配额时,由于以前录屏时用例只有3行数据,导致现在有5行数据的时候,代码仍然只获取了3行数据进行录入,现在需要更改代码,使其按照实际情况自动调整行数。…

github上传代码步骤(http)

github上传步骤(http) 之前github上传不了代码,总是报错。后面发现自己用的ssh上传需要秘钥,现在我介绍一个最简单的http上传方法(虽然没有ssh安全。。。但简单嘛~),现在我做个例子&#xff0c…

深入理解Nginx-以实际http通信例子改造带ssl配Nginx的实战-优雅草卓伊凡|麻子

深入理解Nginx-以实际http通信例子改造带ssl配Nginx的实战-优雅草卓伊凡|麻子 SSL/TLS在Nginx中的底层实现原理 Nginx的SSL模块架构 Nginx通过ngx_http_ssl_module模块实现SSL/TLS功能,该模块基于OpenSSL库构建。根据Nginx官方文档,SSL模块在Nginx架构…

AT6558R-5N32介绍

作为单芯片SOC方案,AT6558R在片上整合了射频前端、数字基带处理器与32位RISC CPU,并具备电源管理能力。该芯片兼容北斗、GPS、GLONASS三大卫星导航系统,可实现多模协同定位‌。 主要特征 支持 BDS/GPS/GLONASS 多系统联合定位 和单系统独立定…

“对象创建”模式之原型模式

目录 Prototype 原型模式动机 Motivation引例模式定义结构 Structure要点总结 Prototype 原型模式 动机 Motivation 在软件系统中,经常面临着“某些结构复杂的对象”的创建工作;由于需求的变化,这些对象经常面临着剧烈的变化,但…

Tomcat服务概述

前言: 作为Apache软件基金会Jakarta项目的核心成果,Tomcat凭借其轻量级、开源免费的特性,已成为Java Web应用服务的行业基准。它实现了完整的Servlet与JSP规范,通过模块化架构(Connector请求处理层与Container业务逻辑…

HarmonyOS应用开发高级认证知识点梳理 (一) 布局与样式

以下是 HarmonyOS 应用开发中 ‌布局与样式‌ 的核心知识点梳理(针对高级认证备考),结合官方文档与高频考点: 一、布局系统核心知识点 布局容器类型‌ 线性布局‌:Column(纵向)、Row&#xf…

【Ragflow】30.离线环境迁移方案

前言 之前的 Ragflow-Plus 在服务器上稳定运行一段时间后,接到任务,要把服务迁移到一台古老的,离线的windows台式机上。 起初认为,下载离线安装包,加载离线镜像,迁移下数据就可以了。 结果坑多得意想不到…

nrf52840蓝牙学习(定时器的应用)

和其他 MCU 处理器一样,在 nrf52840 中定时器的功能是十分强大的。其内部包含了 5 个定时 器 TIMER 模块 :TIMER0 、 TIMER1 、 TIMER2 、 TIMER3 、 TIMER4 ,如下表 10.1 所示。 1. 时钟源 首先定时器 TIMER 工作在高频时钟源&#xff08…