rake db:create fails, authentication problem with postgresql 8.4

浪尽此生 提交于 2019-12-20 14:22:42

问题


first things first, please excuse my utter noobness. I really tried to find a solution out there, but now i'm stuck and completely clueless.

i'm trying to deploy a rails 3 app on a distant server ; when developping on my local VM, no problem showed. But now, when i try to run

rake db:create

it fails, with error (here translated, since i'm french):

FATAL : password authentication failed for user <<mylogin>>

here's my database.yml :

login: &login
  adapter: postgresql
  username: mylogin
  password: mypassword
  host: localhost
  port: 5432
  encoding: UTF8

development:
  <<: *login
  database: somesite_development

test:
  <<: *login
  database: somesite_test

production:
  <<: *login
  database: somesite_production

the user "mylogin" has been created postgre-side with the command-line tool "createuser". It's authorized to create dbs. postgresql.conf configures the server to listen on localhost. I've tried many things with pg_hba.conf, none worked - whatever the method used (ident, password, md5) for user "mylogin" on 127.0.0.1, authentication fails - though i've never had problems connecting / creating dbs with psql.

any clue ?

EDIT: okay, found out how incredibly stupid i've been... the password for my user was simply not set ! I think i forgot the semicolon after

ALTER USER xxxx WITH PASSWORD xxxx ;

... i saw this by requesting "SELECT * FROM pg_shadow;" - the password field was empty. Three days of my life wasted because of this dumb mistake...


回答1:


I was also stuck on this problem for a really long time, and went to a variety of links (including the ones offered in this post) to try and find the answer, but to no avail. However, the solution is very simple. While many of the other responses were on the right track here are the exact steps to solve the problem:

  1. Open your pg_hba.conf file in a text editor of your choice. (It is located in /etc/postgresql//main)

  2. Navigate to the line that reads:

    # "local" is for Unix domain socket connections only

and paste below it:

  local all         all                 trust

This will trust all unix users trying to connect to the psql server on the local machine. (Read documentation at top of page for further info about function of columns)

  1. Save the pg_hba.conf file and exit the text editor.

  2. Restart the Postgresql server by running the command:

    service postgresql restart

  3. Now try and start a psql server by running:

    psql -d -U (or "psql " for short)

  4. You should be able log in with no problem.

*Note: All this assumes that you have have a valid psql username for logging in. If you don't follow the links below to set one up:

Setting up a user: http://erikonrails.snowedin.net/?p=274

Making sure you have a valid postgres user: http://archives.postgresql.org/pgsql-novice/2002-08/msg00072.php

Listing all existing psql users: If you are looking for a "LIST USERS" or "DISPLAY USERS" command then try:

"select * from pg_user;" (when logged in to psql)

Good luck!




回答2:


okay, found out how incredibly stupid i've been... the password for my user was simply not set ! I think i forgot the semicolon after

ALTER USER xxxx WITH PASSWORD xxxx ;

... i saw this by requesting "SELECT * FROM pg_shadow;" - the password field was empty. Three days of my life wasted because of this dumb mistake...




回答3:


I had same problem. In my case it was because in my database.yml file the username started with capital letter but in database it was all lower case.

Solution: When creating user from postgres command line, it converts all letters to lowercase. For using capital letters, double quotes must be used.

Example:

create user AlbertEinstein; result = alberteinstein

vs

create user "AlbertEinstein"; result = AlbertEinstein




回答4:


Here are some concise instructions that should work for you

http://www.cyberciti.biz/faq/psql-fatal-ident-authentication-failed-for-user/.

Basically you need to set the authentication method for localhost to 'trust'.




回答5:


You need to give "myuser" in postgresql the privilege "Can create database objects".

In pgadmin, it looks like this:

After calling rake db:create, you can take away this privilege.




回答6:


In my case, I found that a later host permissions rule line in the pg_hba.conf file had over-ridden the earlier local line. I was correctly configuring the local line to use md5 authentication but the host line was set to ident which I changed to md5

As other have emphasized here, note that using trust is an insecure method, so you shouldn't use it in any production-style deployment.



来源:https://stackoverflow.com/questions/5817301/rake-dbcreate-fails-authentication-problem-with-postgresql-8-4

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!