我正在尝试为Ruby安装PostgreSQL的pg gem。

我发出了以下命令:

gem install pg

我使用RVM安装Ruby 1.9.2。

上面的命令显示了以下错误。

错误是:

Building native extensions.  This could take a while...

ERROR:  Error installing pg:

ERROR: Failed to build gem native extension.

/home/User/.rvm/rubies/ruby-1.9.2-preview3/bin/ruby extconf.rb

checking for pg_config... yes
checking for libpq-fe.h... yes
checking for libpq/libpq-fs.h... yes
checking for PQconnectdb() in -lpq... no
checking for PQconnectdb() in -llibpq... no
checking for PQconnectdb() in -lms/libpq... no
Can't find the PostgreSQL client library (libpq)

*** 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/User/.rvm/rubies/ruby-1.9.2-preview3/bin/ruby
 --with-pg
 --without-pg
 --with-pg-config
 --without-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}/lib
 --enable-static-build
 --disable-static-build
 --with-pqlib
 --without-pqlib
 --with-libpqlib
 --without-libpqlib
 --with-ms/libpqlib
 --without-ms/libpqlib

Gem files will remain installed in /home/user/.rvm/gems/ruby-1.9.2-preview3/gems/pg-0.9.0 for inspection.

Results logged to /home/user/.rvm/gems/ruby-1.9.2-preview3/gems/pg-0.9.0/ext/gem_make.out

我不知道是什么错误…


当前回答

另一种选择是使用在Linux和macOS上运行的Homebrew来安装支持库:

酿造安装libpq

then

酿造链接libpq—force

(——force选项是必需的,因为它与postgres公式冲突。)

其他回答

需要添加包

sudo apt-get install libpq-dev

在RoR中安装pg gem

对于那些试图安装Redmine的人来说,在尝试了以上所有方法后,我错过了sudo apt-get install ruby-all-dev。

初始错误为mkmf。Rb无法在/usr/lib/ruby/include/ruby.h找到ruby的头文件

我在Ubuntu 12.10上运行这个命令:

apt-get install libpq-dev

帮助我-之后运行gem安装pg -v“0.14.1”,现在一切都很好

这个问题的另一个解决方案是使用Homebrew/linuxbrew安装PostgreSQL:

编译安装postgresql

作为一种习惯,我不喜欢使用sudo,除非我不得不。

在阅读和阅读了2天,并尝试了其他笔记中发现的许多东西之后,下面这一行对我来说是Ubuntu Lucid 10.04混合了一些Maverick包和RVM (ruby 1.9.2-p290, RVM 1.10.2 rubygems 1.8.15, rails 3.0.1, postgres 8.4.10)的治愈方法:

gem install pg  --   --with-pg-lib=/usr/lib   

结果:

Building native extensions.  This could take a while...  
Successfully installed pg-0.13.1  
1 gem installed  
Installing ri documentation for pg-0.13.1...  
Installing RDoc documentation for pg-0.13.1...  

{耶-终于成功了}!! 注意,在我的Ubuntu / Postresql安装中,运行pg_config的输出在LIBS变量中缺少项-lpq !!

为什么在某些地方从pq切换到pg——新手会感到困惑??

我仍然不明白的是——and——with(选项的双重集合 但我已经力不从心了