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
英文地址,請注明出處:http://en.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…