rake db:create fails, authentication problem with postgresql 8.4

m_x picture m_x · Apr 28, 2011 · Viewed 16.7k times · Source

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...

Answer

Vidal Ekechukwu picture Vidal Ekechukwu · Feb 11, 2012

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!