服務(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ù)庫(kù)從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ù)制
啟動(dòng)16查詢(xún) 為 f 表示為 主庫(kù)
pocdb=# select pg_is_in_recovery(); pg_is_in_recovery ------------------- f (1 row) Time: 0.786 ms pocdb=#
在16 創(chuàng)建用戶(hù) repl 、創(chuàng)建表、略
主庫(kù)16正常時(shí),p表數(shù)據(jù)為
pocdb=# select max(id) from p; max --------- 3774121 (1 row)
從庫(kù)18 p表數(shù)據(jù)
pocdb=# select max(id) from p; max --------- 3774121 (1 row)
主庫(kù)宕機(jī)前(16)
pocdb=# select max(id) from p; max --------- 4005263 (1 row)
主庫(kù)(16)宕機(jī)后,從庫(kù)進(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ù)器就不會(huì)正常啟動(dòng),因?yàn)樵谙到y(tǒng)中注冊(cè)的服務(wù)重裝后已經(jīng)沒(méi)有了,但是你的postgresql不是安裝在系統(tǒng)盤(pán)區(qū)上的,那么postgresql服務(wù)器的文件和數(shù)據(jù)就還是存在的,比如原來(lái)的安裝目錄是D:\PostgreSQL,那么我們?cè)趺醋尫?wù)器服務(wù)自動(dòng)運(yùn)行起來(lái),這樣我們的程序才能連接數(shù)據(jù)庫(kù)了,而且數(shù)據(jù)還不會(huì)丟失。
第一種方法:
最簡(jiǎn)單的辦法重裝,把原來(lái)的文件全部刪除,如果原來(lái)有數(shù)據(jù)備份,把備份數(shù)據(jù)恢復(fù)就可以了,那如果重裝系統(tǒng)前沒(méi)有備份數(shù)據(jù)呢?這種辦法就找不回原來(lái)的數(shù)據(jù)了,對(duì)于開(kāi)發(fā)者來(lái)說(shuō)是很頭疼的,那么我給大家介紹第二種方法,前提是數(shù)據(jù)庫(kù)的安裝目錄和數(shù)據(jù)庫(kù)數(shù)據(jù)目錄文件夾都是完好無(wú)損的,否則我也沒(méi)辦法了;
第二種方法:
重新注冊(cè)服務(wù),其實(shí)比重新安裝還簡(jiǎn)單了;執(zhí)行命令就可以了,
第一步:進(jìn)入到數(shù)據(jù)庫(kù)的安裝目錄,cd D:\PostgreSQL\bin;
第二部:執(zhí)行服務(wù)注冊(cè):
pg_ctl register -N pg921 -D D:\PostgreSQL\data -S auto -w -t 10 -l D:/PostgreSQL/pg921.log -o "-p 5432",
-N pg921 代表注冊(cè)服務(wù)的名稱(chēng) ,-D代表數(shù)據(jù)庫(kù)文件目錄 ,-S代表服務(wù)啟動(dòng)方式auto自動(dòng),demand手動(dòng),-o "-p 5432"指啟動(dòng)服務(wù)端口;(可以通過(guò)pg_ctl --help命令查看使用方法)
第三步:?jiǎn)?dòng)服務(wù),net start pg921;
通過(guò)上面的的方法就成功的注冊(cè)了服務(wù)器,以后每次開(kāi)機(jī)都可以使用數(shù)據(jù)庫(kù)了;
但是postgresql自帶的一個(gè)管理工具pgAdmin3還是不能正常使用,需要我們配置,配置方法見(jiàn)下圖:
注意:服務(wù)項(xiàng)不需要填寫(xiě),主機(jī)填寫(xiě)localhost,如果填寫(xiě)真實(shí)的ip,必須在數(shù)據(jù)庫(kù)配置文件中配置ip權(quán)限,否則不能連接;
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
標(biāo)簽:珠海 株洲 蚌埠 衡陽(yáng) 烏海 錦州 來(lái)賓 晉城
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PostgreSQL 主備數(shù)據(jù)宕機(jī)恢復(fù)測(cè)試方案》,本文關(guān)鍵詞 PostgreSQL,主備,數(shù)據(jù),宕機(jī),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。