postgresql主从备份_基于PG12.2实现主从异步流复制及主从切换教程(下)
概述
今天主要介紹如何搭建PG主從流復制及主從切換,僅供參考。
PS:上篇的地址在文末鏈接.
PostgreSQL數據庫主從異步流復制搭建
環境說明:
1、安裝PG數據庫(主從庫進行)
用腳本進行,略。
2、主庫配置
2.1、添加流復制用戶
--修改/data/pgdata/postgresql.conf以下參數wal_level = hot_standby # 這個是設置主為wal的主機, minimal,replica or logical使得日志支持流復制max_wal_senders = 4 # 這個設置了可以最多有幾個流復制連接,差不多有幾個從,就設置幾個wal_keep_segments = 256 # 設置流復制保留的最多的xlog數目,不要設置太小導致WAL日志還沒有來得及傳送到standby就被覆蓋,一個WAL文件默認16Mhot_standby = on # "on" allows queries during recovery 設置為備庫時是否支持可讀wal_sender_timeout = 120s # 設置流復制主機發送數據的超時時間--檢查配置cat postgresql.conf |grep -E 'wal_level|max_wal_senders|wal_keep_segments|hot_standby|wal_sender_timeout' | grep -v '^#'2.2、修改配置文件postgresql.conf
--修改/data/pgdata/postgresql.conf以下參數wal_level = hot_standby # 這個是設置主為wal的主機, minimal,replica or logical使得日志支持流復制max_wal_senders = 4 # 這個設置了可以最多有幾個流復制連接,差不多有幾個從,就設置幾個wal_keep_segments = 256 # 設置流復制保留的最多的xlog數目,不要設置太小導致WAL日志還沒有來得及傳送到standby就被覆蓋,一個WAL文件默認16Mhot_standby = on # "on" allows queries during recovery 設置為備庫時是否支持可讀wal_sender_timeout = 120s # 設置流復制主機發送數據的超時時間--檢查配置cat postgresql.conf |grep -E 'wal_level|max_wal_senders|wal_keep_segments|hot_standby|wal_sender_timeout' | grep -v '^#'2.3、修改配置文件pg_hba.conf
增加如下參數
?systemctl restart postgresql2.4、重啟主庫
?systemctl restart postgresql3、從庫配置
PG 12把recovery.conf廢掉了,與PG 11略有不同,但大同小異。
3.1、通過pg_basebackup命令行在從庫上生成基礎備份
這里以/data/pgdata做數據目錄,遷移之前需保證/data/pgdata目錄為空
systemctl stop postgresqlrm -rf /data/pgdata/*#-Fp表示以plain格式數據,-Xs表示以stream方式包含所需的WAL文件,-P表示顯示進度,-R表示為replication寫配置信息。#備份完成,使用-R選項,在data目錄下自動生成standby.signal“信號”文件(可手工使用touch命令生成)以及更新了postgresql.auto.conf文件#postgresql.auto.conf中寫入了主庫的連接信息(可手工添加primary_conninfo信息)。pg_basebackup --progress -D /data/pgdata -h xx.142 -p 55432 -U replica --password -Fp -Xs -P -R3.2、修改配置文件standby.singal
cat > standby.signal <3.3、啟動從庫
#Permissions should be u=rwx (0700) or u=rwx,g=rx (0750)chmod -R 750 /data/pgdata/chown -R postgres:postgres /data/pgdata/systemctl restart postgresql4、主從流復制檢查
4.1、檢查進程
查看進程,主庫所在的機器中會看到sender進程
從庫所在的機器中會看到receiver進程
4.2、檢查異步流復制的情況
1)主庫查看復制狀態
?select pid,usename,client_addr,state,sent_lsn,write_lsn,flush_lsn,replay_lsn,sync_priority,sync_state from pg_stat_replication;參數說明:
- pid # sender的進程
- usename # 復制的用戶用戶名
- client_addr # 復制的客戶端地址
- client_port # 復制的客戶端端口
- backend_start # 主從搭建的時間
- state # 同步狀態 startup: 連接中、catchup: 同步中、streaming: 同步
- sent_location # Master傳送WAL的位置
- write_location # Slave接收WAL的位置
- flush_location # Slave同步到磁盤的WAL位置
- replay_location # Slave同步到數據庫的WAL位置
- sync_priority #同步Replication的優先度, 0: 異步、1~?: 同步(數字越小優先度越高)
- sync_state # 有三個值,async: 異步、sync: 同步、potential: 雖然現在是異步模式,但是有可能升級到同步模式
2)查看從服務(WAL接收器進程)狀態
?psql -c "x" -c "SELECT * FROM pg_stat_wal_receiver;"4.3、數據測試
1)主庫寫入數據
?create table tb1 (i int,t text);brinsert into tb1 values (1,'hwb');2)備庫查詢并寫入數據
?select * from tb1 ;brinsert into tb1 values (2,'hwb2');PostgreSQL主從數據庫切換
當主庫出現故障時,我們需要將備庫提升為主庫進行讀寫操作。激活備庫有3種方式:
1)pg_ctl 方式: 在備庫主機執行 pg_ctl promote shell 腳本
2)觸發器文件方式: 備庫配置 recovery.conf 文件的 trigger_file 參數,之后在備庫主機上創建觸發器文件
3)pg_promote()函數方式,可以通過SQL命令激活備庫(pg12之后)
1、識別當前庫主從角色
1)查看pg_is_in_recovery()視圖
?psql -c "x" -c "SELECT * FROM pg_stat_wal_receiver;"2)pg_controldata識別
pg_controldata 結果為cluster state是in production則為主庫;結果為cluster state是in archive recovery則為備庫。
?./pg_controldata -D /data/pgdata/ | grep cluster3)查看pg_stat_replication
--查詢到結果為主庫,查詢不到結果為備庫select pid, application_name, client_addr, client_port, state, sync_state from pg_stat_replication;2、基于pg_promote函數主從切換
2.1、關閉主庫,模擬故障
?systemctl stop postgresql2.2、激活備庫
pg_promote語法:
?pg_promote(wait boolean DEFAULT true, wait_seconds integer DEFAULT 60)兩個參數:
wait: 表示是否等待備庫的 promotion 完成或者 wait_seconds 秒之后返回成功,默認值為 true。
wait_seconds: 等待時間,單位秒,默認 60
?psql -c "x" -c "select pg_promote(true,60);"2.3、驗證
cd /usr/local/postgres/bindate && ./pg_controldata -D /data/pgdata/ | grep cluster至此便完成備庫的激活,當原主庫修復完后,我們可重復之前步驟將原主庫作為新的備庫使用。
2.4、原主庫切換為新備庫(在原主庫進行)
cat > standby.signal < postgresql.auto.conf <后面會分享更多devops和DBA方面內容,感興趣的朋友可以關注下~
《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀總結
以上是生活随笔為你收集整理的postgresql主从备份_基于PG12.2实现主从异步流复制及主从切换教程(下)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 冒泡排序算法_PHP冒泡排序算法(一)
- 下一篇: 判断元素是否在ndarray_暨南大学药