日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

postgresql主从备份_基于PG12.2实现主从异步流复制及主从切换教程(下)

發布時間:2025/4/16 编程问答 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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 postgresql

2.4、重啟主庫

?systemctl restart postgresql

3、從庫配置

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 -R

3.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 postgresql

4、主從流復制檢查

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 cluster

3)查看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 postgresql

2.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实现主从异步流复制及主从切换教程(下)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。