【Postgresql】postgresql9.3.9版本基於流復制方式雙機熱備方案
阿新 • • 發佈:2018-05-18
postgresql 雙機熱備 流復制 9.3.9
系統環境:centos6.5
數據庫版本: postgres9.3.9
虛擬機2臺:
Master:10.0.2.160
Slave:10.0.2.69
數據存儲位置:/usr/local/pgsql/data/
- 安裝pgsql數據庫
安裝過程可參考我上一篇博客:http://blog.51cto.com/13632960/2117902 兩臺機器都需要安裝完成,我在做熱備的時候,Master數據庫開啟,Slave關閉。
- 創建流復制用戶
Master端進入數據庫並執行: CREATE USER repuser?replication PASSWORD ‘repuser‘;?
- 配置Master端的訪問文件pg_hba.conf?
vim /usr/local/pgsql/data/pg_hba.conf 在最後添加:host replication repuser?10.0.2.69/16 md5 #md5為連接方式 你們也可以選擇其他的
- 配置Master端配置文件 postgresql.conf
在修改之前先創建一個文件夾用於歸檔文件存放:mkdir /usr/local/pgsql/data/archive
vim /usr/local/pgsql/data/postgresql.conf
修改下列項:max_wal_senders = 1? wal_level = hot_standby archive_mode = on? archive_command = ‘cp %p /usr/local/pgsql/data/archive/%f‘‘ hot_standby = on wal_keep_segments = 64
註釋: max_wal_senders是Slave庫的節點數,有多少個slave庫就設多少, ? ? ? wal_level是write ahead log參數值,設置流復制務必將此值更新成hot_standby ? ? ?wal_keep_segments默認值是16,是PG_XLOG下的日誌文件數相關參數 ?? ? archive也可以選擇關閉,歸檔是定時恢復用的,流復制不是必須的
- 主庫備份——Master端
開啟文件備份:/usr/local/pgsql/bin/psql psql (9.3.9) Type "help" for help. postgres=# select pg_start_backup(‘backup_1‘);
- 打包Master端/usr/local/pgsql/data/目錄,並發送到Slave服務器上,排除pg_xlog目錄內容!!!!!
cd /usr/local/pgsql/ tar -czvf? data.tar.gz data--exclude=data/pg_xlog? Slave端如果已經安裝了postgres數據庫,數據目錄名稱一樣的話,可以先停掉備機數據庫,更改數據目錄名稱 mv data data.old 遠程拷貝至slave端並在備機端解壓 scp data.tar.gz [email protected]:/usr/local/pgsql/ 拷貝完成後,進入數據庫關閉備份:select pg_stop_backup(),current_timestamp;
- Slave端解壓並修改相關配置文件
cd /usr/local/pgsql tar -zxvf data.tar.gz cd /usr/local/pgsql/data mkdir pg_xlog vim /usr/local/pgsql/data/postgresql.conf 修改:hot_standby = on
- 備機需要配置recovery.conf文件,將share目錄中的recovery.conf.sample拷貝並改名。
cp /usr/local/pgsql/share/recovery.conf.sample /usr/local/pgsql/data/recovery.conf 復制完成後修改如下內容: ?standby_mode = ‘on‘ primary_conninfo =‘host=10.0.2.69??port=5432 user=repuser password=repuser keepalives_idle=60‘
- 啟動Slave庫
正常啟動備庫,有異常可以看log /usr/local/pgsql/bin/pg_ctl start -D /usr/local/pgsql/data >>logfile 2>&1
- 查看主庫及從庫啟動狀態
Master:
Slave: - 至此postgresql流復制熱備方案部署完成,可以通過navicat或者命令行進行數據插入或者建表測試功能可用性。
【Postgresql】postgresql9.3.9版本基於流復制方式雙機熱備方案