在尝试安装pg gem时找不到'libpq-fe.h标头

dem*_*and 753 postgresql ruby-on-rails pg ruby-on-rails-3 rails-postgresql

我正在使用Ruby on Rails 3.1预发行版.我喜欢使用PostgreSQL,但问题是安装pggem.它给了我以下错误:

$ 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
Run Code Online (Sandbox Code Playgroud)

我该如何解决这个问题?

mu *_*ort 1187

看起来在Ubuntu中头部是libpq-dev包的一部分(至少在以下Ubuntu版本中: 11.04(Natty Narwhal),10.04(Lucid Lynx),11.10(Oneiric Ocelot),12.04(精确穿山甲),14.04(Trusty Tahr)和18.04(Bionic Beaver)):

...
/usr/include/postgresql/libpq-fe.h
...
Run Code Online (Sandbox Code Playgroud)

因此,请尝试libpq-dev为您的操作系统安装或等效:

  • 对于Ubuntu/Debian系统: sudo apt-get install libpq-dev
  • Red Hat Linux(RHEL)系统上:yum install postgresql-devel
  • 对于Mac Homebrew:brew install postgresql
  • 对于Mac MacPorts PostgreSQL:gem install pg -- --with-pg-config=/opt/local/lib/postgresql[version number]/bin/pg_config
  • 对于OpenSuse:zypper in postgresql-devel
  • 对于ArchLinux:pacman -S postgresql-libs

  • 也精确工作. (2认同)
  • 请修改您的答案以包含 `apt-get install postgres-server-dev-{pg.version}` 您的答案不再适用于 Ubuntu 14.04 上的 postgresql 9.4 请参阅:http://stackoverflow.com/a/28837453/75194 (2认同)

iwa*_*bed 157

macOS(以前的Mac OS XOS X)上,使用Homebrew安装正确的标头:

brew install postgresql
Run Code Online (Sandbox Code Playgroud)

然后跑

gem install pg
Run Code Online (Sandbox Code Playgroud)

应该管用.

或者,而不是安装整个postgresql,你可以brew install libpq和导出正确的PATH,并PKG_CONFIG_PATH为在"注意事项"部分解释

  • 如果您还使用Postgres.app,这是否会导致任何问题? (5认同)
  • 或者,只需在mac OSX上运行`brew install libpqxx`即可 (5认同)
  • @RicardoSaporta`libpqxx`安装`postgresql`作为依赖,所以它基本上与`brew install postgresql`相同 (4认同)
  • 对于我运行`brew install postgressql`后我运行`ARCHFLAGS =" - arch x86_64"gem install pg`并且工作正常. (3认同)
  • 您可以`brew install libpq`并导出正确的`PATH`和`PKG_CONFIG_PATH`,而不是安装整个`postgresql`,如'警告'部分所述. (3认同)

Mic*_*ant 118

我也尝试过gem install libpq-dev,但收到了这个错误:

Can't find the 'libpq-fe.h header
*** extconf.rb failed ***
Run Code Online (Sandbox Code Playgroud)

但是我发现安装sudo apt-get(我试图避免使用Ruby on Rails)工作,即

sudo apt-get install libpq-dev
# or
apt-get install postgres-server-dev-{pg.version}
# for postgresql 9.4 on Ubuntu 14.04
Run Code Online (Sandbox Code Playgroud)

然后我就能做到

gem install pg
Run Code Online (Sandbox Code Playgroud)

没有问题.

  • 是的,Ruby pg gem包含了Ubuntu/Debian/...`libpq-dev`包附带的常用PostgreSQL C库. (3认同)

Dav*_*aez 45

我可以用另一种方式解决这个问题.我没有在我的系统上找到该库.因此我使用PostgreSQL主网站上的应用程序安装它.在我的情况下(OS X),我/Library/PostgreSQL/9.1/include/在安装结束后找到了该文件.如果已经安装了PostgreSQL,您可能还有其他位置的文件,具体取决于您的系统.

感谢有关如何为gem安装添加额外路径的链接,我可以使用以下命令将gem指向lib:

export CONFIGURE_ARGS="with-pg-include=/Library/PostgreSQL/9.1/include/"
gem install pg
Run Code Online (Sandbox Code Playgroud)

之后,它工作,因为它现在知道在哪里找到丢失的库.只需用libpq-fe.h的正确位置替换路径即可

  • 大卫的解决方案对我有用.我将libpq-fe.h跟踪到'/Applications/Postgres.app/Contents/Versions/9.3/include'并使用带有所述路径的export命令,然后是'gem install pg'并成功安装了gem. (2认同)
  • 你也可以写成`gem install pg -- with-pg-include=/Library/PostgreSQL/9.1/include/` (2认同)

lfe*_*445 28

找不到libpq-fe.h头文件

我在CentOS 7.0.1406上运行以下命令取得了成功:

~ % psql --version # => psql (PostgreSQL) 9.4.1
yum install libpqxx-devel
gem install pg -- --with-pg-config=/usr/pgsql-9.4/bin/pg_config
Run Code Online (Sandbox Code Playgroud)

或者,您可以将bundler配置为始终pg使用这些选项进行安装(有助于在部署环境中运行bundler),

  • bundle config build.pg --with-pg-config=/usr/pgsql-9.4/bin/pg_config

  • **bundle config build.pg --with-pg-config =/usr/pgsql-9.4/bin/pg_config**在Centos 7上解决我的问题 (3认同)
  • ***捆绑配置build.pg --with-pg-config = / usr / pgsql-10 / bin / pg_config ***如果您使用的是postgresql10 (2认同)

Ari*_*n L 25

对于CentOS 6.4,

yum install postgresql-devel
gem install pg
Run Code Online (Sandbox Code Playgroud)

工作得很好!


小智 18

只是失踪的问题libpq-fe.h

在 ubuntu 上我们只需要运行: sudo apt-get install libpq-dev

上面的命令将安装一个新的软件包libpq-dev,之后您可以再次执行bundle install以恢复软件包安装。


pab*_*rti 16

仅供记录:

使用PostgresApp在OS X中使用Ruby on Rails 4应用程序(在这种情况下需要0.17.1版本 - 一种旧项目):

gem install pg -v '0.17.1' -- --with-pg-config=/Applications/Postgres.app/Contents/Versions/9.3/bin/pg_config
Run Code Online (Sandbox Code Playgroud)


Jie*_*rat 13

在Mac OS X上运行如下:

gem install pg -- --with-pg-config=***/path/to/pg_config***
Run Code Online (Sandbox Code Playgroud)

***/path/to/pg_config*** 是pg_config的路径

  • 已投赞成票。我通过 EnterpriseDB 的 [图形安装程序](http://www.enterprisedb.com/products-services-training/pgdownload#osx) 安装了 Postgresql。然后我需要通过 `sudo find / -name "pg_config"` 找到 pg-config 路径,然后执行 `gem install pg -- --with-pg-config=/Library/PostgreSQL/9.4/bin/pg_config`使用我刚刚发现的路径。 (2认同)

Joh*_*ann 12

在我的情况下它是包postgresql-server-dev-8.4(我在Ubuntu 11.04(Natty Narwhal),64位).


jel*_*der 11

使用Postgres.app的Mac用户的正确答案是针对该libpq软件包提供的内容进行构建.例如,使用9.4版本(撰写本文时的当前版本),您只需要:

export CONFIGURE_ARGS="with-pg-include=/Applications/Postgres.app/Contents/Versions/9.4/include"
gem install pg
Run Code Online (Sandbox Code Playgroud)

这将使您的pggem与您安装的PostgreSQL版本保持同步.在这种情况下,从Homebrew安装东西是一种浪费.


小智 9

我在Amazon Linux上遇到了同样的问题.我可以找到标题libpq-fe.h,但不知何故它不起作用.

它来自通过机器上的不同用户安装的不同版本的软件包.安装了PostgreSQL 9.2和PostgreSQL 9.3.因此,在包含库之前,请确保您的PostgreSQL版本.

对我来说,魔术命令行是:

sudo yum install postgresql93 postgresql93-server postgresql93-libs postgresql93-contrib postgresql93-devel
Run Code Online (Sandbox Code Playgroud)

资料来源:安装PostgreSQL 9.3,PostGIS 2.1和与Yum一起使用pgRouting的几乎白痴指南


Mic*_* A. 9

对于没有安装 PostgreSQL 服务器的MacOS

brew install libpq
gem install pg -- --with-pg-config="/usr/local/Cellar/libpq/9.6.6/bin/pg_config"
Run Code Online (Sandbox Code Playgroud)


Vin*_*ond 8

任何基于Debian的发行版(包括Ubuntu)的更一般的答案如下.首先,安装apt-file以root身份运行的包:

apt-get install apt-file
Run Code Online (Sandbox Code Playgroud)

这允许您搜索包含文件的包.然后,使用更新其数据库

apt-file update
Run Code Online (Sandbox Code Playgroud)

(这可以作为普通用户运行).然后,使用以下方法查找缺少的标题:

apt-file search libpq-fe.h
Run Code Online (Sandbox Code Playgroud)

在我的机器上,这给出了:

libpq-dev: /usr/include/postgresql/libpq-fe.h
postgres-xc-server-dev: /usr/include/postgres-xc/server/gtm/libpq-fe.h
Run Code Online (Sandbox Code Playgroud)

你去!


小智 8

在 Ubuntu 上,安装“libpq-dev”来解决这个问题。

sudo apt-get install libpq-dev
Run Code Online (Sandbox Code Playgroud)


yoo*_*nes 8

在 debian bullseye 上,现有的答案都没有为我解决这个问题。

如果它可以帮助与我具有相同配置的人:

  1. 使用 PostgreSQL 的 apt 存储库:https://wiki.postgresql.org/wiki/Apt
  2. sudo apt-get update && sudo apt-get dist-upgrade(将 PostgreSQL 从 v13 升级到 v14)
  3. sudo apt-get install libpq-dev
  4. gem install pg或者bundle install


A. *_*sas 7

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

如果您从官方存储库安装 postgresql,您将有多个版本无法解决问题,因此实际上需要尝试一下它需要哪个版本。


小智 7

在MacOS M1上解决:

brew install libpq
Run Code Online (Sandbox Code Playgroud)

然后我放入我的路径

echo 'export PATH="/opt/homebrew/opt/libpq/bin:$PATH"' >> ~/.zshrc
Run Code Online (Sandbox Code Playgroud)

和:

gem install pg
Run Code Online (Sandbox Code Playgroud)

  • echo 之后,您还需要 source ~/.zshrc (2认同)

mwa*_*her 6

我在使用 Postgresql 9.6 时遇到了这个问题。我能够通过执行以下操作来修复它:

brew upgrade postgresql@9.6
brew link postgresql@9.6 --force
gem install pg
Run Code Online (Sandbox Code Playgroud)


小智 6

我的 Fedora 30 解决方案:

sudo dnf install /usr/include/libpq-fe.h
Run Code Online (Sandbox Code Playgroud)


ras*_*som 5

我在 Mac OS 上遇到了同样的问题,但我通过在终端中使用以下命令轻松安装了 PostgreSQL gem:

ARCHFLAGS="-arch x86_64" gem install pg
Run Code Online (Sandbox Code Playgroud)

(我首先安装了 PostgreSQL brew install postgresql。)


Cyn*_*hez 5

我找到了这个答案,它是唯一对我有用的答案(Mac OS)——经过大约两天的研究:

$ sudo su

$ env ARCHFLAGS="-arch x86_64" gem install pg

Building native extensions.  This could take a while...
Successfully installed pg-0.11.0
1 gem installed
Installing ri documentation for pg-0.11.0...
Installing RDoc documentation for pg-0.11.0...
Run Code Online (Sandbox Code Playgroud)

请参阅堆栈溢出问题无法找到 PostgreSQL 客户端库 (libpq)


Mar*_*her 5

我最近升级到Mac OS X v10.10 (Yosemite),但在构建 gem 时遇到了困难pg

报告的错误是典型的:

Using config values from /usr/local/bin/pg_config
checking for libpq-fe.h... *** extconf.rb failed ***
Run Code Online (Sandbox Code Playgroud)

我的解决方案是gem uninstall pg然后bundle update pg用最新的替换宝石。brew update; brew upgrade我确实在 Yosemite 安装后运行以获取我之前安装的软件包的最新版本。


Mar*_*rio 5

在 Mac 上,我使用以下代码解决了它:

gem install pg -v '0.18.4' -- --with-pg-config=/Applications/Postgres.app/Contents/Versions/9.4/bin/pg_config
Run Code Online (Sandbox Code Playgroud)


小智 5

我通过在 MacOS Ventura 上创建符号链接解决了这个问题

如果 postgresql 已经安装;

brew link postgresql@12 --force
Run Code Online (Sandbox Code Playgroud)

该命令将给出如下目录路径

If you need to have this software first in your PATH instead consider running:
  echo 'export PATH="/opt/homebrew/opt/postgresql@12/bin:$PATH"' >> ~/.zshrc
Run Code Online (Sandbox Code Playgroud)

您需要将 zsh 或 bash_profile 添加到您的计算机,无论您使用的是哪一个