Re: speed up a logical replica setup
От | Euler Taveira |
---|---|
Тема | Re: speed up a logical replica setup |
Дата | |
Msg-id | a24899ab-858d-4497-a447-c02852fe21e9@app.fastmail.com обсуждение исходный текст |
Ответ на | Re: speed up a logical replica setup (Michael Paquier <michael@paquier.xyz>) |
Ответы |
Re: speed up a logical replica setup
|
Список | pgsql-hackers |
On Tue, Nov 7, 2023, at 8:12 PM, Michael Paquier wrote:
On Tue, Nov 07, 2023 at 10:00:39PM +0100, Peter Eisentraut wrote:> Speaking of which, would it make sense to put this tool (whatever the name)> into the pg_basebackup directory? It's sort of related, and it also shares> some code.
I used the CreateReplicationSlot() from streamutil.h but decided to use the
CREATE_REPLICATION_SLOT command directly because it needs the LSN as output. As
you noticed at that time I wouldn't like a dependency in the pg_basebackup
header files; if we move this binary to base backup directory, it seems natural
to refactor the referred function and use it.
I've read the patch, and the additions to streamutil.h andstreamutil.c make it kind of natural to have it sit in pg_basebackup/.There's pg_recvlogical already there. I am wondering about twothings, though:- Should the subdirectory pg_basebackup be renamed into something moregeneric at this point? All these things are frontend tools that dealin some way with the replication protocol to do their work. Saya replication_tools?
It is a good fit for this tool since it is another replication tool. I also
agree with the directory renaming; it seems confusing that the directory has
the same name as one binary but also contains other related binaries in it.
- And if it would be better to refactor some of the code generic toall these streaming tools to fe_utils. What makes streamutil.h a bitless pluggable are all its extern variables to control the connection,but perhaps that can be an advantage, as well, in some cases.
I like it. There are common functions such as GetConnection(),
CreateReplicationSlot(), DropReplicationSlot() and RunIdentifySystem() that is
used by all of these replication tools. We can move the extern variables into
parameters to have a pluggable streamutil.h.
В списке pgsql-hackers по дате отправления: