Не удается найти заголовок '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 ]

1133 голосов
/ 18 мая 2011

В Ubuntu похоже, что заголовок является частью libpq-dev пакета (по крайней мере, в следующих версиях Ubuntu: 11.04 (Natty Narwhal), 10.04 (Lucid Lynx), 11.10 (Oneiric Ocelot), 12.04 (Precise Pangolin), 14.04 (Trusty Tahr) и 18.04 (Bionic Beaver)):

...
/usr/include/postgresql/libpq-fe.h
...

Так что попробуйте установить libpq-dev или его эквивалент для вашей ОС:

147 голосов
/ 10 декабря 2013

На macOS (ранее Mac OS X и OS X ), используйте Homebrew для установки соответствующих заголовков:

brew install postgresql

, а затем запуск

gem install pg

должен работать.

В качестве альтернативы, вместо установки всего postgresql, вы можете brew install libpq и экспортировать правильный PATHи PKG_CONFIG_PATH, как объяснено в разделе «Предостережения»

116 голосов
/ 17 января 2012

Я также пытался сделать gem install libpq-dev, но я получил эту ошибку:

Can't find the 'libpq-fe.h header
*** extconf.rb failed ***

Однако я обнаружил, что установка с 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

тогда я смог сделать

gem install pg

без проблем.

44 голосов
/ 12 января 2012

Я мог бы решить это по-другому. Я не нашел библиотеку в моей системе. Таким образом, я установил его с помощью приложения с основного сайта PostgreSQL. В моем случае (OS X) я обнаружил файл в /Library/PostgreSQL/9.1/include/ после завершения установки. У вас также может быть файл в другом месте, в зависимости от вашей системы, если у вас уже установлен PostgreSQL.

Благодаря этой ссылке на как добавить дополнительный путь для установки гема , я мог бы указать гем на библиотеку с помощью этой команды:

export CONFIGURE_ARGS="with-pg-include=/Library/PostgreSQL/9.1/include/"
gem install pg

После этого он работает, потому что теперь знает, где найти недостающую библиотеку. Просто замените путь на правильное место для вашего libpq-fe.h

28 голосов
/ 02 марта 2015

Не удается найти заголовок 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

В качестве альтернативы , вы можете настроить упаковщик так, чтобы он всегда устанавливал pg с этими параметрами (полезно для запуска упаковщика в средах развертывания),

  • bundle config build.pg --with-pg-config=/usr/pgsql-9.4/bin/pg_config
23 голосов
/ 10 апреля 2013

Для CentOS 6,4,

yum install postgresql-devel
gem install pg

работал хорошо!

15 голосов
/ 19 октября 2015

Только для записи:

Приложение 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
12 голосов
/ 18 июля 2011

В моем случае это был пакет postgresql-server-dev-8.4 (я на Ubuntu 11.04 (Natty Narwhal), 64 бита).

12 голосов
/ 08 января 2014

В Mac OS X запустите так:

gem install pg -- --with-pg-config=***/path/to/pg_config***

***/path/to/pg_config*** - это путь к pg_config

11 голосов
/ 22 января 2015

Правильный ответ для пользователей Mac с Postgres.app - использовать libpq, поставляемый с этим пакетом. Например, с выпуском 9.4 (текущим на момент написания этой статьи) все, что вам нужно:

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

Это обеспечит синхронизацию вашего драгоценного камня pg именно с той версией PostgreSQL, которую вы установили. Установка чего-либо из Homebrew в этом случае - пустая трата времени.

...