PostgreSQL:基本 pglogical 配置的困难

Ale*_*eev 5 postgresql replication

我发现官方 pglogical 文档非常混乱。不清楚的东西太多了。也许之前配置过 pglogical 的人可以解释如何设置基本的逻辑复制。

有两个 PostgreSQL 9.5 实例 - 10.128.0.8 (archlinux1) 和 10.128.0.9 (archlinux2)。扩展已安装,CREATE EXTENSION 成功。每个实例上都有一张表:

create table test (k text primary key, v text);
Run Code Online (Sandbox Code Playgroud)

我想将它从 archlinux1 复制到 archlinux2。

根据文档,我应该创建一个提供者节点:

SELECT pglogical.create_node(
    node_name := 'provider1',
    dsn := 'host=providerhost port=5432 dbname=db'
);
Run Code Online (Sandbox Code Playgroud)

它应该在master上执行吗?providerhost 应该是 127.0.0.1 还是 10.128.0.8?仅允许从本地主机(根据文档)进行当前复制 - 是否应该更改?我最好的猜测 - 它应该像这样在 master 上执行:

SELECT pglogical.create_node(
    node_name := 'provider1',
    dsn := 'host=127.0.0.1 port=5432 dbname=eax'
);
 create_node 
-------------
  2976894835
(1 row)
Run Code Online (Sandbox Code Playgroud)

下一个:

SELECT pglogical.replication_set_add_all_tables('default', ARRAY['public']);
Run Code Online (Sandbox Code Playgroud)

它应该在 master、replica 上还是在两者上执行?我最好的猜测 - 仅在主人身上:

SELECT pglogical.replication_set_add_all_tables('default', ARRAY['public']);
 replication_set_add_all_tables 
--------------------------------
 t
(1 row)
Run Code Online (Sandbox Code Playgroud)

下一个:

SELECT pglogical.create_node(
    node_name := 'subscriber1',
    dsn := 'host=thishost port=5432 dbname=db'
);
Run Code Online (Sandbox Code Playgroud)

显然它应该在副本上执行:

SELECT pglogical.create_node(
    node_name := 'subscriber1',
    dsn := 'host=127.0.0.1 port=5432 dbname=eax'
);
 create_node 
-------------
   330520249
(1 row)
Run Code Online (Sandbox Code Playgroud)

下一步:

SELECT pglogical.create_subscription(
    subscription_name := 'subscription1',
    provider_dsn := 'host=providerhost port=5432 dbname=db'
);
Run Code Online (Sandbox Code Playgroud)

最好的猜测 - 在副本上执行它,如下所示:

SELECT pglogical.create_subscription(
    subscription_name := 'subscription1',
    provider_dsn := 'host=10.128.0.8 port=5432 dbname=eax'
);
ERROR:  could not connect to the postgresql server: could not connect to server: Connection refused
    Is the server running on host "10.128.0.8" and accepting
    TCP/IP connections on port 5432?

DETAIL:  dsn was:  host=10.128.0.8 port=5432 dbname=eax
Run Code Online (Sandbox Code Playgroud)

哎呀。OK,在master上正确修改pg_hba.conf和postgresql.conf:

# pg_hba.conf
host    all    all    10.128.0.0/16    md5
# postgresql.conf
listen_addresses = 'localhost,10.128.0.8
Run Code Online (Sandbox Code Playgroud)

仍然没有运气:

# SELECT pglogical.create_subscription(
    subscription_name := 'subscription1',
    provider_dsn := 'host=10.128.0.8 port=5432 dbname=eax user=eax password=qwerty'
);
ERROR:  could not connect to the postgresql server in replication mode: FATAL:  no pg_hba.conf entry for replication connection from host "10.128.0.9", user "eax", SSL off

DETAIL:  dsn was:  host=10.128.0.8 port=5432 dbname=eax user=eax password=qwerty
Run Code Online (Sandbox Code Playgroud)

添加到主服务器上的 pg_hba.conf:

host    replication     eax        10.128.0.0/16            md5
Run Code Online (Sandbox Code Playgroud)

在副本上(成功!):

SELECT pglogical.create_subscription(
    subscription_name := 'subscription1',
    provider_dsn := 'host=10.128.0.8 port=5432 dbname=eax user=eax password=qwerty'
);
 create_subscription 
---------------------
          1763399739
(1 row)
Run Code Online (Sandbox Code Playgroud)

现在在主人:

eax=# insert into test values ('aaa', 'bbb');
INSERT 0 1
eax=# select * from test;
  k  |  v  
-----+-----
 aaa | bbb
(1 row)
Run Code Online (Sandbox Code Playgroud)

在副本上:

eax=# select * from test;
 k | v 
---+---
(0 rows)
Run Code Online (Sandbox Code Playgroud)

自然没有用。日志中没有任何帮助。有什么建议吗?

UPD:我还在pglogical 问题跟踪器中创建了一个相应的问题

Ale*_*eev 1

Depesz 发表了一篇关于 pglogic 配置的优秀博客文章https://www.depesz.com/2016/11/08/major-version-upgrading-with-minimal-downtime/