在2台RHEL 8服务器上安装并配置PostgreSQL 14的主从架构

为了在两台RHEL 8服务器上安装并配置PostgreSQL 14的主从架构,你需要按照以下步骤操作。这将包括安装PostgreSQL、初始化数据库、调整配置、设置归档目录等。请确保你具有root或具有适当权限的用户访问权限来执行这些操作。

1. 安装PostgreSQL 14

在两台服务器上都执行以下步骤:

  1. 添加PostgreSQL Yum仓库

    bash 复制代码
    sudo dnf -y install https://download.postgresql.org/pub/repos/yum/reporpms/EL-8-x86_64/pgdg-redhat-repo-latest.noarch.rpm
  2. 安装PostgreSQL

    bash 复制代码
    sudo dnf -y install postgresql14-server

2. 初始化数据库

在两台服务器上都执行:

bash 复制代码
sudo /usr/pgsql-14/bin/postgresql-14-setup initdb

3. 更改数据目录

  1. 停止PostgreSQL服务

    bash 复制代码
    sudo systemctl stop postgresql-14
  2. 创建新的数据目录

    bash 复制代码
    sudo mkdir -p /data/postgres/pgdata
    sudo chown -R postgres:postgres /data/postgres
  3. 初始化新的数据目录

    bash 复制代码
    sudo -u postgres /usr/pgsql-14/bin/initdb -D /data/postgres/pgdata
  4. 更新PostgreSQL服务文件

    编辑 /usr/lib/systemd/system/postgresql-14.service,找到 Environment=PGDATA= 行并更改为:

    bash 复制代码
    Environment=PGDATA=/data/postgres/pgdata

    然后重新加载systemd配置:

    bash 复制代码
    sudo systemctl daemon-reload

4. 配置PostgreSQL

在主服务器上:

  1. 修改postgresql.conf

    编辑 /data/postgres/pgdata/postgresql.conf 文件,设置以下参数:

    bash 复制代码
    listen_addresses = '*'
    max_connections = 2000
    wal_level = replica
    archive_mode = on
    archive_command = 'cp %p /home/postgres/archives/%f'
  2. 修改pg_hba.conf

    编辑 /data/postgres/pgdata/pg_hba.conf,添加以下行以允许从服务器连接:

    bash 复制代码
    host replication all 192.168.197.129/32 md5

    同时允许远程连接:

    bash 复制代码
    host all all 0.0.0.0/0 md5

在从服务器上:

  1. 修改postgresql.conf

    编辑 /data/postgres/pgdata/postgresql.conf 文件,设置以下参数:

    bash 复制代码
    listen_addresses = '*'
    max_connections = 2000
    hot_standby = on
  2. 修改pg_hba.conf 与主服务器相同。

5. 设置归档目录

在两台服务器上都执行以下步骤:

bash 复制代码
sudo mkdir -p /home/postgres/archives
sudo chown -R postgres:postgres /home/postgres/archives

6. 设置主从复制

  1. 在主服务器上创建复制用户

    bash 复制代码
    sudo -u postgres psql -c "CREATE USER replicator REPLICATION LOGIN CONNECTION LIMIT 2 ENCRYPTED PASSWORD 'your_password';"
  2. 在从服务器上配置复制

    停止PostgreSQL服务:

    bash 复制代码
    sudo systemctl stop postgresql-14

    清理旧的数据目录:

    bash 复制代码
    sudo -u postgres rm -rf /data/postgres/pgdata/*

    使用pg_basebackup进行基础备份:

    bash 复制代码
    sudo -u postgres pg_basebackup -h 192.168.197.128 -D /data/postgres/pgdata -U replicator -v -P --wal-method=fetch

    创建recovery.conf文件:

    bash 复制代码
    sudo -u postgres bash -c "cat > /data/postgres/pgdata/recovery.conf <<EOF
    standby_mode = 'on'
    primary_conninfo = 'host=192.168.197.128 port=5432 user=

replicator password=your_password'

trigger_file = '/tmp/MasterNow'

EOF"

复制代码
### 7. 启动PostgreSQL服务

在两台服务器上:

```bash
sudo systemctl start postgresql-14
sudo systemctl enable postgresql-14

8. 验证设置

  1. 在主服务器上,检查是否有连接到从服务器的复制流程。
  2. 在从服务器上,检查是否能够查询数据并确认处于只读模式。

注意事项

  • 确保防火墙和安全组设置允许这两台服务器在相应端口(默认是5432)上相互通信。
  • 保持密码的安全性和复杂性。
  • 以上步骤可能需要根据实际环境进行适当调整。
相关推荐
狼爷12 分钟前
短视频播放量(Views)计数系统实现方案:高并发、不丢数的工业级实践
后端·架构
倔强的石头_41 分钟前
kingbase备份与恢复实战(六)—— 备份自动化与保留策略:Windows任务计划+日志追溯
数据库
轻刀快马2 小时前
别被 ORM 框架宠坏了:从一场“订单消失”悬案,看懂 MySQL 为什么要强推 InnoDB
数据库·mysql
后端漫漫3 小时前
Redis 客户端工具体系
数据库·redis·缓存
PaperData4 小时前
1988-2025年《中国人口和就业统计年鉴》全年份excel+PDF
数据库·人工智能·数据分析·经管
Dabei4 小时前
Android 副屏(Virtual Display)创建与悬浮窗画中画显示实战
前端·架构
程序员老邢4 小时前
【产品底稿 12】工程架构最终定型:完整模块拆分、分包规范、层级依赖与开发规约全清单
微服务·架构·springboot·多模块·技术债务
星河耀银海5 小时前
C语言与数据库交互:SQLite实战与数据持久化
c语言·数据库·sqlite·交互
过期动态5 小时前
MySQL中的约束
android·java·数据库·spring boot·mysql
程序员陆通5 小时前
月烧 400 刀到不到 20 刀:我是怎么把 OpenClaw 的 Token 账单砍掉 95% 的
java·前端·数据库