无法在 CentOS 7 上启动 postgresql 服务

声明:本页面是StackOverFlow热门问题的中英对照翻译,遵循CC BY-SA 4.0协议,如果您需要使用它,必须同样遵循CC BY-SA许可,注明原文地址和作者信息,同时你必须将它归于原作者(不是我):StackOverFlow 原文地址: http://stackoverflow.com/questions/35492893/
Warning: these are provided under cc-by-sa 4.0 license. You are free to use/share it, But you must attribute it to the original authors (not me): StackOverFlow

提示:将鼠标放在中文语句上可以显示对应的英文。显示中英文
时间:2020-09-09 06:10:44  来源:igfitidea点击:

Unable to start postgresql service on CentOS 7

postgresqlcentoscentos7rhelrhel7

提问by Muthu Palanisamy

Unable to start postgresql-9.5 on CentOS 7.

无法在 CentOS 7 上启动 postgresql-9.5。

I followed this page - https://wiki.postgresql.org/wiki/YUM_Installation- for installing the database server on CentOS.

我按照这个页面 - https://wiki.postgresql.org/wiki/YUM_Installation- 在 CentOS 上安装数据库服务器。

I tried the same after setting setenforce 0, and that did not help either.

设置后我尝试了同样的方法setenforce 0,但这也没有帮助。

I am doing all operations as root.

我正在做所有操作root

systemctl start postgresql-9.5.service
Job for postgresql-9.5.service failed because the control process exited with error 
code. See "systemctl status postgresql-9.5.service" and "journalctl -xe" for details.

And here is what I get for status -

这是我获得的地位 -

Redirecting to /bin/systemctl status  postgresql-9.5.service
● postgresql-9.5.service - PostgreSQL 9.5 database server
   Loaded: loaded (/usr/lib/systemd/system/postgresql-9.5.service; enabled; vendor preset: disabled)
   Active: failed (Result: exit-code) since Thu 2016-02-18 15:20:30 EST; 2min 28s ago
  Process: 15041 ExecStartPre=/usr/pgsql-9.5/bin/postgresql95-check-db-dir ${PGDATA} (code=exited, status=1/FAILURE)

Feb 18 15:20:30 myserver systemd[1]: Starting PostgreSQL 9.5 database server...
Feb 18 15:20:30 myserver systemd[1]: postgresql-9.5.service: control process exited, code=exited status=1
Feb 18 15:20:30 myserver systemd[1]: Failed to start PostgreSQL 9.5 database server.
Feb 18 15:20:30 myserver systemd[1]: Unit postgresql-9.5.service entered failed state.
Feb 18 15:20:30 myserver systemd[1]: postgresql-9.5.service failed.

And the contents of the different conf files are as follows -

并且不同的conf文件的内容如下——

[root@myserver /]# cat /etc/ld.so.conf.d/postgresql-pgdg-libs.conf
/usr/pgsql-9.5/lib/

[root@myserver /]# cat /usr/lib/tmpfiles.d/postgresql-9.5.conf
d /var/run/postgresql 0755 postgres postgres -

[root@myserver /]# cat /usr/pgsql-9.5/share/postgresql-9.5-libs.conf
/usr/pgsql-9.5/lib/

[root@myserver /]# cat /etc/alternatives/pgsql-ld-conf
/usr/pgsql-9.5/lib/

[root@myserver /]# cat /var/lib/alternatives/pgsql-ld-conf
auto
/etc/ld.so.conf.d/postgresql-pgdg-libs.conf

/usr/pgsql-9.5/share/postgresql-9.5-libs.conf
950

Googled for the error that I am seeing. A number of folks have seen the same error, and the underlying cause is different in each case. Reading through those posts, it is not clear that I am seeing any of the already reported causes.

谷歌搜索我看到的错误。许多人都看到了同样的错误,并且每种情况的根本原因都不同。通读这些帖子,我不清楚是否看到了任何已报告的原因。

回答by Dmitry Savinkov

Make sure you have installed all packages correctly and updated yum repository sections [base]and [updates]before installation as it mentioned in the guide. We have CentOS 7 with PostgreSQL 9.5 and it works perfectly fine with following steps:

确保您已正确安装所有软件包并更新 yum 存储库部分,[base][updates]在安装之前按照指南中的说明进行安装。我们有带有 PostgreSQL 9.5 的 CentOS 7,它可以通过以下步骤完美运行:

vi /etc/yum.repos.d/CentOS-Base.repo
yum localinstall http://yum.postgresql.org/9.5/redhat/rhel-7-x86_64/pgdg-centos95-9.5-2.noarch.rpm
yum list postgres*
yum install -y postgresql95-server.x86_64 postgresql95-contrib.x86_64 postgresql95-libs.x86_64 
/usr/pgsql-9.5/bin/postgresql95-setup initdb
systemctl enable postgresql-9.5.service
systemctl start postgresql-9.5.service 

and finally, systemctl status postgresql-9.5.serviceshould show you something like this:

最后,systemctl status postgresql-9.5.service应该向您展示如下内容:

postgresql-9.5.service - PostgreSQL 9.5 database server
   Loaded: loaded (/usr/lib/systemd/system/postgresql-9.5.service; enabled)
   Active: active (running) since Fri 2016-02-19 00:01:13 UTC; 6min ago
  Process: 10809 ExecStart=/usr/pgsql-9.5/bin/pg_ctl start -D ${PGDATA} -s -w -t 300 (code=exited, status=0/SUCCESS)
  Process: 10802 ExecStartPre=/usr/pgsql-9.5/bin/postgresql95-check-db-dir ${PGDATA} (code=exited, status=0/SUCCESS)
 Main PID: 10811 (postgres)
   CGroup: /system.slice/postgresql-9.5.service
           ├─10811 /usr/pgsql-9.5/bin/postgres -D /var/lib/pgsql/9.5/data
           ├─10812 postgres: logger process   
           ├─10814 postgres: checkpointer process   
           ├─10815 postgres: writer process   
           ├─10816 postgres: wal writer process   
           ├─10817 postgres: autovacuum launcher process   
           └─10818 postgres: stats collector process 

回答by isapir

The most common issue is that the database cluster was not initialized. You can initialize it easily by running the postgresql-XX-setup script with the initdbcommand, e.g.

最常见的问题是数据库集群未初始化。您可以通过使用initdb命令运行 postgresql-XX-setup 脚本来轻松初始化它,例如

sudo /usr/pgsql-11/bin/postgresql-11-setup initdb

Then start the Postgres service, e.g.

然后启动 Postgres 服务,例如

sudo systemctl start postgresql-11