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

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

主站蜘蛛池模板: 中文字幕乱码av | 在线免费观看av网址 | 成人片在线视频 | avwww.| 日韩av一卡 | 亚洲一区二区三区人妻 | 黄色免费看网站 | 日本人做爰全过程 | 伊人网址 | 久久人妻少妇嫩草av蜜桃 | 成年人a级片| 亚洲激情自拍偷拍 | 黄网在线观看视频 | av男人网| 亚洲不卡视频在线观看 | 欧美激情专区 | 欧美日韩激情在线观看 | 精品人伦一区二区三区蜜桃网站 | 久久久久久久无码 | 国产精品网站视频 | 动漫羞羞| 大陆明星乱淫(高h)小说 | 五月天激情影院 | 亚洲免费在线观看av | 玖玖爱这里只有精品 | 色av一区二区三区 | 熟妇人妻中文字幕 | 国产亚洲欧美精品久久久www | 香蕉视频链接 | 国产精品成人aaaaa网站 | 久久久综合色 | 亚洲黄色片免费看 | www.午夜| 国产在线一区二 | 夜夜欢视频 | 97免费视频观看 | 影音先锋久久 | 麻豆国产一区二区三区 | 天堂中文在线观看视频 | 视频在线不卡 | 欧美区日韩区 | 台湾佬美性中文娱乐网 | 精品国产成人亚洲午夜福利 | 91精品国产综合久久久密臀九色 | www.午夜激情| 精产国产伦理一二三区 | 免费在线观看亚洲 | 一区二区三区免费在线观看 | 自由成熟xxxx色视频 | 99ri在线观看 | 国产99精品 | h在线 | 精品久久人人 | 亚洲性免费 | 国产区亚洲区 | 国产免费一区二区三区最新不卡 | 一区二区三区天堂 | 国产成人高清在线 | 欧美视频黄| 久久久久久久久国产精品 | 在线视频一区二区三区四区 | 性生活一区 | 亚洲制服一区二区 | 五月天伊人网 | 97国产精东麻豆人妻电影 | 亚洲精品一区二区三区在线观看 | 丰满熟女人妻一区二区三 | 亚洲国产精品va在线看黑人 | 丰满尤物白嫩啪啪少妇 | a天堂在线视频 | 综合久久中文字幕 | 肌肉猛男裸体gay网站免费 | 人妻精品久久久久中文 | 一级特黄av| 日韩成人无码影院 | 婷婷色综合网 | 久久久久久久久久综合 | 69热在线| 久久久国产精华液999999 | 久久久综合久久久 | 国产制服丝袜在线 | 午夜伦伦电影理论片费看 | 欧美在线一区二区三区四区 | 欧美日韩国产成人精品 | 麻豆伦理片 | 色涩网站 | 男人靠女人免费视频网站 | 国产尤物视频在线 | 国产婷婷色综合av蜜臀av | 欧美人妻精品一区二区 | 免费黄片毛片 | 国产片91| 丰满秘书被猛烈进入高清播放在 | 国产精品久久久久国产a级 国产一区二区在线播放 | 国产性―交―乱―色―情人 | 亚洲 欧美 激情 另类 校园 | 久久久精品久久久久 | 日本毛片视频 | 日韩在线观看视频一区 |