我使用的是Ruby on Rails 3.1预版本。我喜欢使用PostgreSQL,但问题是安装pg gem。它给了我以下错误:

$ gem install pg
Building native extensions.  This could take a while...
ERROR:  Error installing pg:
    ERROR: Failed to build gem native extension.

        /home/u/.rvm/rubies/ruby-1.9.2-p0/bin/ruby extconf.rb
checking for pg_config... no
No pg_config... trying anyway. If building fails, please try again with
 --with-pg-config=/path/to/pg_config
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
    --without-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=/home/u/.rvm/rubies/ruby-1.9.2-p0/bin/ruby
    --with-pg
    --without-pg
    --with-pg-dir
    --without-pg-dir
    --with-pg-include
    --without-pg-include=${pg-dir}/include
    --with-pg-lib
    --without-pg-lib=${pg-dir}/lib
    --with-pg-config
    --without-pg-config
    --with-pg_config
    --without-pg_config
    Gem files will remain installed in /home/u/.rvm/gems/ruby-1.9.2-p0/gems/pg-0.11.0 for inspection.
    Results logged to /home/u/.rvm/gems/ruby-1.9.2-p0/gems/pg-0.11.0/ext/gem_make.out

我怎么解决这个问题?


当前回答

在CentOS上,我使用下面的命令安装libpq-dev包

yum install postgresql-devel

执行gem install pg返回与“No pg_config…”不管怎样。如果构建失败,请使用——with-pg-config=/path/to/pg_config"再试一次。

安装宝石如下解决了我的问题

gem install pg -- --with-pg-config=/usr/pgsql-x.x/bin/pg_config

其他回答

Ubuntu 20.04.1 LTS,这似乎对我有用:

sudo apt-get install ruby ruby-dev libpqxx-dev libpq-fe-dev libpq-dev 
sudo gem install pg -- --with-pg-config=/usr/include/postgresql/pg_config --with-pg-include=/usr/include/postgresql/

对于Mac OS X,只需安装https://postgresapp.com/,并遵循命令行部分和ruby的步骤

sudo mkdir -p /etc/paths.d &&
echo /Applications/Postgres.app/Contents/Versions/latest/bin | sudo tee /etc/paths.d/postgresapp

然后

sudo ARCHFLAGS="-arch x86_64" gem install pg

只是缺少libpq-fe.h的问题

在ubuntu上,我们只需要运行: Sudo apt-get安装libpq-dev

上面的命令将安装一个新的包libpq-dev,之后你可以再次执行bundle install来继续你的包安装。

在macOS(以前的Mac OS X和OS X)上,使用Homebrew安装正确的头文件:

brew install postgresql

然后运行

gem install pg

应该工作。

或者,不安装整个postgresql,你可以酿造安装libpq并导出正确的PATH和PKG_CONFIG_PATH,如“警告”部分所述

郑重声明:

Ruby on Rails 4应用程序在OS X与PostgresApp(在这种情况下需要0.17.1版本-有点老项目):

gem install pg -v '0.17.1' -- --with-pg-config=/Applications/Postgres.app/Contents/Versions/9.3/bin/pg_config