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

2023-12-06 00:20

本文主要是介绍在2台RHEL 8服务器上安装并配置PostgreSQL 14的主从架构,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

1. 安装PostgreSQL 14

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

  1. 添加PostgreSQL Yum仓库

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

    sudo dnf -y install postgresql14-server
    

2. 初始化数据库

在两台服务器上都执行:

sudo /usr/pgsql-14/bin/postgresql-14-setup initdb

3. 更改数据目录

  1. 停止PostgreSQL服务

    sudo systemctl stop postgresql-14
    
  2. 创建新的数据目录

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

    sudo -u postgres /usr/pgsql-14/bin/initdb -D /data/postgres/pgdata
    
  4. 更新PostgreSQL服务文件
    编辑 /usr/lib/systemd/system/postgresql-14.service,找到 Environment=PGDATA= 行并更改为:

    Environment=PGDATA=/data/postgres/pgdata
    

    然后重新加载systemd配置:

    sudo systemctl daemon-reload
    

4. 配置PostgreSQL

在主服务器上:

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

    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,添加以下行以允许从服务器连接:

    host replication all 192.168.197.129/32 md5
    

    同时允许远程连接:

    host all all 0.0.0.0/0 md5
    

在从服务器上:

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

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

5. 设置归档目录

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

sudo mkdir -p /home/postgres/archives
sudo chown -R postgres:postgres /home/postgres/archives

6. 设置主从复制

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

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

    sudo systemctl stop postgresql-14
    

    清理旧的数据目录:

    sudo -u postgres rm -rf /data/postgres/pgdata/*
    

    使用pg_basebackup进行基础备份:

    sudo -u postgres pg_basebackup -h 192.168.197.128 -D /data/postgres/pgdata -U replicator -v -P --wal-method=fetch
    

    创建recovery.conf文件:

    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)上相互通信。
  • 保持密码的安全性和复杂性。
  • 以上步骤可能需要根据实际环境进行适当调整。

这篇关于在2台RHEL 8服务器上安装并配置PostgreSQL 14的主从架构的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/459705

相关文章

PostgreSQL的扩展dict_int应用案例解析

《PostgreSQL的扩展dict_int应用案例解析》dict_int扩展为PostgreSQL提供了专业的整数文本处理能力,特别适合需要精确处理数字内容的搜索场景,本文给大家介绍PostgreS... 目录PostgreSQL的扩展dict_int一、扩展概述二、核心功能三、安装与启用四、字典配置方法

SQL Server配置管理器无法打开的四种解决方法

《SQLServer配置管理器无法打开的四种解决方法》本文总结了SQLServer配置管理器无法打开的四种解决方法,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录方法一:桌面图标进入方法二:运行窗口进入检查版本号对照表php方法三:查找文件路径方法四:检查 S

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

mysql中的服务器架构详解

《mysql中的服务器架构详解》:本文主要介绍mysql中的服务器架构,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、mysql服务器架构解释3、总结1、背景简单理解一下mysqphpl的服务器架构。2、mysjsql服务器架构解释mysql的架

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

postgresql数据库基本操作及命令详解

《postgresql数据库基本操作及命令详解》本文介绍了PostgreSQL数据库的基础操作,包括连接、创建、查看数据库,表的增删改查、索引管理、备份恢复及退出命令,适用于数据库管理和开发实践,感兴... 目录1. 连接 PostgreSQL 数据库2. 创建数据库3. 查看当前数据库4. 查看所有数据库

Linux如何快速检查服务器的硬件配置和性能指标

《Linux如何快速检查服务器的硬件配置和性能指标》在运维和开发工作中,我们经常需要快速检查Linux服务器的硬件配置和性能指标,本文将以CentOS为例,介绍如何通过命令行快速获取这些关键信息,... 目录引言一、查询CPU核心数编程(几C?)1. 使用 nproc(最简单)2. 使用 lscpu(详细信

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手

PostgreSQL数据库密码被遗忘时的操作步骤

《PostgreSQL数据库密码被遗忘时的操作步骤》密码遗忘是常见的用户问题,因此提供一种安全的遗忘密码找回机制是十分必要的,:本文主要介绍PostgreSQL数据库密码被遗忘时的操作步骤的相关资... 目录前言一、背景知识二、Windows环境下的解决步骤1. 找到PostgreSQL安装目录2. 修改p

Nginx 重写与重定向配置方法

《Nginx重写与重定向配置方法》Nginx重写与重定向区别:重写修改路径(客户端无感知),重定向跳转新URL(客户端感知),try_files检查文件/目录存在性,return301直接返回永久重... 目录一.try_files指令二.return指令三.rewrite指令区分重写与重定向重写: 请求