我是postgres的新手。
我安装了postgres。我在玩psql命令,我不小心掉了postgres数据库。我不知道里面有什么。
我目前正在制作一个教程:http://www.rosslaird.com/blog/building-a-project-with-mezzanine/
我被困在sudo -u postgres psql postgres
错误信息:psql: FATAL: role "postgres"不存在
$ which PSQL
/Applications/Postgres.app/Contents/MacOS/bin/psql
这是psql -l输出的内容
List of databases
Name | Owner | Encoding | Collate | Ctype | Access privileges
------------+------------+----------+---------+-------+---------------------------
user | user | UTF8 | en_US | en_US |
template0 | user | UTF8 | en_US | en_US | =c/user +
| | | | | user =CTc/user
template1 | user | UTF8 | en_US | en_US | =c/user +
| | | | | user =CTc/user
(3 rows)
那么我应该采取哪些步骤呢?删除一切相关的psql和重新安装一切?
谢谢你们的帮助!
上下文
我添加了一个我在这里没有看到的情况的答案,这是一个边缘情况,如果您在同一台机器上有多个用户,并且试图使用postgres服务的用户不是在该机器上安装postgres的用户。
我所尝试过的
在其他类似的命令中,这些命令对我来说都失败了:
createuser -s [your username]
# createuser: error: connection to server on socket "/tmp/.s.PGSQL.5432" failed: FATAL: role "[your username]" does not exist
createuser -s postgres
# createuser: error: connection to server on socket "/tmp/.s.PGSQL.5432" failed: FATAL: role "[your username]" does not exist
sudo -u postgres createuser --superuser [your username]
# sudo: unknown user: postgres
# sudo: error initializing audit plugin sudoers_audit
psql -U postgres
# psql: error: connection to server on socket "/tmp/.s.PGSQL.5432" failed: FATAL: role "postgres" does not exist
原因
原因是postgres角色和[你的用户名](也就是你的命令行中的whoami)都不在postgres中。
解决方案
在这种极端情况下,我必须首先登录安装postgres的用户:
sudo su - [username that installed postgres]
然后为我的新用户创建一个角色:
createuser -s [your username]
上下文
我添加了一个我在这里没有看到的情况的答案,这是一个边缘情况,如果您在同一台机器上有多个用户,并且试图使用postgres服务的用户不是在该机器上安装postgres的用户。
我所尝试过的
在其他类似的命令中,这些命令对我来说都失败了:
createuser -s [your username]
# createuser: error: connection to server on socket "/tmp/.s.PGSQL.5432" failed: FATAL: role "[your username]" does not exist
createuser -s postgres
# createuser: error: connection to server on socket "/tmp/.s.PGSQL.5432" failed: FATAL: role "[your username]" does not exist
sudo -u postgres createuser --superuser [your username]
# sudo: unknown user: postgres
# sudo: error initializing audit plugin sudoers_audit
psql -U postgres
# psql: error: connection to server on socket "/tmp/.s.PGSQL.5432" failed: FATAL: role "postgres" does not exist
原因
原因是postgres角色和[你的用户名](也就是你的命令行中的whoami)都不在postgres中。
解决方案
在这种极端情况下,我必须首先登录安装postgres的用户:
sudo su - [username that installed postgres]
然后为我的新用户创建一个角色:
createuser -s [your username]