時間:2024-02-05 11:03作者:下載吧人氣:19
1. 基于文件的日志傳送
創(chuàng)建一個高可用性(HA)集群配置可采用連續(xù)歸檔,集群中主服務(wù)器工作在連續(xù)歸檔模式下,備服務(wù)器工作在連續(xù)恢復(fù)模式下(1臺或多臺可隨時接管主服務(wù)器),備持續(xù)從主服務(wù)器讀取WAL文件。
連續(xù)歸檔不需要對數(shù)據(jù)庫表做任何改動,可有效降低管理開銷,對主服務(wù)器的性能影響也相對較低。
直接從一個數(shù)據(jù)庫服務(wù)器移動WAL記錄到另一臺服務(wù)器被稱為日志傳送,PostgreSQL通過一次一文件(WAL段)的WAL記錄傳輸實現(xiàn)了基于文件的日志傳送。
日志傳送所需的帶寬取根據(jù)主服務(wù)器的事務(wù)率而變化;
日志傳送是異步的,即WAL記錄是在事務(wù)提交后才被傳送,那么在一個窗口期內(nèi)如果主服務(wù)器發(fā)生災(zāi)難性的失效則會導(dǎo)致數(shù)據(jù)丟失,還沒有被傳送的事務(wù)將會被丟失;
數(shù)據(jù)丟失窗口可以通過使用參數(shù)archive_timeout進(jìn)行限制,可以低至數(shù)秒,但同時會增加文件傳送所需的帶寬。
2. 流復(fù)制
PostgreSQL在9.x之后引入了主從的流復(fù)制機(jī)制,所謂流復(fù)制,就是備服務(wù)器通過tcp流從主服務(wù)器中同步相應(yīng)的數(shù)據(jù),主服務(wù)器在WAL記錄產(chǎn)生時即將它們以流式傳送給備服務(wù)器,而不必等到WAL文件被填充。
默認(rèn)情況下流復(fù)制是異步的,這種情況下主服務(wù)器上提交一個事務(wù)與該變化在備服務(wù)器上變得可見之間客觀上存在短暫的延遲,但這種延遲相比基于文件的日志傳送方式依然要小得多,在備服務(wù)器的能力滿足負(fù)載的前提下延遲通常低于一秒;
在流復(fù)制中,備服務(wù)器比使用基于文件的日志傳送具有更小的數(shù)據(jù)丟失窗口,不需要采用archive_timeout來縮減數(shù)據(jù)丟失窗口;
將一個備服務(wù)器從基于文件日志傳送轉(zhuǎn)變成基于流復(fù)制的步驟是:把recovery.conf文件中的primary_conninfo設(shè)置指向主服務(wù)器;設(shè)置主服務(wù)器配置文件的listen_addresses參數(shù)與認(rèn)證文件即可。
操作系統(tǒng): CentOS 7
數(shù)據(jù)庫: PostgreSQL 12
1、創(chuàng)建具有流復(fù)制權(quán)限的用戶
CREATE ROLE replica login replication encrypted password ‘replica的密碼’;
網(wǎng)友評論