Не удается найти заголовок 'libpq-fe.h при попытке установить гем pg - PullRequest
715 голосов
/ 18 мая 2011

Я использую предварительную версию Ruby on Rails 3.1. Мне нравится использовать PostgreSQL, но проблема заключается в установке гема pg. Это дает мне следующую ошибку:

$ 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

Как мне решить эту проблему?

Ответы [ 39 ]

2 голосов
/ 06 сентября 2013

Во FreeBSD (9.1) необходимым пакетом является / usr / ports / database / postgresql-server *, который при установке также установит требуемый заголовочный файл, что приводит к сбою установки gem для "pg"Этот ответ помог мне найти решение, но разница в именах пакетов потребовала небольшого поиска.

Надеюсь, это поможет кому-то избежать царапин при поиске пакета "-dev" в системе FreeBSD!

2 голосов
/ 12 ноября 2017

В Ubuntu установите «libpq-dev», чтобы избавиться от этой проблемы.

sudo apt-get install libpq-dev
2 голосов
/ 19 февраля 2014

Вкл. Debian 7.0, 64-разрядный (Wheezy), просто запустите:

sudo apt-get install libpq-dev

После успешной установки libpq-dev выполните:

bundle install
2 голосов
/ 26 января 2015

Расположение libpq-fe.h зависит от того, где находится ваша установка PostgreSQL (зависит от того, как вы ее установили). Используйте locate (http://en.wikipedia.org/wiki/Locate_%28Unix%29), чтобы найти файл libpq-fe.h на вашем компьютере. Если он существует, он будет находиться в каталоге include вашей установки PostgreSQL.

$ locate libpq-fe.h
/Library/PostgreSQL/9.1/include/libpq-fe.h

Каталог bin, содержащий pg_config, будет находиться в том же каталоге, что и каталог include. Как показывает ошибка, используйте параметр --with-pg-config для установки гема:

$ gem install pg --with-pg-config="/Library/PostgreSQL/9.1/bin/pg_config"

Обратите внимание, что вам может потребоваться запустить updatedb, если вы никогда не использовали locate или если вы не обновлялись после установки PostgreSQL.

2 голосов
/ 05 января 2018

У меня была эта проблема с Postgresql 9.6. Я смог это исправить, выполнив:

brew upgrade postgresql@9.6
brew link postgresql@9.6 --force
gem install pg
2 голосов
/ 05 апреля 2017

У меня только что было это на OSX под управлением brew и postgres@9.4.

Мое исправление было таким:

CONFIGURE_ARGS="with-pg-include=/usr/local/opt/postgresql@9.4/include/" bundle install
2 голосов
/ 15 февраля 2016

Я наконец решил эту проблему, но не используя ранее описанные методы.

Используя brew install postgresql, я обнаружил, что он уже установлен, но не связан.

  1. Узнайте, где установлен PostgreSQL, и удалите его,

  2. Затем brew install postgresql снова,

  3. brew link postgresql

  4. gem install pg

1 голос
/ 02 марта 2016

Для AltLinux должен быть установлен пакет postgresqlx.x-devel (в моем случае postgresql9.5-devel):

apt-get install postgresql9.5-devel
1 голос
/ 07 января 2013

Я решил эту проблему, установив пакет 'postgresql-common'.Этот пакет содержит двоичный файл pg_config, который, скорее всего, вы пропустили.

1 голос
/ 07 февраля 2014

У меня была похожая проблема, и это исправило ее для меня:

gem install do_postgres -- --with-pgsql-server-dir=/Applications/Postgres.app/Contents/MacOS --with-pgsql-server-include=/Applications/Postgres.app/Contents/MacOS/include/server

Источник:

https://gist.github.com/oisin/6562181

...