PostgreSQL 主從集群搭建

下面是 PostgreSQL 主從復制(Streaming Replication)環境的安裝與配置指南,適合在兩臺或多臺服務器之間構建一主一從(或一主多從)的高可用讀寫分離系統。


環境準備

角色主機名/IP說明
主庫192.168.1.10可讀寫,負責復制源
從庫192.168.1.11只讀,從主庫同步數據

推薦 PostgreSQL 版本一致,例如 15.x;操作系統為 Ubuntu/CentOS 均可。


一、安裝 PostgreSQL(主從都要裝)

以 Ubuntu 為例:

sudo apt update
sudo apt install postgresql postgresql-contrib -y

CentOS:

sudo yum install -y postgresql-server postgresql-contrib

初始化數據庫(如未自動初始化):

sudo -u postgres /usr/pgsql-15/bin/initdb -D /var/lib/pgsql/15/data

二、配置主庫(192.168.1.10)

1. 修改 postgresql.conf

路徑通常為 /etc/postgresql/15/main/postgresql.conf/var/lib/pgsql/15/data/postgresql.conf

# 啟用 WAL 日志并設置參數
wal_level = replica
max_wal_senders = 10
wal_keep_size = 128MB
hot_standby = on
listen_addresses = '*'

2. 修改 pg_hba.conf(允許從庫連接復制)

# 添加允許從庫復制連接
host    replication     all     192.168.1.11/32     md5

3. 重啟主庫

sudo systemctl restart postgresql

三、從庫配置(192.168.1.11)

1. 停止 PostgreSQL 服務并清空數據目錄

sudo systemctl stop postgresql
rm -rf /var/lib/postgresql/15/main/*

2. 使用 pg_basebackup 拉取主庫數據

pg_basebackup -h 192.168.1.10 -D /var/lib/postgresql/15/main -U postgres -P -R

說明:

  • -h:主庫 IP
  • -D:寫入數據目錄
  • -U:復制用戶(需先創建)
  • -R:自動創建 standby.signalprimary_conninfo

如果提示用戶不存在,請先在主庫執行:

CREATE ROLE repl WITH REPLICATION LOGIN PASSWORD 'replpass';

并確保 pg_hba.conf 中允許該 IP 使用此用戶連接。

3. 修改復制用戶密碼(如果 -R 中未設置)

編輯 postgresql.conf 確保:

primary_conninfo = 'host=192.168.1.10 port=5432 user=repl password=replpass'

四、啟動從庫

sudo systemctl start postgresql

檢查日志 /var/log/postgresql/postgresql-15-main.log 是否同步成功。


五、驗證主從同步

主庫執行:

SELECT * FROM pg_stat_replication;

從庫查看:

SELECT pg_is_in_recovery();  -- 返回 true 表示是從庫

六、主從讀寫測試建議

操作主庫從庫
創建表/插入數據? 支持? 禁止
查詢數據? 支持? 支持
自動同步? 向從庫推送? 被動接收

七、開機自啟動設置(主從)

sudo systemctl enable postgresql

八、參考目錄結構(Debian/Ubuntu)

配置文件路徑
postgresql.conf/etc/postgresql/15/main/
pg_hba.conf/etc/postgresql/15/main/
數據目錄/var/lib/postgresql/15/main/
日志文件/var/log/postgresql/postgresql-15-main.log

常見問題排查

問題解決辦法
pg_basebackup 報權限錯誤主庫需創建 replication 權限用戶
從庫無法連接主庫檢查主庫防火墻 / pg_hba.conf
主庫 pg_stat_replication 為空檢查從庫連接信息是否正確
寫入從庫失敗合理,PostgreSQL 只讀備庫默認禁止寫入

高級擴展建議

目標建議工具
自動故障切換repmgr, Patroni
虛擬 IP 高可用切換Keepalived + VIP
讀寫分離中間件pgpool-II
多從、鏈式復制支持
雙機部署腳本化自動搭建Ansible/腳本工具

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/88795.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/88795.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/88795.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

STM32安全固件升級:使用自定義 bootloader 實現SD卡固件升級,包含固件加密

前言 在 STM32 嵌入式開發中,Bootloader 是一個不可或缺的模塊。ST 公司為 STM32 提供了功能完備的官方 Bootloader,支持多種通信接口(如 USART、USB DFU、I2C、SPI 等),適用于標準的固件更新方案。 然而&#xff0c…

一步部署APache編譯安裝腳本

接下來我來介紹以下編譯安裝的好處 編譯安裝的優點與缺點 一、優點 高度可定制 可根據實際需求啟用或關閉特性(如 Apache 的模塊、MySQL 的引擎等)。 靈活控制編譯參數、優化性能(如 --enable-xxx、--with-xxx)。 更高的性能…

[Linux]mmap()函數內存映射原理及用法

一、內存映射 內存映射,簡而言之就是將用戶空間的一段內存區域映射到內核空間,映射成功后,用戶對這段內存區域的修改可以直接反映到內核空間,同樣,內核空間對這段區域的修改也直接反映用戶空間。那么對于內核空間和用…

通信無BUG,ethernet ip轉profinet網關,汽車焊接設備通信有心機

在運用“激光釬焊”對汽車車頂、側面板、后行李箱蓋等位置進行接合時,必須配備能夠沿著復雜車身線條,對細窄焊接線實施高精度快速檢測及模仿控制的“焊縫跟蹤控制”。 那么汽車生產線的系統升級改造迫在眉睫,當西門子PLC和庫卡機器人無法通信…

python腳本ETH獲取最新發行版本并將是否更新信息發送到釘釘

import requests import json import time import hmac import hashlib import base64 import urllib.parse# 1. 配置釘釘機器人 webhook "https://oapi.dingtalk.com/robot/send?access_tokenXXX" secret "XXX" # 如果沒有加簽驗證,請設…

【Docker基礎】Docker容器管理:docker ps及其參數詳解

目錄 1 docker ps命令概述 1.1 命令定位與作用 1.2 命令基本語法 2 基礎參數詳解 2.1 默認輸出解析 2.2 核心參數解析 2.2.1 -a, --all 2.2.2 -q, --quiet 2.2.3 --no-trunc 3 高級過濾與格式化 3.1 過濾器(--filter)詳解 3.1.1 常用過濾條件 3.1.2 實際應用示例 …

應急響應-感染Neshta病毒

病毒確定: 根據感染現象確定為Virus/Win32.Neshta家族病毒 病毒表現: 該病毒為感染式病毒。該病毒會在系統%SystemRoot%目錄下釋放svchost.com文件,并通過添加注冊表的方式確保每個exe文件執行的時候都會先執行這個文件。該病毒還會收集系統信…

Hyperledger Fabric 入門筆記(二十)Fabric V2.5 測試網絡進階之Tape性能測試

文章目錄 前言一、介紹二、架構三、安裝說明四、使用方法4.1. 修改配置文件4.2. 啟動測試網絡4.3. 運行測試 前言 本文介紹由Hyperledger中國技術工作組提供的另一款區塊鏈網絡性能測試工具Tape的架構、安裝和在Fabric測試網絡中的使用。 一、介紹 Tape是一款輕量級的、可以快…

怎樣在 VS Code 中快速創建 Vue 單文件組件(SFC)的基礎模板結構?

問題 在Vue項目的開發中&#xff0c;我們經常遇到一個問題&#xff0c;創建新組件時要自己輸入基本的框架&#xff0c;比如&#xff1a; <template><div class"page-box"></div> </template><script> export default {name: ,data()…

高防IP在服務器中的作用都有哪些?

高防IP作為一種通過技術手段讓用戶網絡服務更加安全的一種IP地址&#xff0c;有著更高的防御能力&#xff0c;有著強大的流量清洗中心和防御系統&#xff0c;幫助企業實時監控網絡流量&#xff0c;將惡意的用戶請求識別并過濾掉&#xff0c;保護目標服務器不會受到網絡攻擊&…

實戰 X-AnyLabeling:構建高效自動標注系統的工程實踐

文章目錄 一、項目背景與目標二、系統架構與模塊劃分2.1 模塊組成說明2.2 架構圖 三、模型封裝與平臺對接3.1 模型封裝接口3.2 接入 X-AnyLabeling 平臺 四、可視化與預測驗證4.1 UI 預測標簽預覽 五、性能優化與工程經驗5.1 模型加速與推理優化5.2 經驗總結5.3 實際效果 本文將…

UC3842/UC3843反激教程教學開關電源 反激設計步驟,每一關鍵元器件計算

資料下載地址&#xff1a;UC3842/UC3843反激教程教學開關電源 反激設計步驟&#xff0c;每一關鍵元器件計算 1、原理圖 2、PCB圖 3、變壓器設計資料 4、開關電源設計資料 5、主要元器件說明書 6、系統整體資料 7、說明文檔 7.1、電源設計概述 電源規格&#xff1a;設計一款 2…

Docker 入門教程(二):Docker 的基本原理

文章目錄 &#x1f433; Docker 入門教程&#xff08;二&#xff09;&#xff1a;Docker 的基本原理1. Docker 架構總覽&#xff1a;三大核心角色2. 鏡像與容器的關系3. 容器啟動流程&#xff1a;docker run 背后發生了什么&#xff1f; &#x1f433; Docker 入門教程&#xf…

21.安卓逆向2-frida hook技術-HookOkHttp的攔截器

免責聲明&#xff1a;內容僅供學習參考&#xff0c;請合法利用知識&#xff0c;禁止進行違法犯罪活動&#xff01; 內容參考于&#xff1a;圖靈Python學院 工具下載&#xff1a; 鏈接&#xff1a;https://pan.baidu.com/s/1bb8NhJc9eTuLzQr39lF55Q?pwdzy89 提取碼&#xff1…

小程序入門:swpier 和 swpier-item 的基本使用

在前端開發中&#xff0c;創建交互式的用戶界面組件是至關重要的。今天&#xff0c;我們將深入探討 swpier 和 swpier-item 的基本使用方法&#xff0c;這兩個組件在構建輪播圖等滑動效果的場景中非常實用。 一、swpier 組件概述 swpier 組件是實現滑動效果的核心容器。它負責…

SQL學習筆記4

約束 1、約束 約束&#xff0c;是指作用在表中字段上的規則&#xff0c;用于限制字段輸入的數據&#xff0c;使得表格式統一&#xff0c;數據內容正確。同一個字段的約束可以有多個 約束包括&#xff1a; 非空約束&#xff0c;限制表中的值不為null:not null 唯一約束&…

力扣刷題(第七十天)

靈感來源 - 保持更新&#xff0c;努力學習 - python腳本學習 比特位計數 解題思路 對于任意整數 x&#xff0c;其 1 的個數等于 x // 2 的 1 的個數加上 x % 2。狀態轉移方程&#xff1a;dp[x] dp[x // 2] (x % 2)。 class Solution:def countBits(self, n: int) ->…

鴻蒙網絡編程系列56-倉頡版通過數據包結束標志解決TCP粘包問題

1. TCP粘包問題解決思路 在本系列的上一篇文章演示了TCP數據粘包的原因以及可能的解決方法&#xff0c;本文將通過其中的添加數據包結束標志的方法來解決這個問題。我們知道&#xff0c;數據粘包的原因是因為發送的時候沒有標明數據包的邊界&#xff0c;那么&#xff0c;我們人…

Redis網絡通信模塊深度解析:單線程Reactor到多線程IO的架構演進

一、核心架構&#xff1a;單線程Reactor模型 Redis網絡模塊采用經典Reactor模式&#xff0c;核心流程如下&#xff1a; void aeMain(aeEventLoop *eventLoop) {while (!eventLoop->stop) {// 前置鉤子&#xff08;集群心跳/數據持久化&#xff09;if (eventLoop->befor…

PILCO: 基于模型的高效策略搜索方法原理解析

PILCO: 基于模型的高效策略搜索方法原理解析 PILCO (Probabilistic Inference for Learning Control) 是一種基于模型的強化學習算法&#xff0c;由Marc Deisenroth和Carl Rasmussen于2011年提出。該算法在數據效率方面表現出色&#xff0c;能夠以極少的樣本數據實現有效學習。…