Cannot install pg gem in Mavericks with Postgres.app

34,936

Solution 1

You probably have the wrong path for --with-pg-config, check if it's actually there.

You can find the correct path to pg_config with:

find /Applications -name pg_config

In the latest Postgres.app Version the path is:

gem install pg -- --with-pg-config=/Applications/Postgres.app/Contents/Versions/9.5/bin/pg_config

Solution 2

In my case (running Postgres.app v9.3.4.2) it only seemed to work when prepending the environment architecture flags:

env ARCHFLAGS="-arch x86_64" gem install pg -- \
--with-pg-config=/Applications/Postgres.app/Contents/Versions/9.3/bin/pg_config 

Solution 3

Being on a brand new mac, here's what I had to do:

  1. Install Xcode tools from the app store
  2. Open Xcode tools and accept the license
  3. Now run (hopefully a future-proofed command):

    version=$(ls /Applications/Postgres.app/Contents/Versions/ | tail -1) gem install pg -- --with-pg-config=/Applications/Postgres.app/Contents/Versions/$version/bin/pg_config .

If you have trouble, you can troubleshoot a bit by checking out the actual error in the mkmf.log which you can find by running (if using rvm):

cd ~/.rvm ; find . -name mkmf.log | grep pg

Solution 4

I was able to install pg with this command

    gem install pg -- --with-pg-config=/Library/PostgreSQL/9.3/bin/pg_config

I found my path by running

    sudo find / -name "pg_config"

and I Successfully installed pg-0.17.1

Solution 5

adding the postgress bin dir to the path also does the trick. just add the bin to the pat like this. with recent installs the latest symbolic link makes sure that this path should be 'stable' for future version upgrades.

export PATH=$PATH:/Applications/Postgres.app/Contents/Versions/latest/bin
Share:
34,936
blundin
Author by

blundin

Christ follower, husband, storyteller, writer, and IT strategist

Updated on July 05, 2022

Comments

  • blundin
    blundin almost 2 years

    I am trying to install the pg gem for use with Postgres.app on my local machine. I am running Mavericks.

    Postgres.app is installed and running fine, but I cannot get the gem to work. I've done the following:

    1. Used the command 'env ARCHFLAGS="-arch x86_64" gem install pg -- --with-pg-config=/Applications/Postgres.app/Contents/MacOS/bin/pg_config' from the Postgres.app documentation
    2. Updated Homebrew and installed the Apple GCC 4.2
    3. Installed the Xcode developer tools
    4. Updated my $PATH to reference both the Postgres.app bin and lib directories

    All with no success. Here is the specific error message I receive:

    Building native extensions with: '--with-pg-config=/Applications/Postgres.app/Contents/MacOS/bin/pg_config'
    This could take a while...
    ERROR:  Error installing pg:
        ERROR: Failed to build gem native extension.
    
        /Users/Brian/.rvm/rubies/ruby-2.0.0-p353/bin/ruby extconf.rb --with-pg-config=/Applications/Postgres.app/Contents/MacOS/bin/pg_config
    Using config values from /Applications/Postgres.app/Contents/MacOS/bin/pg_config
    sh: /Applications/Postgres.app/Contents/MacOS/bin/pg_config: No such file or directory
    sh: /Applications/Postgres.app/Contents/MacOS/bin/pg_config: No such file or directory
    checking for libpq-fe.h... no
    Can't find the 'libpq-fe.h header
    *** extconf.rb failed ***
    Could not create Makefile due to some reason, probably lack of necessary
    libraries and/or headers.  Check the mkmf.log file for more details.  You may
    need configuration options.
    
    Provided configuration options:
        --with-opt-dir
        --with-opt-include
        --without-opt-include=${opt-dir}/include
        --with-opt-lib
        --without-opt-lib=${opt-dir}/lib
        --with-make-prog
        --without-make-prog
        --srcdir=.
        --curdir
        --ruby=/Users/Brian/.rvm/rubies/ruby-2.0.0-p353/bin/ruby
        --with-pg
        --without-pg
        --with-pg-config
        --with-pg-dir
        --without-pg-dir
        --with-pg-include
        --without-pg-include=${pg-dir}/include
        --with-pg-lib
        --without-pg-lib=${pg-dir}/
    

    I'd appreciate any help you can offer. Thanks!

  • blundin
    blundin over 10 years
    Embarrassingly enough, that's it. After upgrading to the latest version of Postgres.app the path changed and I did not notice. Thanks!
  • JD Maresco
    JD Maresco over 10 years
    This was it for me too!
  • Gabriel Osorio
    Gabriel Osorio about 10 years
    Thanks for this! For some reason, on my installation I had to run $ gem install pg -- --with-pg-config=/Applications/Postgres.app/Contents/Version‌​s/9.3/bin/pg_config .
  • Sean
    Sean almost 10 years
    Newer Postgres.app installs might need you to use this command gem install pg -- --with-pg-config=/Applications/Postgres.app/Contents/MacOS/b‌​in/pg_config .
  • Ege Ersoz
    Ege Ersoz almost 10 years
    @Sean: There is no 'bin' folder under Contents/MacOS on my system. Just a postgres executable file. The one Gabriel Osorio mentioned seems to be the right path (as of 9.3.4.1).
  • Michael Shimmins
    Michael Shimmins almost 10 years
    This is the correct path for the latest version of Postgres App.
  • ovatsug25
    ovatsug25 almost 10 years
    does anybody know why we need the '--' before the option?
  • superluminary
    superluminary almost 10 years
    This does solve the issue, but it means installing a whole other postgres just for that one header file.
  • peterhurford
    peterhurford almost 10 years
    For further reference, I just downloaded Postgres.app yesterday and my pg_config is located at Applications/Postgres.app/Contents/Versions/9.3/bin/pg_confi‌​g. One should be able to figure out where their pg_config is by using ls to look through the Applications/Postgres.app/Contents directory. See if you have /Contents/MacOS or /Contents/Versions...
  • peterhurford
    peterhurford almost 10 years
    You can put the ARCHFLAGS in your .bash_profile (or equivalent) by including export ARCHFLAGS="-arch x86_64". For me, without this, PG doesn't work.
  • peterhurford
    peterhurford almost 10 years
    Yeah, don't do this if you're using Postgres.app. In fact, you should run brew uninstall postgres if it's there.
  • Nick Ginanto
    Nick Ginanto over 9 years
    every new ruby version I keep using this answer! thanks a million!
  • BAR
    BAR over 9 years
    The -- -- is important, must be a bug in pg.
  • BAR
    BAR over 9 years
    The -- -- is important, must be a bug in pg.
  • Tom De Leu
    Tom De Leu over 9 years
    @BAR: no, the "--" is used to tell "gem install" to stop processing options, and anything after that (like "--with-pg-config") are build flags for how to build the specific gem. Check guides.rubygems.org/command-reference/#gem-install
  • Tim Scollick
    Tim Scollick almost 9 years
    It looks like Postgres.app has been bumped up a version. I had to use gem install pg -- --with-pg-config=/Applications/Postgres.app/Contents/Version‌​s/9.4/bin/pg_config
  • Powers
    Powers almost 9 years
    It's easier to find the pg_config file with this command, so you don't have to search through all the files on your computer: $ find /Applications/Postgres.app/ -name "pg_config" Searching through /Library/ would work on your machine.
  • Edward
    Edward over 8 years
    Why is the extra set of -- needed for pass in arguments to gem install pg?
  • Christoph Geschwind
    Christoph Geschwind almost 8 years
    Thanks, prepending this to gem install worked fine: PATH=$PATH:/Applications/Postgres.app/Contents/Versions/late‌​st/bin gem install pg
  • Chad Gorshing
    Chad Gorshing over 7 years
    I'm using bundler and it took me a bit to figure out how to add this to a bundle command. You can use bundle config pg.build "....", see more at bundler.io/v1.3/man/bundle-config.1.html
  • Mig
    Mig over 2 years
    "latest" work as a version now, there is a symlink. That being said, I have a new M1 ship Mac and this does not work for me, I don't know why. I inspect the path and everything is there. Maybe that's because it does not expect a dylib for libpq.