On Thu, Apr 4, 2019 at 6:11 AM Michael Paquier <mich...@paquier.xyz> wrote:

> On Wed, Apr 03, 2019 at 11:28:50AM +0200, Magnus Hagander wrote:
> > As pointed out by Michael Banck as a comment on my blogpost, the
> pg_rewind
> > documentation says it requires superuser permissions on the remote
> server.
> >
> > Is that really so, though? I haven't tested it, but from a quick look at
> > the code it looks like it needs pg_ls_dir(), pg_stat_file() and
> > pg_read_binary_file(), all, of which are independently grantable.
> >
> > Or am I missing something?
>
> Somebody I heard of has mentioned that stuff on his blog some time
> ago:
> https://paquier.xyz/postgresql-2/postgres-11-superuser-rewind/


Hah. I usually read your blog, but I had forgotten about that one :)


And what you need to do is just that:
> CREATE USER rewind_user LOGIN;
> GRANT EXECUTE ON function pg_catalog.pg_ls_dir(text, boolean, boolean)
> TO rewind_user;
> GRANT EXECUTE ON function pg_catalog.pg_stat_file(text, boolean) TO
> rewind_user;
> GRANT EXECUTE ON function pg_catalog.pg_read_binary_file(text) TO
> rewind_user;
> GRANT EXECUTE ON function pg_catalog.pg_read_binary_file(text, bigint,
> bigint, boolean) TO rewind_user;
>
> I think that we should document that and back-patch, as now the docs
> only say that a superuser should be used, but that is wrong.
>
> At the same time, let's also document that we need to use a checkpoint
> on the promoted standby so as the control file gets a refresh and
> pg_rewind is able to work properly.  I promised that some time ago and
> got reminded of that issue after seeing this thread...
>
> What do you think about the attached?
>

Looks good. Maybe we should list the "role having sufficient permissions"
before superuser, "just because", but not something I feel strongly about.

The part about CHECKPOINT also looks pretty good, but that's entirely
unrelated, right? :)

-- 
 Magnus Hagander
 Me: https://www.hagander.net/ <http://www.hagander.net/>
 Work: https://www.redpill-linpro.com/ <http://www.redpill-linpro.com/>

Reply via email to