6

我无法在 Mac OS X 上重新启动 postgres 服务器。我该如何解决这个问题?

尝试了两种方法:

pg_ctl 重启返回:

pg_ctl: PID file "usr/local/var/postgres:/postmaster.pid" does not exist
Is server running?
starting server anyway
pg_ctl: could not read file "usr/local/var/postgres:/postmaster.opts"

服务器不重启

pg_ctl -D /usr/local/var/postgres restart 结果:

   pg_ctl: PID file "/usr/local/var/postgres/postmaster.pid" does not exist
   Is server running?
   starting server anyway
   server starting
   LOG:  could not bind IPv4 socket: Address already in use
   HINT:  Is another postmaster already running on port 5432? If not, wait a few seconds and retry.
   LOG:  could not bind IPv6 socket: Address already in use
   HINT:  Is another postmaster already running on port 5432? If not, wait a few seconds and retry.
   WARNING:  could not create listen socket for "*"
   FATAL:  could not create any TCP/IP sockets
4

1 回答 1

13

1 - 您的data目录可能有误。确保使用正确的路径。

2 - 如果你安装了多个postgres,你需要指定pg_ctl使用哪个。

我手动安装了 postgres 9.2,下面是我的启动方式:

/Library/PostgreSQL/9.2/bin/pg_ctl -D /Library/PostgreSQL/9.2/data start

我通过 HomeBrew 安装了 postgres 9.1,它是这样开始的:

/usr/local/Cellar/postgresql/9.1.5/bin/pg_ctl -D /usr/local/var/postgres-9.1.5 start
于 2013-10-02T21:28:25.653 回答