当我创建一个新用户,但它不能登录数据库。
我是这样做的:
postgres@Aspire:/home/XXX$ createuser dev
Shall the new role be a superuser? (y/n) n
Shall the new role be allowed to create databases? (y/n) y
Shall the new role be allowed to create more new roles? (y/n) y
然后创建一个数据库:
postgres@Aspire:/home/XXX$ createdb -O dev test_development
之后,我尝试psql -U dev -W test_development登录,但得到错误:
psql: FATAL: Peer authentication failed for user "dev"
我试图解决这个问题,但失败了。
虽然@flaviodesousa的答案可以工作,但它也强制所有用户(其他所有人)输入密码。
有时对其他人保持对等身份验证是有意义的,但对服务用户例外。在这种情况下,你会想要在pg_hba.conf中添加一行,看起来像这样:
local all some_batch_user md5
我建议你在注释标题行下面添加这一行:
# TYPE DATABASE USER ADDRESS METHOD
local all some_batch_user md5
重启PostgreSQL需要使用
sudo service postgresql restart
如果你使用的是9.3,你的pg_hba.conf很可能是:
/etc/postgresql/9.3/main/pg_hba.conf
虽然@flaviodesousa的答案可以工作,但它也强制所有用户(其他所有人)输入密码。
有时对其他人保持对等身份验证是有意义的,但对服务用户例外。在这种情况下,你会想要在pg_hba.conf中添加一行,看起来像这样:
local all some_batch_user md5
我建议你在注释标题行下面添加这一行:
# TYPE DATABASE USER ADDRESS METHOD
local all some_batch_user md5
重启PostgreSQL需要使用
sudo service postgresql restart
如果你使用的是9.3,你的pg_hba.conf很可能是:
/etc/postgresql/9.3/main/pg_hba.conf