文章目录概况安装PostgreSQL设置主节点设置从节点验证故障处理,主从节点切换从节点扩容概况CentOS Linux release 7.7.1908PostgreSQL13三台服务器,一主两从,实时复制。主节点读写,从节点只读,读写分离不借助插件或第三方中间件,仅使用PostgreSQL自带的流复制功能Replication主节点可建库建表、可读写,两个从节点为只读,程序使用时可以将查询和统计相关服务读取从节点,通过读写分离减少数据库读写压力设置同步复制,为热备份,数据实时同步,对于大多数业务来说,可以认为三个库数据完全相同,当一个库故障时,其他库仍然可提供服务,增加服务可用性当主节点故障时,数据无法更新,只能手动将从节点升格为主节点,需要修改服务的数据库连接配置等,服务短暂不可用(也可提前准备好监控和切换脚本,服务不可用时尽早发现和切换)。需要根据自己业务特点,是否能接受此种情况,来决定是否使用此方式。单点故障,自动切换的集群,可以考虑使用PGPool-II 等第三方中间件搭建,后面研究好我会出一篇文档安装PostgreSQL命令如下,具体可参考我之前的博客《PostgreSQL简介和安装部署》# 安装 repository 源:sudo yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm# 安装 PostgreSQL13:sudo yum install -y postgresql13-server# 初始化数据库,并设置启动命令和开机启动:sudo /usr/pgsql-13/bin/postgresql-13-setup initdbsudo systemctl enable postgresql-13sudo systemctl start postgresql-13# 另外,查看状态,关闭命名和重启命令sudo systemctl status postgresql-13sudo systemctl stop postgresql-13sudo systemctl restart postgresql-13123456789101112131415三个节点安装完成后,就可以开始使用了可以创建用户、赋予权限、修改密码,可以建库建表早一些功能测试等默认安装创建的数据库,没有主从之分,都是主节点,可以使用这条语句验证下是否为从节点,查询结果为"f"表示false,当前数据库节点为主库节点sudo -u postgres /usr/pgsql-13/bin/psql -c "select pg_is_in_recovery()"1下面开始搭建集群,关闭三个PostgreSQL服务,开始改配置文件设置主节点主从节点可以自己规划好,准备好不同机器就行,也可以使用最小集群一主一从主要是修改2个配置文件,都在data目录下,一个是数据库基础配置,一个是访问权限控制默认初始化的数据库,data目录在/var/lib/pgsql/13/data修改文件夹里面的pg_hba.conf,设置 Replication 访问策略,允许流复制# replication privilege.# 追加一条“允许postgres用户,通过全部网络地址使用 Replication ”的策略host replication postgres 0.0.0.0/0 trust123继续修改数据库配置文件postgres.conf,进行一些参数设置,允许流复制# -----------------------------# PostgreSQL configuration file# -----------------------------# - Connection Settings -listen_addresses = '*' # what IP address(es) to listen on;#port = 5432 # (change requires restart)max_connections = 200 # (change requires restart)# - Authentication -#authentication_timeout = 1min # 1s-600spassword_encryption = scram-sha-256 # md5 or scram-sha-256#------------------------------------------------------------------------------# RESOURCE USAGE (except WAL)#------------------------------------------------------------------------------# - Memory -shared_buffers = 1GB # min 128kB 官方推荐内存设置带大小为系统内存的1/4temp_buffers = 64MB # min 800kBwork_mem = 64MB # min 64kBmax_stack_depth = 4MB # min 100kBdynamic_shared_memory_type = posix # the default is the first option#------------------------------------------------------------------------------# WRITE-AHEAD LOG#------------------------------------------------------------------------------wal_level = replica # minimal, replica, or logicalfsync = on # flush data to disk for crash safetysynchronous_commit = on # synchronization level;wal_log_hints = on # also do full page writes of non-critical updates# - Checkpoints -checkpoint_timeout = 10min # range 30s-1dmax_wal_size = 1GBmin_wal_size = 80MB# - Archiving -archive_mode = on # enables archiving; off, on, or always# (change requires restart)archive_command = 'cp %p /data/postgresql/archive/%f' # command to use to archive a logfile segment#-----------------------------------------------------------------------------# REPLICATION#------------------------------------------------------------------------------max_wal_senders = 10 # max number of walsender processes 设置了可以最多有几个流复制的链接# (change requires restart)wal_keep_size = 1024 # in megabytes; 0 disablesmax_slot_wal_keep_size = 10 # in megabytes; -1 disableswal_sender_timeout = 120s # in milliseconds; 0 disables# - Standby Servers -hot_standby = on # "off" disallows queries during recovery#------------------------------------------------------------------------------# REPORTING AND LOGGING#------------------------------------------------------------------------------# - Where to Log -log_destination = 'stderr' # Valid values are combinations oflogging_collector = on # Enable capturing of stderr and csvloglog_directory = 'log' # directory where log files are written,# can be absolute or relative to PGDATAlog_filename = 'postgresql-%a.log' # log file name pattern,log_truncate_on_rotation = on # If on, an existing log file with thelog_rotation_age = 1d # Automatic rotation of logfiles willlog_rotation_size = 50MB # Automatic rotation of logfiles willlog_min_duration_statement = 2000 # 配置数据库慢查询时间,如果超过配置的时间,就会将查询的SQL语句记录到日志# - What to Log -log_connections = onlog_disconnections = onlog_line_prefix = '%m [%p] ' # special values:log_timezone = 'Asia/Shanghai'datestyle = 'iso, mdy'#intervalstyle = 'postgres'timezone = 'Asia/Shanghai'# These settings are initialized by initdb, but they can be changed.lc_messages = 'en_US.UTF-8' # locale for system error message# stringslc_monetary = 'en_US.UTF-8' # locale for monetary formattinglc_numeric = 'en_US.UTF-8' # locale for number formattinglc_time = 'en_US.UTF-8' # locale for time formatting# default configuration for text searchdefault_text_search_config = 'pg_catalog.english'shared_preload_libraries = '' # citus (change requires restart)1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586启动服务,使配置生效,主节点设置完毕sudo systemctl start postgresql-13# 或sudo systemctl restart postgresql-13123设置从节点主从要保持一致,主要是 data 保持一致,我们可以直接将主节点data同步到从节点如果从节点没有关闭,可以先关闭 sudo systemctl stop postgresql-13去默认的data位置,删除所有文件
时间: 2025-05-16 07:54:34 浏览: 120
### 安装与配置 PostgreSQL 13 在 CentOS 7.7.1908 下的一主两从高可用集群
#### 1. 环境准备
在三台服务器上分别安装 CentOS 7.7.1908,确保每台机器的硬件资源满足需求。以下是各节点的基础信息:
- **主节点 (Master)**
IP 地址:`192.168.123.10`
CPU:4 核
内存:4GB
- **从节点 1 (Slave 1)**
IP 地址:`192.168.123.20`
CPU:4 核
内存:4GB
- **从节点 2 (Slave 2)**
IP 地址:`192.168.123.30`
CPU:4 核
内存:4GB
确保所有节点之间的网络连通性正常。
---
#### 2. Yum 源配置
编辑 `/etc/yum.repos.d/pgdg.repo` 文件,添加以下内容以支持 PostgreSQL 的官方仓库[^1]:
```ini
[pgdg13]
name=PostgreSQL 13 for RHEL/CentOS $releasever - $basearch
baseurl=https://download.postgresql.org/pub/repos/yum/13/redhat/rhel-$releasever-$basearch
enabled=1
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-PGDG
```
运行命令更新 yum 缓存:
```bash
yum makecache fast
```
---
#### 3. 安装 PostgreSQL 和 repmgr 插件
在所有节点上执行以下命令来安装 PostgreSQL 及其管理工具 `repmgr`:
```bash
yum install -y postgresql13-server postgresql13-contrib repmgr15
```
初始化主节点上的数据库实例:
```bash
/usr/pgsql-13/bin/initdb -D /var/lib/pgsql/13/data/
```
启动并设置开机自启服务:
```bash
systemctl enable --now postgresql-13
```
---
#### 4. 主节点配置
修改主节点的配置文件 `/var/lib/pgsql/13/data/postgresql.conf`,启用流复制功能[^2]:
```conf
listen_addresses = '*'
wal_level = replica
max_wal_senders = 10
hot_standby = on
archive_mode = on
archive_command = 'cd .'
```
允许从节点连接,在 `/var/lib/pgsql/13/data/pg_hba.conf` 中添加如下条目:
```conf
host replication all 192.168.123.20/32 md5
host replication all 192.168.123.30/32 md5
```
重启主节点的服务使更改生效:
```bash
systemctl restart postgresql-13
```
---
#### 5. 备份主节点数据至从节点
在主节点上创建用于复制的用户账户:
```sql
CREATE USER repl REPLICATION LOGIN CONNECTION LIMIT 1 ENCRYPTED PASSWORD 'your_password';
```
使用 `pg_basebackup` 工具将主节点的数据备份到两个从节点上[^5]。例如,在 Slave 1 执行以下命令:
```bash
su - postgres
pg_basebackup -h 192.168.123.10 -U repl -D /var/lib/pgsql/13/data -Fp -Xs -P -R
```
完成后调整目录权限:
```bash
chown -R postgres:postgres /var/lib/pgsql/13/data
chmod 700 /var/lib/pgsql/13/data
```
重复上述操作完成第二个从节点的数据同步。
---
#### 6. 配置从节点
在每个从节点的 `/var/lib/pgsql/13/data/recovery.conf` 文件中指定主节点的信息(对于 PostgreSQL 13,此文件已被移除,改为直接编辑 `postgresql.auto.conf` 或通过其他方式定义恢复参数)。可以手动创建一个触发器文件实现自动切换为主节点的功能。
启动从节点服务前确认配置无误:
```bash
systemctl start postgresql-13
```
验证从节点是否成功进入只读模式:
```sql
SELECT pg_is_in_recovery();
-- 如果返回 true,则表示当前处于 standby 模式。
```
---
#### 7. 实现读写分离
利用负载均衡技术或者应用程序层面逻辑区分查询请求发送目标。推荐采用 HAProxy 或 PgBouncer 来分发流量给不同的后端实例[^4]。
---
#### 8. 故障切换方案
借助 `repmgr` 提供的自动化脚本简化故障检测与接管流程。具体步骤包括但不限于监控心跳信号丢失情况下的重新选举过程以及通知管理员介入干预必要时刻的手动干预措施[^3]。
---
阅读全文
相关推荐


















