AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1011271
Accepted
ufk
ufk
Asked: 2020-04-08 03:57:31 +0800 CST2020-04-08 03:57:31 +0800 CST 2020-04-08 03:57:31 +0800 CST

将具有 pglogical 复制的第 3 台服务器添加到具有流同步复制的 2 台服务器集群中,并使用赞助人进行故障保护

  • 772

我有 3 台带有 Ubuntu 19.10、PostgreSQL 12.2 和 Patroni 1.6.4 的服务器,我希望进行以下设置:

我想拥有两台具有同步复制的服务器,并且我想添加第三台具有 pglogical 复制的服务器,只是为了接受对特定表的插入。没有 DELETE、TRUNCATE 或其他任何东西。

我每天记录大量购买,大约 3 亿。我希望服务器已经拥有过去 30 天的购买历史记录,并且具有非常大存储空间的第三台服务器将保存所有购买历史记录。

到目前为止,我有一个带有 etcd 的赞助人集群,用于 2 台服务器,配置如下:

这是针对第一台和第二台服务器我有以下配置,当然每个配置中服务器的名称都不同:

scope: patroni_cluster_1
name: server_X

restapi:
  listen: 0.0.0.0:8008
  connect_address: X.X.X.X:8008

etcd:
  hosts: X.X.X.X:2379
  protocol: http

bootstrap:
  dcs:
    ttl: 30
    loop_wait: 10
    retry_timeout : 10
    maximum_lag_on_failover: 1048576
    postgresql:
      use_pg_rewind: true
      use_slots: true
      parameters:
        wal_keep_segments: 100

  initdb:
  - encoding: UTF8
  - data-checksums

  pg_hba:
  - host replication replicator 0.0.0.0/0 md5
  - host all all 0.0.0.0/0 md5

postgresql:
  listen: 0.0.0.0:5432
  connect_address: X.X.X.X:5432
  synchronous_mode: true
  synchronous_mode_strict: false
  data_dir: /var/lib/postgresql/patroni_cluster_1/server_X/data
  bin_dir: /usr/lib/postgresql/12/bin
  authentication:
    replication:
      username: replicator
      password: XXXX
    superuser:
      username: postgres
      password: XXXX
  parameters:
    shared_preload_libraries: pglogical

我将 pglogical 添加为共享库,因为我想知道是否可以使用 Patroni 完全设置第三台服务器。

我阅读了有关如何使用https://blog.dbi-services.com/postgresql-logical-replication-with-pglogical/设置 pglogical 的信息,我想知道我是否可以使用 pglogical 完全配置第三台服务器以仅用于插入。

我是 Patroni 的新手,我很迷茫,所以关于这个问题的任何信息都将不胜感激。

postgresql failovercluster database-replication patroni
  • 1 1 个回答
  • 280 Views

1 个回答

  • Voted
  1. Best Answer
    ufk
    2020-04-23T00:24:15+08:002020-04-23T00:24:15+08:00

    我发现这样做的唯一方法是创建一个执行配置 pglogical 的 psql 命令的 bash 脚本。

    所以我在 yaml 中添加了一个 post_bootstrap 属性,如此处所述:https ://github.com/zalando/patroni/blob/master/docs/SETTINGS.rst

    bash 脚本接收数据库 dsn 作为参数,我用它来连接它并配置我喜欢的东西。

    据我所知,没有办法直接从赞助人配置 pglogical。

    • 0

相关问题

  • OS X 上的 Postgresql 安装问题

  • 修复 mysql 命令行程序中的 Control-C?

  • 有哪些好的 PostgreSQL 管理工具?[关闭]

  • Access 通过 ODBC 连接到远程 Postgresql 数据库是否可用?

  • 哪个数据库服务器扩展性更好:PostgreSQL 还是 MySQL?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve