Postgres could not connect to server
Asked Answered
G

66

645

After I did brew update and brew upgrade, my postgres got some problem. I tried to uninstall postgres and install it again, but it didn't work as well.

This is the error message. (I also got this error message when I try to do rake db:migrate)

$ psql
psql: could not connect to server: No such file or directory
    Is the server running locally and accepting
    connections on Unix domain socket "/tmp/.s.PGSQL.5432"?

How can I solve it?

Mac version: Mountain lion.

homebrew version: 0.9.3

postgres version: psql (PostgreSQL) 9.2.1

And this is what I did:

$ brew uninstall postgresql
Uninstalling /usr/local/Cellar/postgresql/9.2.1...
$ brew uninstall postgresql
Uninstalling /usr/local/Cellar/postgresql/9.1.4...
$ psql --version
bash: /usr/local/bin/psql: No such file or directory
$ brew install postgresql
==> Downloading http://ftp.postgresql.org/pub/source/v9.2.1/postgresql-9.2.1.tar.bz2
Already downloaded: /Library/Caches/Homebrew/postgresql-9.2.1.tar.bz2
......
......
==> Summary
/usr/local/Cellar/postgresql/9.2.1: 2814 files, 38M, built in 2.7 minutes
$ initdb /usr/local/var/postgres -E utf8
The files belonging to this database system will be owned by user "laigary".
This user must also own the server process.

The database cluster will be initialized with locale "en_US.UTF-8".
The default text search configuration will be set to "english".

initdb: directory "/usr/local/var/postgres" exists but is not empty
If you want to create a new database system, either remove or empty
the directory "/usr/local/var/postgres" or run initdb
with an argument other than "/usr/local/var/postgres".
$ mkdir -p ~/Library/LaunchAgents
$ cp /usr/local/Cellar/postgresql/9.2.1/homebrew.mxcl.postgresql.plist ~/Library/LaunchAgents/
$ launchctl load -w ~/Library/LaunchAgents/homebrew.mxcl.postgresql.plist
homebrew.mxcl.postgresql: Already loaded
$ pg_ctl -D /usr/local/var/postgres -l /usr/local/var/postgres/server.log start
server starting
$ env ARCHFLAGS="-arch x86_64" gem install pg
Building native extensions.  This could take a while...
Successfully installed pg-0.14.1
1 gem installed
$ psql --version
psql (PostgreSQL) 9.2.1
$ psql
psql: could not connect to server: No such file or directory
    Is the server running locally and accepting
    connections on Unix domain socket "/tmp/.s.PGSQL.5432"?

Now, after I reinstalled homebrew, when I use $ psql, it doesn't show any error message.

But I run rake db:migrate in my Rails app, it shows:

could not connect to server: No such file or directory
    Is the server running locally and accepting
    connections on Unix domain socket "/var/pgsql_socket/.s.PGSQL.5432"?

/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/connection_adapters/postgresql_adapter.rb:1213:in `initialize'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/connection_adapters/postgresql_adapter.rb:1213:in `new'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/connection_adapters/postgresql_adapter.rb:1213:in `connect'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/connection_adapters/postgresql_adapter.rb:329:in `initialize'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/connection_adapters/postgresql_adapter.rb:28:in `new'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/connection_adapters/postgresql_adapter.rb:28:in `postgresql_connection'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/connection_adapters/abstract/connection_pool.rb:309:in `new_connection'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/connection_adapters/abstract/connection_pool.rb:319:in `checkout_new_connection'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/connection_adapters/abstract/connection_pool.rb:241:in `block (2 levels) in checkout'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/connection_adapters/abstract/connection_pool.rb:236:in `loop'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/connection_adapters/abstract/connection_pool.rb:236:in `block in checkout'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/1.9.1/monitor.rb:211:in `mon_synchronize'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/connection_adapters/abstract/connection_pool.rb:233:in `checkout'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/connection_adapters/abstract/connection_pool.rb:96:in `block in connection'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/1.9.1/monitor.rb:211:in `mon_synchronize'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/connection_adapters/abstract/connection_pool.rb:95:in `connection'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/connection_adapters/abstract/connection_pool.rb:404:in `retrieve_connection'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/connection_adapters/abstract/connection_specification.rb:170:in `retrieve_connection'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/connection_adapters/abstract/connection_specification.rb:144:in `connection'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/railties/databases.rake:107:in `rescue in create_database'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/railties/databases.rake:51:in `create_database'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/railties/databases.rake:40:in `block (3 levels) in <top (required)>'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/railties/databases.rake:40:in `each'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/gems/1.9.1/gems/activerecord-3.2.8/lib/active_record/railties/databases.rake:40:in `block (2 levels) in <top (required)>'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/1.9.1/rake/task.rb:205:in `call'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/1.9.1/rake/task.rb:205:in `block in execute'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/1.9.1/rake/task.rb:200:in `each'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/1.9.1/rake/task.rb:200:in `execute'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/1.9.1/rake/task.rb:158:in `block in invoke_with_call_chain'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/1.9.1/monitor.rb:211:in `mon_synchronize'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/1.9.1/rake/task.rb:151:in `invoke_with_call_chain'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/1.9.1/rake/task.rb:144:in `invoke'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/1.9.1/rake/application.rb:116:in `invoke_task'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/1.9.1/rake/application.rb:94:in `block (2 levels) in top_level'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/1.9.1/rake/application.rb:94:in `each'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/1.9.1/rake/application.rb:94:in `block in top_level'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/1.9.1/rake/application.rb:133:in `standard_exception_handling'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/1.9.1/rake/application.rb:88:in `top_level'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/1.9.1/rake/application.rb:66:in `block in run'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/1.9.1/rake/application.rb:133:in `standard_exception_handling'
/usr/local/Cellar/ruby/1.9.3-p327/lib/ruby/1.9.1/rake/application.rb:63:in `run'
/usr/local/bin/rake:32:in `<main>'
Couldn't create database for {"adapter"=>"postgresql", "encoding"=>"unicode", "database"=>"riy_development", "pool"=>5, "username"=>nil, "password"=>nil}

Finally I've found a solution.

sudo mkdir /var/pgsql_socket/
sudo ln -s /private/tmp/.s.PGSQL.5432 /var/pgsql_socket/

This solution is a little tricky, but it works. Hope anyone has a better solution

Update

This works for me as well.

rm /usr/local/var/postgres/postmaster.pid
Glennaglennie answered 16/11, 2012 at 4:53 Comment(8)
I am having your exact same problem, but your solution did not work for me. I think this is a permissions problem but I don't have the knowledge of file permissions to fix it.Wilhelm
For are those who install PG via Homebrew and are having problems, I found another answer. Just uninstall pg gem and reinstall with Homebrew configs. See the answer at https://mcmap.net/q/47870/-in-rails-couldn-39-t-create-database-for-quot-adapter-quot-gt-quot-postgresql-quot.Mccormack
similar answer here - #13573704Indopacific
Start postgres.Brose
Upgrade your existing to the newer version with the following command brew postgresql-upgrade-databaseVinna
What worked for me: brew services stop postgres && initdb && createdb $(whoami) && createuser -s postgres && brew services start postgresBerryman
I had a similar problem. I accidentally deleted the default 'postgres' database. You can try this: sudo -d 'existing db like template01' -u postgres -h localhost; from there create db: create database postgres; then try: sudo -u postgres psqlAttached
Just want to add this sneaky fix, since I ran into the same issue today: i forgot to rails db:create first. Whoops.Brenna
R
1253

Had a similar problem; a pid file was blocking postgres from starting up. To fix it:

$ rm /usr/local/var/postgres/postmaster.pid
$ brew services restart postgresql

and then all is well.


UPDATE:

For Apple M1 (Big Sur) users, do this instead:

$ rm /opt/homebrew/var/postgres/postmaster.pid
$ brew services restart postgresql

UPDATE (Nov 15 2022):

For Apple M1 / M2 (Ventura) users, just do this:

$ bundle install (just to make sure pg is installed)
$ brew services restart postgresql
Roque answered 16/9, 2013 at 15:55 Comment(29)
This worked for me on OSX Mavericks after seeing this issue upon a update/restart.Enforcement
Thanks, this worked for me too. My PostgreSQL from Homebrew broke after I did a minor Maverick update to 10.9.2, maybe it was just a metter of cleaning the old .pid file.Indopacific
Using Yosemite it didn't work. Still the same error and the file no longer exists. But it used to work on OSX versions for me though... any help? "could not connect to server: No such file or directory Is the server running locally and accepting connections on Unix domain socket "/tmp/.s.PGSQL.5432"?"Indented
@BetuUuUu see this post for a solution on Yosemite. It's not pretty, but it works. #25970632Cacilia
@Cacilia thanks, I already solved!:) The solution was to uninstall via homebew and then restart my computer right away, so then I would be able to reinstall postgres. The old version was running in the background, creating files and conflicts every time I tried to reinstall postgres.Indented
This didn't work for me on Mavericks: rm: /usr/local/var/postgres/postmaster.pid: No such file or directoryPompei
This worked for me, after erasing I had to start postgres. # pg_ctl -D /usr/local/var/postgres -l /usr/local/var/postgres/server.log startEpilimnion
I recommend tailing the server log to make sure this is actually the issue: tail /usr/local/var/postgres/server.logHenna
After Yosemite crashed and restarted, cannot connect to Postgres. your answer worked perfect. :)Wende
Mac Yosemite 10.10.5 after battery died, rebooted, and xCode finished it's update - your answer still works beautifully ... thanks!Publia
This does not work for mac users, check my answer below https://mcmap.net/q/46772/-postgres-could-not-connect-to-serverSnaggy
I don't see that pid file . I am using PostGreSQL version 9.6Sallust
Remember to restart the service after deleting the .pidLeuko
for those whose the command does not work, ensure first you can see invisible files, then check path /usr/local/var/ You may have multiple folders there for different versions of postgresql. Each could contain the postmaster.pid file that needs to be removedSaiz
This followed by brew services restart postgresql worked for meEaten
This worked for me after an accidental restart (battery died and I had to reboot). Thank you!Humble
should be rm -rf ~/usr/local/var/postgres/postmaster.pidHalting
@FábioBCSouza No it should not!Edda
@ruohola, without recursive force I could not make it work. Using rm -rf the pid was deletedHalting
Some forget about the version, so they will get No such file or directory. They should be more specific: rm /usr/local/var/postgresql\@9.5/postmaster.pid then brew services restart [email protected]Obsequent
Thanks ! For me I just needed to run the second command: 'brew services restart postgresql'Skunk
If you installed a specific version of postgres using homebrew, the paths above might be different. If you run brew list | grep postgres and see postgresql@11 for example, then you would need to run $ rm /usr/local/var/postgresql@11/postmaster.pid $ brew services restart postgresql@11Topnotch
I just wanna say this is the worse errors I get every single time there's an OS update, Postgres update, computer restart or anything in between. It's incredible that I need to go seeking for the same solution over and over. Had to vent somewhere.Stanwinn
Thank you! Directly restarting for me didn't work, had to remove the pid file.Yacketyyak
As @Obsequent says, sometimes you need to be version specific. I needed rm /opt/homebrew/var/postgresql@12/postmaster.pid and postgresql@12 (macOS Big Sur on M1)Billybillycock
Works on Catalina as well!Keary
I just had to brew services restart postgresqlFourdimensional
My postmaster.pid file was in /usr/local/var/postgresql@13/postmaster.pid rather than the directory above - so you might need to do find / -name postmaster.pid to get the right directory.Commonable
This worked for me in Monterey.Amathist
A
365

This sometimes happens when brew does a postgres upgrade, causing the data files to become incompatible with the new server.

In my case, it happened when upgrading from 9.3 to 9.4.

OS X/Homebrew:

Try running postgres -D /usr/local/var/postgres -- it will give you a much more verbose output if postgres fails to start. Or open the log file at /usr/local/var/log/postgres.log (/opt/homebrew/var/log/postgres.log on Mac M1) and look for the line "FATAL: database files are incompatible with server"

In my case, running rm -rf /usr/local/var/postgres && initdb /usr/local/var/postgres -E utf8 removed my old databases and then reinitialized the postgres db schema. (THIS WILL DESTROY YOUR DATA)

Thanks to https://github.com/Homebrew/homebrew/issues/35240 for that solution. Full instructions for a thorough re-install can be found here: How to completely uninstall and reinstall Homebrew Postgres - Test Double Blog (Again, if you're on an M1 Mac then substitute the /opt/homebrew/var path wherever it says /usr/local/var)

After regenerating my databases (with rake db:create) everything worked fine again.

Finally, links in the comments point to this possible solution that preserves your data, but I haven't tried it: How to upgrade PostgreSQL from version 9.6 to version 10.1 without losing data - Stack Overflow

Aeciospore answered 13/1, 2015 at 15:16 Comment(14)
This worked for me with a homebrew installed postgres on Yosemite.Velour
If running postgres -D /usr/local/var/postgres tells you that the data directory was initialized with an older, incompatible version of Postgres, and you don't want to lose your local data, you might try this threadCircuitry
After the above command was run, I ran: pg_ctl -D /usr/local/var/postgres -l logfile start and then my server started in the backgroundTouraco
Use brew services start postgres on OSX to start postgres on background instead of postgres -D /usr/local/var/postgresHooknosed
Just a head's up that this deletes your databases, which may not be what you want (or you might not care if this is all dev all the time)Esbensen
Worked for me. I lost all my local databases but it fix it so it works. This i fine by me since this has locally.Bluepoint
FATAL: database files are incompatible with server was the reason. I don't know how to fix that yet, but at least I know what's going on. Thanks!Graciagracie
I just accidentally upgraded my postgresql from 9.5 to 10.1 and improperly shutdown the pc. For the record, here's the log: postgres -D /usr/local/var/postgres \n `2018-02-12 11:31:23.676 +08 [2526] FATAL: database files are incompatible with server 2018-02-12 11:31:23.676 +08 [2526] DETAIL: The data directory was initialized by PostgreSQL version 9.5, which is not compatible with this version 10.1.Afterbirth
@Graciagracie I had the same issue, and fixed it with the instructions here: #24379873Equestrienne
WOW! After trying everything, this rm -rf /usr/local/var/postgres && initdb /usr/local/var/postgres -E utf8 finally worked for me. Thank you!Normative
Command rm -rf /usr/local/var/postgres throw me an error "folder doesn't exists" but then I ran initdb /usr/local/var/postgres it worked for me! ThanksGeologize
Worked for Postgres 13 -> 14 upgrade on macOS 10.15 in which other listed answers did not.Arvie
Note that after this you may need to recreate the postgres role /usr/local/opt/postgres/bin/createuser -s postgres and your personal database psql -U postgres then create database with your role name.Applied
postgres -D /usr/local/var/postgres turned out to show postmaster.pid already existsFadeout
E
91

Found a solution that worked for me here:

https://dba.stackexchange.com/questions/75214/psql-could-not-connect-to-server-no-such-file-or-directory

You basically run the following command to manually start the server:

pg_ctl -D /usr/local/var/postgres -l /usr/local/var/postgres/server.log start
Emit answered 1/4, 2015 at 5:57 Comment(2)
Out of all the answers this is the only one that worked for me. Using El CapitanFender
I have tried with that cmd but not working for me!!Christopherchristopherso
S
69

If installing and uninstalling postgres with brew doesn't work for you, look at the logs of your postgresql installation or:

postgres -D /usr/local/var/postgres

if you see this kind of output:

LOG:  skipping missing configuration file "/usr/local/var/postgres/postgresql.auto.conf"
FATAL:  database files are incompatible with server
DETAIL:  The data directory was initialized by PostgreSQL version 9.4, which is not compatible with this version 9.6.1.

Then try the following:

rm -rf /usr/local/var/postgres && initdb /usr/local/var/postgres -E utf8

Then start the server:

pg_ctl -D /usr/local/var/postgres -l logfile start

Source

Snaggy answered 9/2, 2017 at 3:17 Comment(3)
That works when the reason is different from the accepted answer, i.e. the database files are not compatible with the current version. Since exactly that has been my problem, I upvote.Pedagogy
This one worked for me in mac os big sur.Pemmican
@zepol.j of course you need to back it up LOLSnaggy
P
64

Upgrading the database works for me

brew postgresql-upgrade-database
Pokey answered 23/1, 2018 at 19:17 Comment(6)
👍✅⭐️🙏Thank you Tomer! This worked for me 6/2/20 upgrading from 9.4 to 12 on macOS Mojave 10.14.6Sequential
After changing Ruby version, I didn't noticed but my Postgresql installation changed versions and only with this command could have it running again.Purposive
this worked for me also. 2 days back I updated homebrew which caused my postgres but after updating postgressql , its working fine. Thanks againDripping
No such file or directory @ rb_sysopen - /usr/local/var/postgres/PG_VERSIOPellitory
Thank you so much! 🥳🥳🥳 This worked for me 👍👍👍 I think brew automatically updated lot of packages when I installed some other package.Gilleod
Thank you Tomer! This worked for me too, upgrading from 13 to 14 on Mac Monterey 12.3.1. Don't you love one line solutions? 😊Churinga
S
40

On Yosemite, if the pid file is blocking Postgres from starting and you have a launchctl daemon trying (and failing) to load the database daemons, then you'll need to unload the plist file:

$ launchctl unload ~/Library/LaunchAgents/homebrew.mxcl.postgresql.plist

Then remove the pid file

$ rm /usr/local/var/postgres/postmaster.pid

Then reload the launchctl daemon

$ launchctl load ~/Library/LaunchAgents/homebrew.mxcl.postgresql.plist
Swob answered 18/12, 2014 at 8:26 Comment(1)
This worked on a Monterey MacOS too! ThanksLoreanloredana
P
36

For anyone reading this and using Postgres.app, you may need host: localhost in your database.yml. http://postgresapp.com/documentation#toc_3

Piteous answered 14/6, 2013 at 6:54 Comment(4)
Doing this changes the connection from a socket to a TCP connection which may have negative implications. See #6771149Wilfredwilfreda
Hmm, actually, if you downvote... Maybe don't say why? meta.#252797 Or maybe say why, but log out first so you're anonymous.Piteous
I think the down vote is because the original question wasn't for the Postgres.app but Homebrew. So while the answer might be useful somewhere, it isn't answering the question.Olen
The link doesn't seem to go anywhere specific (and searching "localhost" on the past has no results) but this just fixed the issue for me after an hour of searching.Paramount
O
29
brew services start postgres 

worked for me!

Oestrin answered 14/3, 2017 at 23:49 Comment(1)
This worked for me. For some reason when I updated brew I was getting the OP error. I explicitly upgraded postgres with that above command and that seemed to work.Turnstile
O
19

The problem can also be attributed to a crashed process that left postmaster.pid file behind. I do this and work's:

$ brew services stop postgresql
$ rm /usr/local/var/postgres/postmaster.pid # adjust path accordingly to your install
$ brew services start postgresql
Oestrin answered 18/10, 2018 at 14:55 Comment(2)
i can't find this .pid file anywhereBalmung
try a: $ ls -a usr/local/var/postgres if don't try a: $ where postgres or a: $ which postgresOestrin
A
18

The problem is because there is already a running service on the port 5432 and we cannot establish psql socket connection through this port.

I removed the socket file

rm -rf /tmp/.s.PGSQL.5432/

Then I reinitialized postgres services

postgres -D /usr/local/var/postgres

This worked for me.

Arleanarlee answered 19/5, 2018 at 20:59 Comment(0)
S
17

Check that the socket file exists.

$ ls -l /tmp/.s.PGSQL.5432
srwxrwxrwx  1 you  wheel  0 Nov 16 09:22 /tmp/.s.PGSQL.5432

If it doesn't then check your postgresql.conf for unix_socket_directory change.

$ grep unix_socket /usr/local/var/postgres/postgresql.conf
#unix_socket_directory = ''     # (change requires restart)
#unix_socket_group = ''         # (change requires restart)
#unix_socket_permissions = 0777     # begin with 0 to use octal notation
Sebastien answered 16/11, 2012 at 14:44 Comment(4)
This is my computer response. $ ls -l /tmp/.s.PGSQL.5432 ls: /tmp/.s.PGSQL.5432: No such file or directory $ grep unix_socket /usr/local/var/postgres/postgresql.conf #unix_socket_directory = '' # (change requires restart) #unix_socket_group = '' # (change requires restart) #unix_socket_permissions = 0777 # begin with 0 to use octal notationGlennaglennie
Finally I find the solution. $ mkdir /var/pgsql_socket/ $ sudo mkdir /var/pgsql_socket/ $ ln -s /private/tmp/.s.PGSQL.5432 /var/pgsql_socket/ This solution is little tricky, but it works. Hope anyone have a better solutionGlennaglennie
nice job @GaryLai. Very strange that I did not have to do the same with my homebrew postgresqlSebastien
this may help some folks out there: github.com/mxcl/homebrew/issues/14527Abscission
D
17

The most fool proof way around this is to do

brew reinstall postgresql

This will keep your user permission etc all intact and everything is reset to new. Works all the time !

Doloritas answered 4/11, 2016 at 3:9 Comment(2)
This is worked but i recommend if rm /usr/local/var/postgres/postmaster.pid on mac os not worked then use this command.Germano
Exactly, I tried deleting postmaster.pid but I wasn't there, so I tried this solution and it recreated that file and now it works fine.Ginni
B
11

In my case, the trouble was caused by Mac OS updating. Upgrading PostgreSQL solved the issue.

# upgrade database version solved the trouble
$ brew postgresql-upgrade-database

However, this error is quite common and has multiple possible reasons, you shouldn’t fully rely on my solution above.

Burrus answered 29/10, 2020 at 5:25 Comment(1)
This seemed to work well for big sur. note that depending on your specific version of postgresql from brew, and OS --any of the solutions involving deleting files from specific paths may not have the right path. In my case even when I found the right path it still failed--but this worked.Chlamydate
C
10

For MacOS BigSur, homebrew postgres:

  • rm /opt/homebrew/var/postgres/postmaster.pid
  • brew services restart postgresql
Contrasty answered 28/5, 2021 at 14:17 Comment(0)
S
9

This worked for me . I didn't have to remove any file

brew postgresql-upgrade-database

Spae answered 22/9, 2021 at 15:44 Comment(1)
This was also my issue; my data directory was of an older version than the server, due to brew updating it. You can see if this is the problem by looking at the logs: postgres -D /usr/local/var/postgres. If you need to upgrade, you'll see something like, The data directory was initialized by PostgreSQL version 13, which is not compatible with this version 14.2.Recur
N
8

This is actually what you are supposed to do:

you should instead look at /usr/local/var/postgres/postmaster.pid

and then look at the first line of the file - this is the bad PID

Run

ps aux | grep <PID>

for example:

ps aux | grep 12345

then do

kill <PID>

for example

kill 12345

Assuming it's still running

https://superuser.com/questions/553045/fatal-lock-file-postmaster-pid-already-exists

do not listen to the accepted answer it is bad and will corrupt your data!!!

Nguyetni answered 6/5, 2017 at 2:15 Comment(1)
Thanks, this worked for me. Removing the postmaster.pid in the accepted answer wasn't actually enough.Barela
D
7

Changing postresql or database.yml config settings, changing $PATH, or creating symlinks were all unnecessary for me. All I needed to do was gem uninstall pg and then bundle (or gem install pg).

The issue was that the pg gem had been installed before homebrew postgres, so was picking up the settings from the version of postgres that comes with MacOS. Reinstalling it (and thus rebuilding the native extension) fixed the problem.

Doretheadoretta answered 23/8, 2013 at 19:8 Comment(1)
Just wanted to say thanks. I just upgraded PostgresApp on macOS and although I could connect using psql, I couldn't connect via rails. uninstalling and reinstalling the pg gem was just the ticket! :)Presa
E
7

This happened to me when I upgraded from 9.3.4 to 9.5 as the databases are incompatible without upgrading.

I used pg_upgrade as follows:

Stop postgres

$ brew services stop postgresql

Upgrade the databases:

$ pg_upgrade \
   -d /usr/local/var/postgres \
   -D /usr/local/var/postgres9.5 \
   -b /usr/local/Cellar/postgresql/9.3.4/bin/ \
   -B /usr/local/Cellar/postgresql/9.5.0/bin/ \
   -v

Archive the old databases:

 $ mv /usr/local/var/postgres /usr/local/var/postgres9.3.save
 $ mv /usr/local/var/postgres9.5 /usr/local/var/postgres

Restart postgres:

 $ brew services start postgresql

Updated Gems (for rails / active record) :

 $ gem uninstall pg
 $ gem uninstall activerecord-postgresql-adapter
 $ bundle install
Esbensen answered 10/8, 2016 at 19:0 Comment(1)
These instructions are also at collectiveidea.com/blog/archives/2016/01/08/… , and still worked for me today when upgrading from 9.4.0 to 9.6.3. I didn't need to do anything to the .pid file manually.Esdraelon
S
6

I faced the same problem for psql (PostgreSQL) 9.6.11.

what worked for me -

remove postmaster.pid -- rm /usr/local/var/[email protected]/postmaster.pid

restart postgres -- brew services restart [email protected]

If this also doesn't work then run -- sudo chmod 700 /usr/local/var/[email protected]

Slick answered 12/4, 2019 at 6:52 Comment(0)
L
5

Psql option

-h hostname --host=hostname

: Specifies the host name of the machine on which the server is running. If the value begins with a slash, it is used as the directory for the Unix-domain socket.

$ grep "port\|unix_socket" /etc/postgresql/9.1/main/postgresql.conf
port = 5433                                         # (change requires restart)
unix_socket_directory = '/var/run/postgresql'       # (change requires resta

$ netstat -nalp | grep postgres
unix  2      [ ACC ]     STREAM     LISTENING     106753   4349/postgres       /tmp/.s.PGSQL.5432
unix  2      [ ACC ]     STREAM     LISTENING     10377 1031/postgres       /var/run/postgresql/.s.PGSQL.5433

Run psql with -host Option

$ psql -p 5433 -h /var/run/postgresql

No need to make a soft link

Laina answered 2/3, 2014 at 7:8 Comment(0)
S
5

If postgres was installed using homebrew, you can fix this by running:

brew link postgres
Stalingrad answered 14/3, 2017 at 23:19 Comment(0)
H
5

This worked for me (as a mix of previous answers):

$ rm /usr/local/var/postgres/postmaster.pid

$ pg_ctl -D /usr/local/var/postgres -l /usr/local/var/postgres/server.log start

Source: https://coderwall.com/p/zf-fww/postgres-on-osx-with-homebrew-not-running-after-osx-crash

Heckman answered 17/3, 2018 at 14:23 Comment(0)
C
5

So i stubled upon this after the rails db:create command. Setting up the environment in a macOS Catalina 10.15.3.

First thing that i checked was the flow that got me here. After ensuring that that all things had went smoothly and there was no error that might had escaped my mind i tried the most popular solutions from here but none of the seemed to work.

So far the only error i was seeing was the

$ psql psql: could not connect to server: No such file or directory Is the server running locally and accepting connections on Unix domain socket "/tmp/.s.PGSQL.5432"?

So i needed some more specific information about what was happening. Due to that reason i decided to look at the postgres logfile which is located at

/usr/local/var/log/postgres.log

So after opening the log i saw this error

LOG: starting PostgreSQL 12.2 on x86_64-apple-darwin19.3.0, compiled by Apple clang version 11.0.0 (clang-1100.0.33.17), 64-bit LOG: could not translate host name "localhost", service "5432" to address: nodename nor servname provided, or not known WARNING: could not create listen socket for "localhost" FATAL: could not create any TCP/IP sockets LOG: database system is shut down

So this is a bit more explanatory and specific. The problem is something about that PostgreSQL cannot "see" and resolve the localhost server.

So next thing i did was to check the /etc/hosts file whose default contents should look like this:

##
# Host Database
#
# localhost is used to configure the loopback interface
# when the system is booting.  Do not change this entry.
##
127.0.0.1   localhost
255.255.255.255 broadcasthost
::1          localhost 

After comparing the above with mine i saw that in mine this line was different and commented (!).

#::1             localhost

So i removed the # symbol in front of the line saved the file and re run the

rails db:create 

and the database was succesfully initiated.

Clericalism answered 25/3, 2020 at 23:35 Comment(1)
God bless you. Other answers are not working for me and there's no way I could see a postmaster.pid. I have other error but thank god for hinting me on the log file to inspect :. /usr/local/var/log/postgres.log.Pomander
T
5

Solution for MacOS M1 Monterey

rm /opt/homebrew/var/postgres/postmaster.pid
brew services restart postgresql
Treachery answered 6/5, 2022 at 15:40 Comment(0)
M
4

Came across this issue too on MacOS Sierra and when we ran pg_ctl as described above we then had the following error pg_ctl: no database directory specified and environment variable PGDATA unset. So we followed the steps here which solved our issue, namely:

mkdir ~/.postgres

initdb ~/.postgres

pg_ctl -D ~/.postgres start

Melan answered 2/11, 2016 at 20:29 Comment(0)
A
4

I got same issue because I'm using a wrong Postgres's username in code. I logged into postgres psql -d postgres and enter \du to take role name and correct Postgres's username.

So when you guys face this issue, you guys need to make sure you're using correct Postgres username, password, hostname and database...

Hope this will help anyone

Adria answered 16/10, 2017 at 4:39 Comment(0)
P
4

If you shut down your system without quitting psql, postgres would not have removed some files.

I didn't find the file postmaster.pid in the location usr/local/var/postgres

So I did the below:

brew services start postgresql

The above command should let you start postgres

Prescind answered 12/7, 2019 at 11:26 Comment(0)
A
3

I ran into this issue after trying to restore/drop/create a db while other processes were accessing them. MacOSX/Homebrew fix was:

  1. close all other accessing processes rails server, rails console, guard, etc...
  2. load/unload using the commands found in brew info postgres
  3. run restore/drop/create from before
Appel answered 24/1, 2014 at 18:17 Comment(0)
O
3

FWIW this happened to me today, but what happened was that I was running Ubuntu updates at the time, which were likely updating Postgres. Once the update completed, I was able to connect without a hitch.

For completeness' sake, I was trying to retrieve records from the database from a Rails console:

development (main):0 > a = MyModel.find 73694
PG::ConnectionBad: 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"?
Omnivore answered 10/2, 2015 at 14:54 Comment(0)
K
3

It looks like your psql doesn't run. You should run it before connect. You can do that using Postgres.app for Mac OS only. (Download and install this app http://postgresapp.com) Open the app, and you have a PostgreSQL server ready and awaiting new connections. Close the app, and the server shuts down. You also can find this info here http://www.postgresql.org/download/macosx/. Hope this will help you.

Kadiyevka answered 9/6, 2015 at 21:12 Comment(2)
While this link may answer the question, it is better to include the essential parts of the answer here and provide the link for reference. Link-only answers can become invalid if the linked page changes.Marcomarconi
The question was specifically referring to a homebrew installation and not a Postgres.app install. While this answer is helpful, it doesn't answer the question. It would be like saying "Use MySQL instead."Olen
T
3

It is because a previous server a still running, try closing everything down and re-running your application.

Telegenic answered 1/10, 2016 at 9:22 Comment(0)
C
3

For those who use this command and doesn't work or the file is not there and are using Ruby on Rails

rm /usr/local/var/postgres/postmaster.pid

Or any other command and just keep on failing.

I solved this problem uninstalling with Brew. I had to uninstall with brew 2 times, because at the first uninstall there will remain another version of postgresql, with the second uninstall the process will be completed.

Install postgresql with Brew

Then drop, create and migrate the data bases of the project

(Don't forget to start the postgresql server)

Cressy answered 8/2, 2017 at 16:7 Comment(0)
E
3

¿Are you recently changed the pg_hba.conf? if you did just check for any typo in:

"local" is for Unix domain socket connections only

local all all password

IPv4 local connections:

host all all 127.0.0.1/32 password

IPv6 local connections:

host all all ::1/128 password

Sometimes a simple mistake can give us a headache. I hope this help and sorry if my english is no good at all.

Engedi answered 28/10, 2017 at 16:9 Comment(0)
B
3

This happens when postgres server is not running. Steps to properly install Postgres via Homebrew on MAC :

  1. brew install postgres

  2. initdb /Users/<username>/db -E utf8 [This initializes postgres to use the given directory as the database directory. Normally it is not adviced to use the user directory for database storage. Edit sudoers file to add initdb and similar commands and then run initdb on /usr/local/var/postgres]

  3. pg_ctl -D /Users/<username>/db -l logfile start [After getting success with step 2 it will prompt to run step 3. This command manually starts the server.]

Bonilla answered 4/1, 2018 at 6:57 Comment(0)
S
2

I got this same error. Turns out postgres just wasn't running at all (it is usually always running in the background, but for whatever reason it wasn't today).

If this is the case, just type postgres in the command line of your project directory

Systole answered 10/5, 2014 at 22:13 Comment(0)
S
2

After a tremendous amount of back and forth, it really came down to the pg gem version I was using. On mavericks, pg version 0.15.1 would not connect to port 5432 but version 0.17.1 works just fine - very odd.

Sphenic answered 23/11, 2014 at 19:29 Comment(0)
A
2

For me it was an apache upgrade that caused the problem. I could still run psql in console or call db directly from kdevelop. Also it worked to add "host=localhost" to connection string.

BUT the real problem was that apache had changed to private tmp.

Solution: Update /usr/lib/systemd/system/apache2.service and change PrivateTmp=true to PrivateTmp=false.

I am working on OpenSuse OS, but I guess that something similar could happen on Mac.

Agonize answered 11/10, 2016 at 7:32 Comment(0)
S
2

Had the same problem. Upgrading DB did the trick! postgresql-upgrade-database

Saleswoman answered 15/9, 2020 at 3:0 Comment(0)
S
2

I simply restarted postgres:

brew services restart postgresql

There was no need to remove postmaster.pid.

Shirting answered 23/1, 2021 at 20:58 Comment(0)
R
2

This worked for me: rm /usr/local/var/postgres/postmaster.pid

Russelrussell answered 30/7, 2021 at 14:27 Comment(0)
U
2

If you're on a M1 mac and you installed postgresql with the M1 version of homebrew, this shloud work:

$ rm /opt/homebrew/var/postgres/postmaster.pid
$ brew services restart postgresql
Unison answered 29/8, 2021 at 18:59 Comment(0)
A
1

I found that after installing the latest patch to Postgres 9.6, all my executables (postgres, psql, pg_dump, pg_restore etc) got dropped and I had to relink them. Fortunately Homebrew can do this for you:

brew link --force postgresql # (or in my case, `[email protected]`)
Alderney answered 15/5, 2019 at 3:49 Comment(0)
L
1

Try

sudo systemctl start postgresql@12-main

Here my postgresql version is 12.

Lordling answered 21/4, 2020 at 12:50 Comment(0)
H
1

I was working on a project on my MacBook M1 (Air) and had opened some tabs and suddenly my Postgres server stopped and starting giving the below error :

psql: could not connect to server: Connection failed Is the server running locally and accepting connections on Unix domain socket "/tmp/.s.PGSQL.5432"

I tried many solutions like ;

  1. updating brew and Postgres.
  2. restarting servers.
  3. Tried to kill the process from the command line.

But sadly , nothing worked for me.

And Finally, I thought of restarting my mac . And to my surprise, the postgres server started working pretty much fine the way it used to do before. I think there must have been some problem with the Postgres directories. But I am glad that , it worked.

I recommend you, to go through the above-mentioned options first before restarting.

Thanks.

Hyperaesthesia answered 15/3, 2021 at 5:0 Comment(0)
S
1

For Mac OS Catalina, this worked

$ rm /usr/local/var/postgres/postmaster.pid
$ brew services restart postgresql
Spae answered 26/10, 2021 at 15:48 Comment(0)
I
1

For macOS Monterey, I used brew services restart postgresql.

brew install postgresql
createdb mydb
createdb: error: connection to server on socket "/tmp/.s.PGSQL.5432" failed: No such file or directory
    Is the server running locally and accepting connections on that socket?

brew services restart PostgreSQL
==> Successfully started `postgresql` (label: homebrew.mxcl

Idaline answered 6/12, 2021 at 23:48 Comment(0)
K
1

I solved this problem in ubuntu by simply restaring the computer. The reason of this problem for my case was that the postgres was not stopped gracefully (via sudo kill).

Kropotkin answered 19/9, 2022 at 10:7 Comment(0)
W
0

The Cause

Lion comes with a version of postgres already installed and uses those binaries by default. In general you can get around this by using the full path to the homebrew postgres binaries but there may be still issues with other programs.

The Solution

Run this script:

#!/bin/sh

BREW_POSTGRES_DIR=`brew info postgres | awk '{print $1"/bin"}' | grep "/postgresql/"`
LION_POSTGRES_DIR=`which postgres | xargs dirname`
LION_PSQL_DIR=`which psql | xargs dirname`

sudo mkdir -p $LION_POSTGRES_DIR/archive
sudo mkdir -p $LION_PSQL_DIR/archive

for i in `ls $BREW_POSTGRES_DIR`
do
    if [ -f $LION_POSTGRES_DIR/$i ] 
    then
        sudo mv $LION_POSTGRES_DIR/$i $LION_POSTGRES_DIR/archive/$i
        sudo ln -s $BREW_POSTGRES_DIR/$i $LION_POSTGRES_DIR/$i
    fi
    
    if [ -f $LION_PSQL_DIR/$i ] 
    then
        sudo mv $LION_PSQL_DIR/$i $LION_PSQL_DIR/archive/$i
        sudo ln -s $BREW_POSTGRES_DIR/$i $LION_PSQL_DIR/$i
    fi  
done

Via

http://nextmarvel.net/blog/2011/09/brew-install-postgresql-on-os-x-lion/

Warpath answered 22/7, 2013 at 4:10 Comment(0)
F
0

Just two steps to run the database after the Installation (Before that ensure your logged as postgres user)

Installed-Dirs/bin/postmaster -D Installed-Dirs/pgsql/data

For an example:

[postgres@localhost bin]$ /usr/local/pgsql/bin/postmaster -D /usr/local/pgsql/data

Step-2 : Run psql from the Installed path (To check where you installed '#which postgres' will use to find out the installed location)

[postgres@localhost bin]$ psql 
Fellmonger answered 24/1, 2015 at 10:42 Comment(0)
P
0

I used the Bitnami stack and installed as non-root user psql. On using psql I did receive the mentioned error.

Turns out, there are 2 versions of psql

  1. a root level psql prepackaged in the linux distro. This points to /usr/bin/psql
  2. a non-root level psql installed by the Bitnami stack. This points to /bitnami/postgresql/postgresql/bin/psql

You might want to change the alias of the psql, so that it points to the non-root user.

alias psql='/bitnami/postgresql/postgresql/bin/psql'

The above worked for me on doing psql -U postgres

Plataea answered 9/7, 2017 at 6:38 Comment(0)
K
0

The data directory contains an old postmaster.pid file / The data directory contains an unreadable postmaster.pid file PostgreSQL puts a file named postmaster.pid in the data directory to store the process id of the PostgreSQL server process. If PostgreSQL crashes, this file can contain an old pid that confuses PostgreSQL. You can fix this issue by deleting the postmaster.pid file. However, you must make sure that PostgreSQL is really not running. Open Activity Monitor and make sure that there are no processes named ‘postgres’ or ‘postmaster’.

If you delete the postmaster.pid file while PostgreSQL is running, bad things will happen.

Source: https://postgresapp.com/documentation/troubleshooting.html

Keek answered 10/10, 2017 at 2:21 Comment(0)
T
0

If you are facing the issue while upgrading Postgres (or after upgrading), please follow the steps mentioned here to safely transfer data between versions, which will resolve the issue:

Upgrade PostgreSQL 9.6.5 to 10.0 using Homebrew (macOS)

Timeworn answered 4/12, 2017 at 5:43 Comment(0)
M
0

One of the cause will be make sure the size of the disk is not full execute the command postmaster -D path of the postgres

Munitions answered 16/7, 2018 at 13:58 Comment(0)
F
0

For us, we had to define localhost in the psql command like the following:

psql -h localhost -U postgres

Not sure why the -h doesn't default to localhost...

Flashy answered 13/6, 2019 at 22:29 Comment(6)
I get connection refusedLipstick
Ok. Is your database running on your localhost?Flashy
yes. Trying to configure basic connection with localhostLipstick
Is your server running on port 5432?Flashy
yes.. I checked and the different versions were 10 and 11. I had to run brew postgresql-upgrade-database..Lipstick
You might need to make sure that the security setting are set correctly in the pg_hba.conf file.Flashy
P
0

I had to fix the permissions for a directory:

sudo chmod 0750 /usr/local/var/postgres
Pola answered 26/3, 2020 at 11:32 Comment(0)
G
0

What worked for me I had 2 versions of PostgreSQL while running brew services list

Name           Status  User           Plist
consul         stopped                
docker-machine stopped                
mysql          stopped                
postgresql     started homebrew.mxcl.postgresql.plist
[email protected] stopped                
redis          stopped                
runit          stopped                
unbound        stopped                
vault          stopped 

and just launched the other version brew services start [email protected]

Gadmann answered 26/6, 2020 at 16:17 Comment(0)
C
0

In my case, I was running other project using docker-compose and I had to stop postgresql with sudo service postgresql stop && docker-compose up -d postgres && docker-compose up rails

To fix this error in my new project, I just had to run: sudo service postgresql restart and then it just fixed it.

Celebrated answered 20/7, 2020 at 14:43 Comment(0)
C
0

I have macOS Catalina (10.15.6) and PostgreSQL 12.

When I run brew services start postgresql, brew said it start PostgreSQL without problem, but it does not show when I get ps auxw | grep post.

To solve it, I install Postgres.app from this link, and install and press Init button.

It will find your databases and show it to you.

Colcannon answered 4/9, 2020 at 11:4 Comment(0)
B
0

MacOS Big Sur seemed to renamed the Application\ Support folder to ApplicationSupport. So the updated Path would be:

/Users/<USERNAME>/Library/ApplicationSupport/Postgres/var-10 
(or "/var-<YOUR PG VERSION>")
Behnken answered 15/12, 2020 at 12:21 Comment(0)
H
0

This is how it fixed this error for me on my MacOS (I had used homebrew to install postgres) :

cd /opt/homebrew/var
rm -rf postgres
initdb ./postgres -E utf8
pg_ctl -D ./postgres -l logfile start
rm postgres/postmaster.pid
brew services restart postgresql
createdb $(whoami)
Hepzi answered 29/10, 2021 at 8:14 Comment(0)
C
0

Quickest solution which worked for me:

  1. Find the postgres process that's running already in the port configured for postgres
lsof -i:5432
  1. Find the process id of postgres and kill them
kill -9 <pid>
Commons answered 3/2, 2022 at 15:50 Comment(0)
P
0

I've had same problem but the solutions did not work. I've finally fixed it with updating my postgres db:

brew postgresql-upgrade-database
Petrolic answered 13/7, 2022 at 18:9 Comment(0)
C
0

When I started the course they mentioned I needed to set_pg, so I need to do that every time I create a new terminal window

$set_pg
Chainsmoke answered 25/7, 2022 at 13:25 Comment(0)
U
0

For MacOS Monterey and Postgresql@14 (the path is different):
rm /usr/local/var/postgresql@14/postmaster.pid
brew services restart postgresql

Unsnap answered 13/10, 2022 at 20:39 Comment(0)
M
0

For me, upgrading using brew works fine.

  • Config: Mac OS - Monterey M1
brew postgresql-upgrade-database
Muckraker answered 18/10, 2022 at 12:26 Comment(0)
B
0

I tried almost all of these answers and this is what finally worked for me to get postgres to start

  • tail the logs for postgres.
    • the path needs to be updated depending on where postgres is installed, and your version. I am using postgresql@14 on an m1 Monterey and installed it with homebrew.

    • i finally found the path i needed to look at using this article.

    • tail /opt/homebrew/var/log/[email protected]

output shows this:

2023-02-03 15:33:49.294 CST [82651] FATAL:  could not open directory "pg_notify": No such file or directory
2023-02-03 15:33:49.294 CST [82651] LOG:  database system is shut down
  • go to the / directory and cd opt/homebrew/var/postgresql@14

  • create the missing directory (maybe this is a different directory for you)

    • mkdir pg_notify
  • repeat this process for all missing directories.

    • I needed to mkdir for pg_tblspc, pg_replslot, pg_twophase, pg_stat_tmp, pg_logical/snapshots, pg_logical/mappings, pg_commit_ts, pg_snapshots, & pg_commit_ts but i recommend you specifically run the tail command each time to make sure you are not missing different directories & files than me.

finally after running the tail command repeatedly after creating each missing directory, I got this output.

2023-02-03 15:49:18.909 CST [85772] LOG:  redo done at 0/17211D8 system usage: CPU: user: 0.00 s, system: 0.00 s, elapsed: 0.00 s
2023-02-03 15:49:18.914 CST [85771] LOG:  database system is ready to accept connections
Bendick answered 3/2, 2023 at 22:15 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.