首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何使pg_ctl重新加载工作?询问postgres用户的密码,但不接受

如何使pg_ctl重新加载工作?询问postgres用户的密码,但不接受
EN

Stack Overflow用户
提问于 2019-03-14 00:15:43
回答 1查看 1.9K关注 0票数 0

我已经按照站点上的Postgres说明使用PostgreSQL 11在CentOS 7 VM上安装了yum。安装后,我做了

代码语言:javascript
运行
复制
/usr/pgsql-11/bin/postgresql-11-setup initdb
systemctl enable postgresql-11
systemctl start postgresql-11

然后去配置postgresql.conf文件。

现在,我需要重新加载数据库,以便这些更改生效。

我试过使用sudo pg_ctl reload帐户,它会提示我输入postgres的密码。据我所知,这个帐户是通过初始化创建的,没有密码,但是只按enter键是不被接受的。

然后,我尝试更改密码,从根执行su -u postgres psql postgres,在shell中执行ALTER USER postgres PASSWORD 'myPasswordHere';,后者返回ALTER ROLE作为确认。重试上述重新加载,新密码仍未被接受。

然后,我尝试将systemctl restart postgres-11作为根,但这似乎完全破坏了数据库,不允许我做任何涉及数据库的进程,甚至访问Postgres。

我不得不删除数据目录并重新运行上面的initdb命令来重新启动所有内容(而且pg_ctl命令仍然不接受我的密码)。

如何正确地重新加载数据库,从而实现对postgresql.conf的更改?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-03-14 09:03:59

你在很多方面都很困惑。

  1. 数据库用户不同于操作系统用户。如果在数据库中更改postgres的密码,操作系统用户仍然没有密码。 不过,我看不出这是如何破坏数据库的。可能您的pg_hba.conf文件配置错误。
  2. 您将pg_ctl reload作为操作系统用户postgres运行,而不是以root身份运行,因为postgres拥有PostgreSQL进程,因此不需要sudo,因此不需要操作系统密码。

您可能应该阅读有关客户端认证用户管理客户端认证文档。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55153046

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档