重新启动我的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。
导致这种情况发生的另一类原因是由于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
(奇怪的是,它在第一次运行时失败了,在第二次运行时工作了,所以在放弃之前尝试两次)
我在编写psql (PostgreSQL) 9.6.11时遇到了同样的问题。
什么对我有用?
删除邮政局长。Pid——rm /usr/local/var/postgresql@9.6/postmaster.pid
重启postgres——brew服务重启postgresql@9.6
如果邮政局长。Pid不存在或上述进程不工作,则运行——
Sudo chmod 700 /usr/local/var/postgresql@9.6
我也犯过类似的错误。
所有这些都是从命令行完成的(根本没有sudo调用)
我验证我已经安装了PostgreSQL psql -V(注意这是一个大写的“V”)
我试图连接到服务器:psql postgres
这就是我在堆栈溢出问题中遇到错误的地方
在做了一些关于可能的修复的研究之后,我显然安装了PostgreSQL,但我没有一个默认的服务器。
我要做的是创建一个自定义数据目录
据我所知,创建自定义数据目录与设置默认服务器是一样的。
由于这是一台新机器(使用apple m1芯片的MacBook Pro 2021),我想找到最简单的解决方案,我相信这个自定义数据目录就是这样。修复此问题的其余步骤如下:
在主目录中,我创建了一个空目录mkdir myData
从主目录,初始化一个服务器:initdb myData(将一堆文件扔到myData目录)
pg_ctl -D myData -l logfile start(启动服务器)
PSQL postgres(连接到服务器)
所以,作为一个刚刚接触PostgreSQL和数据库以及SQL的人,有几点注意事项:
使用\q可以“退出”到服务器的连接(当连接到服务器时,也可以输入“帮助”)
也可以用pg_ctl -D myData stop来“停止”服务器
在这一点上,我现在确定我已经安装了PostgreSQL,有一个服务器,我可以启动和停止,并有能力连接到/断开,该服务器。