重新启动我的Mac,我得到了可怕的Postgres错误:

psql: could not connect to server: No such file or directory
 Is the server running locally and accepting
 connections on Unix domain socket "/var/run/postgresql/.s.PGSQL.5432"?

发生这种情况的原因是由于一个无关的问题,我的macbook完全死机了,我不得不使用电源按钮进行硬重启。重启后,由于这个错误,我无法启动Postgres。


当前回答

我也有同样的问题。 大多数情况下,问题在于有一个剩余的文件

/ usr / local / var / pid postgres -邮政局长。

这适用于大多数人,但我的情况是不同的-我试着在谷歌上搜索这个问题3个小时,通过brew在OSX上卸载postresql,清除数据库,没有任何工作。

最后,我注意到我有一个问题,每当我试图安装任何东西时,它会弹出:

Error: Permission denied @ rb_sysopen - /private/tmp/github_api_....

或者在安装结束时进行类似的操作。

我只是简单地执行了sudo chmod -R 777 /private/tmp,它终于工作了!

我写下来是因为这可能是别人的解

其他回答

导致这种情况发生的另一类原因是由于Postgres的版本更新。

你可以通过查看postgres日志来确认这是一个问题:

tail -n 10000 /usr/local/var/log/postgres.log

看到这样的条目:

DETAIL:  The data directory was initialized by PostgreSQL version 12, which is not compatible with this version 13.0.

在这种情况下(假设你在Mac上使用brew),只需运行:

brew postgresql-upgrade-database

(奇怪的是,它在第一次运行时失败了,在第二次运行时工作了,所以在放弃之前尝试两次)

对我来说,解决办法就是重启电脑。我首先尝试使用Brew服务重新启动,当它不起作用时,重新启动似乎是下一个最好的选择,然后再考虑一些更复杂的解决方案。之后一切都照常进行。

我也有同样的问题。 大多数情况下,问题在于有一个剩余的文件

/ usr / local / var / pid postgres -邮政局长。

这适用于大多数人,但我的情况是不同的-我试着在谷歌上搜索这个问题3个小时,通过brew在OSX上卸载postresql,清除数据库,没有任何工作。

最后,我注意到我有一个问题,每当我试图安装任何东西时,它会弹出:

Error: Permission denied @ rb_sysopen - /private/tmp/github_api_....

或者在安装结束时进行类似的操作。

我只是简单地执行了sudo chmod -R 777 /private/tmp,它终于工作了!

我写下来是因为这可能是别人的解

我在这里遇到了类似的问题,我解决了这个问题,如下所示。

实际上postgres进程已经死亡,要查看postgres的状态,请运行以下命令

sudo /etc/init.d/postgres status

它会说进程已死,只要启动进程

sudo /etc/init.d/postgres start

也许这是不相关的,但类似的错误出现当你升级postgres到一个主要版本使用brew;使用brew info postgresql发现这有助于:

To migrate existing data from a previous major version of PostgreSQL run:
brew postgresql-upgrade-database