我使用的是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 6.5(挤压)下,我创建了一个文件:

$ sudo touch /etc/profile.d/psql.sh

与内容:

pathmunge /usr/pgsql-9.3/bin

注意这里,你应该用pg_config文件设置你的PostgreSQL路径。你可以通过以下命令找到:

$ sudo find / -iname pg_config

保存文件:

$ sudo chmod +x /etc/profile.d/ruby.sh

然后再试着执行你的命令。

注意:任何时候你改变Bash配置-改变概要文件。d配置-您应该重新加载Bash。

其他回答

在Debian 7.0, 64位(Wheezy)上,只需运行:

sudo apt-get install libpq-dev

成功安装libpq-dev后,运行:

bundle install

只有卸载(sudo apt-get purge) libpq-dev并重新安装它才对我有用。

在Fedora 32上,我通过专门安装libpq5-devel解决了同样的问题。

如果你从官方存储库安装postgresql,你会有几个版本都不能解决这个问题,所以这真的是一个尝试它需要哪个版本的问题。

我已经尝试了所有的解决方案,但只在命令下工作

pip install psycopg2-binary

Mac用户使用Postgres的正确答案。应用程序是根据该包提供的libpq构建的。例如,对于9.4版本(撰写本文时的最新版本),您所需要的是:

export CONFIGURE_ARGS="with-pg-include=/Applications/Postgres.app/Contents/Versions/9.4/include"
gem install pg

这将使你的pg gem与你安装的PostgreSQL版本保持同步。在这种情况下,安装Homebrew软件是一种浪费。