PostgreSQL 主備數據宕機恢復測試方案

主節點宕機數據,備庫數據恢復

背 景

在從節點停止服務,然後往主庫不斷寫入數據,然後把主機宕機掉,啟動從庫,把主庫宕機期間的增量wal日志復制到從庫的archive目錄下, 執行恢復腳本,則會把主機宕機後的增量數據追加到數據庫。

環境

服務器 角色
10.10.56.16 master
10.10.56.18 slave

– 配置16 master 的 pg_hba,conf 文件

host all  all  10.10.56.0/0  md5
host replication all  10.10.56.0/0  trust
"pg_hba.conf" 96L, 4652C 

配置16 master的 postgresql.conf

listen_addresses = '*'
max_connections = 1000 
wal_level = logical 
archive_mode = on 
archive_command = '/bin/true' 
log_destination = 'csvlog'
logging_collector = on 
log_filename = 'postgresql-%Y-%m-%d.log' 
log_rotation_size = 20MB 
log_statement = 'mod'
log_replication_commands = on
deadlock_timeout = 100ms 

配置18 slave,初始化數據庫從master pg_basebackup

 /opt/pgsql-10/bin/pg_basebackup -h 10.10.56.16 -U repl -W -Fp -Pv -Xs -R -D /pgdata/10/poc/data/

配置18的 recovery.conf ,從歸檔目錄恢復數據

#standby_mode = 'on'
#primary_conninfo = 'user=repl password=123456 host=10.10.56.16 port=5432 sslmode=disable sslcompression=1 target_session_attrs=any'
restore_command = 'cp /pgdata/10/archive/%f %p'

以上就實現瞭主從異步流復制

啟動16查詢 為 f 表示為 主庫

pocdb=# select pg_is_in_recovery();
 pg_is_in_recovery
-------------------
 f
(1 row)
Time: 0.786 ms
pocdb=#

在16 創建用戶 repl 、創建表、略

主庫16正常時,p表數據為

pocdb=# select max(id) from p;
 max
---------
 3774121
(1 row)

從庫18 p表數據

pocdb=# select max(id) from p;
 max
---------
 3774121
(1 row)

主庫宕機前(16)

pocdb=# select max(id) from p;
 max
---------
 4005263
(1 row)

主庫(16)宕機後,從庫進行恢復後,數據已經追加:

postgres@clw-db3:/pgdata/10/poc/data> /opt/pgsql-10/bin/psql pocdb
psql (10.3)
Type "help" for help.
pocdb=# select max(id) from p;
 max
---------
 4005263
(1 row)

補充:postgresql在windows重裝後如何重新恢復的方法

背景

windows系統重裝後我們的postgresql服務器就不會正常啟動,因為在系統中註冊的服務重裝後已經沒有瞭,但是你的postgresql不是安裝在系統盤區上的,那麼postgresql服務器的文件和數據就還是存在的,比如原來的安裝目錄是D:\PostgreSQL,那麼我們怎麼讓服務器服務自動運行起來,這樣我們的程序才能連接數據庫瞭,而且數據還不會丟失。

處理方法

第一種方法:

最簡單的辦法重裝,把原來的文件全部刪除,如果原來有數據備份,把備份數據恢復就可以瞭,那如果重裝系統前沒有備份數據呢?這種辦法就找不回原來的數據瞭,對於開發者來說是很頭疼的,那麼我給大傢介紹第二種方法,前提是數據庫的安裝目錄和數據庫數據目錄文件夾都是完好無損的,否則我也沒辦法瞭;

第二種方法:

重新註冊服務,其實比重新安裝還簡單瞭;執行命令就可以瞭,

第一步:進入到數據庫的安裝目錄,cd D:\PostgreSQL\bin;

第二部:執行服務註冊:

pg_ctl register -N pg921 -D D:\PostgreSQL\data -S auto -w -t 10 -l D:/PostgreSQL/pg921.log -o "-p 5432",

-N pg921 代表註冊服務的名稱 ,-D代表數據庫文件目錄 ,-S代表服務啟動方式auto自動,demand手動,-o “-p 5432″指啟動服務端口;(可以通過pg_ctl –help命令查看使用方法)

第三步:啟動服務,net start pg921;

通過上面的的方法就成功的註冊瞭服務器,以後每次開機都可以使用數據庫瞭;

但是postgresql自帶的一個管理工具pgAdmin3還是不能正常使用,需要我們配置,配置方法見下圖:

註意:服務項不需要填寫,主機填寫localhost,如果填寫真實的ip,必須在數據庫配置文件中配置ip權限,否則不能連接;

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。如有錯誤或未考慮完全的地方,望不吝賜教。

推薦閱讀: