CentOS 7无法启动postgresql服务
Unable to start postgresql service on CentOS 7
无法在 CentOS 7 上启动 postgresql-9.5。
我关注此页面 - https://wiki.postgresql.org/wiki/YUM_Installation - 在 CentOS 上安装数据库服务器。
我在设置 setenforce 0
后尝试了同样的方法,但也没有帮助。
我正在以 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.
这是我得到的状态 -
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.
而不同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
用 Google 搜索我看到的错误。
很多人都遇到过同样的错误,而且每种情况下的根本原因都不同。通读这些帖子,我不清楚我是否看到任何已经报告的原因。
请确保您已正确安装所有软件包并在安装前更新 yum 存储库部分 [base]
和 [updates]
,如 guide 中所述。我们有 CentOS 7 和 PostgreSQL 9.5,它可以通过以下步骤完美运行:
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
最后,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
最常见的问题是数据库集群未初始化。您可以使用 initdb
命令通过 运行 postgresql-XX-setup 脚本轻松初始化它,例如
sudo /usr/pgsql-11/bin/postgresql-11-setup initdb
然后启动Postgres服务,例如
sudo systemctl start postgresql-11
这些步骤在我们的测试服务器上帮助了我。
通过 SSH 连接您的服务器。
然后切换用户:
sudo su - postgres
检查 Postgres 状态:
pg_ctl status
停止数据库:
pg_ctl stop
检查是否没有服务器进程存在:
ps axf | grep postg
启动 Postgres 服务:
sudo systemctl start postgresql.service
或
sudo systemctl start postgresql
然后查看状态:
systemctl status postgresql.service ИЛИ systemctl status postgresql
无法在 CentOS 7 上启动 postgresql-9.5。
我关注此页面 - https://wiki.postgresql.org/wiki/YUM_Installation - 在 CentOS 上安装数据库服务器。
我在设置 setenforce 0
后尝试了同样的方法,但也没有帮助。
我正在以 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.
这是我得到的状态 -
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.
而不同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
用 Google 搜索我看到的错误。 很多人都遇到过同样的错误,而且每种情况下的根本原因都不同。通读这些帖子,我不清楚我是否看到任何已经报告的原因。
请确保您已正确安装所有软件包并在安装前更新 yum 存储库部分 [base]
和 [updates]
,如 guide 中所述。我们有 CentOS 7 和 PostgreSQL 9.5,它可以通过以下步骤完美运行:
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
最后,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
最常见的问题是数据库集群未初始化。您可以使用 initdb
命令通过 运行 postgresql-XX-setup 脚本轻松初始化它,例如
sudo /usr/pgsql-11/bin/postgresql-11-setup initdb
然后启动Postgres服务,例如
sudo systemctl start postgresql-11
这些步骤在我们的测试服务器上帮助了我。
通过 SSH 连接您的服务器。
然后切换用户:
sudo su - postgres
检查 Postgres 状态:
pg_ctl status
停止数据库:
pg_ctl stop
检查是否没有服务器进程存在:
ps axf | grep postg
启动 Postgres 服务:
sudo systemctl start postgresql.service
或
sudo systemctl start postgresql
然后查看状态:
systemctl status postgresql.service ИЛИ systemctl status postgresql