濮阳杆衣贸易有限公司

主頁 > 知識庫 > PostgreSQL 主備數(shù)據(jù)宕機(jī)恢復(fù)測試方案

PostgreSQL 主備數(shù)據(jù)宕機(jī)恢復(fù)測試方案

熱門標(biāo)簽:外呼調(diào)研系統(tǒng) 合肥公司外呼系統(tǒng)運(yùn)營商 打電話智能電銷機(jī)器人授權(quán) 重慶自動外呼系統(tǒng)定制 美容工作室地圖標(biāo)注 海豐有多少商家沒有地圖標(biāo)注 地圖標(biāo)注和圖片名稱的區(qū)別 漯河外呼電話系統(tǒng) 辦公外呼電話系統(tǒng)

主節(jié)點(diǎn)宕機(jī)數(shù)據(jù),備庫數(shù)據(jù)恢復(fù)

背 景

在從節(jié)點(diǎn)停止服務(wù),然后往主庫不斷寫入數(shù)據(jù),然后把主機(jī)宕機(jī)掉,啟動從庫,把主庫宕機(jī)期間的增量wal日志復(fù)制到從庫的archive目錄下, 執(zhí)行恢復(fù)腳本,則會把主機(jī)宕機(jī)后的增量數(shù)據(jù)追加到數(shù)據(jù)庫。

環(huán)境

服務(wù)器 角色
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,初始化數(shù)據(jù)庫從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 ,從歸檔目錄恢復(fù)數(shù)據(jù)

#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'

以上就實(shí)現(xiàn)了主從異步流復(fù)制

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

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

在16 創(chuàng)建用戶 repl 、創(chuàng)建表、略

主庫16正常時,p表數(shù)據(jù)為

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

從庫18 p表數(shù)據(jù)

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

主庫宕機(jī)前(16)

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

主庫(16)宕機(jī)后,從庫進(jìn)行恢復(fù)后,數(shù)據(jù)已經(jīng)追加:

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)

補(bǔ)充:postgresql在windows重裝后如何重新恢復(fù)的方法

背景

windows系統(tǒng)重裝后我們的postgresql服務(wù)器就不會正常啟動,因?yàn)樵谙到y(tǒng)中注冊的服務(wù)重裝后已經(jīng)沒有了,但是你的postgresql不是安裝在系統(tǒng)盤區(qū)上的,那么postgresql服務(wù)器的文件和數(shù)據(jù)就還是存在的,比如原來的安裝目錄是D:\PostgreSQL,那么我們怎么讓服務(wù)器服務(wù)自動運(yùn)行起來,這樣我們的程序才能連接數(shù)據(jù)庫了,而且數(shù)據(jù)還不會丟失。

處理方法

第一種方法:

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

第二種方法:

重新注冊服務(wù),其實(shí)比重新安裝還簡單了;執(zhí)行命令就可以了,

第一步:進(jìn)入到數(shù)據(jù)庫的安裝目錄,cd D:\PostgreSQL\bin;

第二部:執(zhí)行服務(wù)注冊:

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

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

第三步:啟動服務(wù),net start pg921;

通過上面的的方法就成功的注冊了服務(wù)器,以后每次開機(jī)都可以使用數(shù)據(jù)庫了;

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

注意:服務(wù)項不需要填寫,主機(jī)填寫localhost,如果填寫真實(shí)的ip,必須在數(shù)據(jù)庫配置文件中配置ip權(quán)限,否則不能連接;

以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • PostgreSQL+Pgpool實(shí)現(xiàn)HA主備切換的操作
  • PostgreSQL 數(shù)據(jù)同步到ES 搭建操作
  • postgresql 如何查看pg_wal目錄下xlog文件總大小
  • postgresql之使用lsn 獲取 wal文件名的實(shí)例
  • 修改postgresql存儲目錄的操作方式
  • postgresql運(yùn)維之遠(yuǎn)程遷移操作
  • postgresql 12版本搭建及主備部署操作

標(biāo)簽:珠海 株洲 蚌埠 衡陽 烏海 錦州 來賓 晉城

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PostgreSQL 主備數(shù)據(jù)宕機(jī)恢復(fù)測試方案》,本文關(guān)鍵詞  PostgreSQL,主備,數(shù)據(jù),宕機(jī),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PostgreSQL 主備數(shù)據(jù)宕機(jī)恢復(fù)測試方案》相關(guān)的同類信息!
  • 本頁收集關(guān)于PostgreSQL 主備數(shù)據(jù)宕機(jī)恢復(fù)測試方案的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    金门县| 白城市| 武威市| 松溪县| 文登市| 平原县| 栾川县| 安康市| 西华县| 新沂市| 容城县| 泸定县| 葫芦岛市| 宜阳县| 贵南县| 巴马| 棋牌| 苍山县| 开封县| 平南县| 岗巴县| 黑山县| 盘山县| 胶州市| 闽清县| 邵东县| 织金县| 资源县| 海口市| 辉县市| 徐水县| 丰台区| 阳谷县| 凤阳县| 金塔县| 常熟市| 深水埗区| 巴东县| 广州市| 贺兰县| 合肥市|