• pgsql 主从搭建


    在 PostgreSQL 中,主从复制(Master-Slave Replication)是一种常见的数据库高可用性和数据备份解决方案。它允许你创建一个主数据库服务器(Master),并在一个或多个从数据库服务器(Slave)上复制主数据库的数据。这有助于提高系统的可用性,因为在主服务器发生故障时,可以切换到从服务器来提供服务。以下是在 PostgreSQL 中设置主从复制的基本步骤:

    注意: 在开始之前,请确保你已经安装了 PostgreSQL,并且主从服务器都可以访问彼此。

    配置主服务器(Master):

    a. 打开主服务器的 PostgreSQL 配置文件,通常位于 /etc/postgresql//main/postgresql.conf。

    b. 确保以下参数设置正确:

    listen_addresses = '*' # 允许远程连接

    wal_level = replica     # 设置 WAL 日志级别为 replica

    max_wal_senders = 3     # 允许的 WAL 发送者数量,根据需要进行调整

    wal_keep_segments = 64  # 保留的 WAL 日志段数量,根据需要进行调整

    打开 pg_hba.conf 文件(通常位于相同目录),确保允许从服务器连接到主服务器。添加以下行:

    host replication md5

    其中 是用于复制的用户名, 是从服务器的IP地址。例如:

    host replication replicator 192.168.1.2/32 md5

    重新启动 PostgreSQL 以使更改生效。

    创建复制用户和权限:

    在主服务器上创建一个用于复制的用户,并授予适当的权限。登录到主服务器的 PostgreSQL,然后执行以下命令:

    CREATE USER replicator REPLICATION LOGIN CONNECTION LIMIT 3;

    备份和还原数据:

    在主服务器上执行备份操作,并将备份文件传输到从服务器。可以使用 pg_dump 命令创建备份:

    pg_dump -U -h -F c -b -f

    替换为数据库用户名, 替换为数据库主机名, 替换为备份文件的路径, 替换为要备份的数据库名称。

    在从服务器上执行还原操作:

    pg_restore -U -h -d

    配置从服务器(Slave):

    a. 打开从服务器的 PostgreSQL 配置文件,通常位于 /etc/postgresql//main/postgresql.conf。

    b. 设置以下参数以启用从服务器:

    listen_addresses = '*'  # 允许远程连接

    hot_standby = on        # 启用热备份模式

    c.创建一个 recovery.conf 文件,通常位于与数据目录相同的位置,包含以下内容:

    standby_mode = 'on'

    primary_conninfo = 'host= port= user= password='

    restore_command = 'cp /var/lib/postgresql//main/archive/%f %p'

    archive_cleanup_command = '/usr/lib/postgresql//bin/pg_archivecleanup /var/lib/postgresql//main/archive %r'

    trigger_file = '/tmp/postgresql.trigger'

    替换 , , , 以及相关的路径和版本信息。

    d. 重新启动从服务器的 PostgreSQL。

    启动主从复制:

    在从服务器上,启动 PostgreSQL 服务后,它会自动连接到主服务器并开始复制数据。你可以在主服务器上进行监视和管理复制进程。

    测试主从复制:

    在主服务器上进行一些数据更改,然后验证这些更改是否在从服务器上反映出来。你可以使用 pg_stat_replication 视图来监视复制状态。

    这只是一个基本的主从复制设置过程,实际环境中可能需要更复杂的配置,例如使用流复制(streaming replication)或逻辑复制(logical replication)来满足特定需求。此外,确保在生产环境中采取适当的安全措施,如加密和访问控制,以保护你的数据库。

  • 相关阅读:
    基于SqlSugar的开发框架循序渐进介绍(29)-- 快速构建系统参数管理界面-Vue3+ElementPlus
    神经网络算法有哪些模型,神经网络算法模型resnet
    前端使用 Konva 实现可视化设计器(16)- 旋转对齐、触摸板操作的优化
    涉及 GitHub、GitLab,研究人员发现 70 个 Web 缓存中毒漏洞;微软:许多攻击者仍对 Log4j 漏洞加以利用;VS 2022 新版发布 | 开源日报
    用案例的方式解释 React 18 新特性——并发渲染、自动批处理等
    typescript57-数组泛型接口
    RabbitMQ个人实践
    解决:Package ‘setuptools‘ requires a different Python: 3.7.16 not in ‘>=3.8‘
    面试:Glide和Fresco图片框架对比
    【Swift学习路线讲解】
  • 原文地址:https://blog.csdn.net/sun13212715744/article/details/132916933