Не могу найти 'libpq-fe.H заголовок при попытке установить PG gem

Я использую версию Ruby on Rails 3.1 pre. Мне нравится использовать 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

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

30 ответов


похоже, что в Ubuntu этот заголовок является частью libpq-dev пакета (по крайней мере, в следующих версиях Ubuntu: 11.04 (Натти Нарвал), 10.04 (Lucid Lynx),11.10 (Онейроидного Оцелота), 12.04 (Точный Панголин), 14.04 (надежный Тар) и 18.04 (Bionic Beaver)):

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

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

  • для систем Ubuntu:sudo apt-get install libpq-dev
  • On Red Hat Linux (RHEL) системы:yum install postgresql-devel
  • Для Mac доморощенного: 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

On macOS (ранее Mac OS X и OS X), используйте доморощенного установить правильные заголовки:

brew install postgresql

и потом работает

gem install pg

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


Я также пытался сделать 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

без проблем.


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

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

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

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


не удается найти 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

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

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

на CentOS 6.4,

yum install postgresql-devel
gem install pg

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


на Mac OS X работает следующим образом:

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

***/path/to/pg_config*** путь к pg_config


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


просто для протокола:

приложение 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

правильный ответ для пользователей 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 в этом случае является пустой тратой времени.


у меня была такая же проблема на Amazon Linux. Я мог бы найти заголовок libpq-fe.h, но почему-то не работал.

Он пришел из разных версий пакетов, которые были установлены через разных пользователей на машине. Были установлены PostgreSQL 9.2 и PostgreSQL 9.3. Итак, убедитесь, что ваша версия PostgreSQL перед включением библиотек.

для меня волшебная командная строка была:

sudo yum install postgresql93 postgresql93-server postgresql93-libs postgresql93-contrib postgresql93-devel

источник: почти идиотское руководство по установите PostgreSQL 9.3, PostGIS 2.1 и pgRouting с помощью Yum


более общий ответ для любого дистрибутива на основе Debian (который включает Ubuntu) следующий. Во-первых, установите apt-file пакет работает как root:

apt-get install apt-file

Это позволяет искать пакеты, содержащие файл. Затем обновите свою базу данных с помощью

apt-file update

(Это можно запустить как обычный пользователь). Затем найдите отсутствующий заголовок, используя:

apt-file search libpq-fe.h

на моей машине, это дает:

libpq-dev: /usr/include/postgresql/libpq-fe.h
postgres-xc-server-dev: /usr/include/postgres-xc/server/gtm/libpq-fe.h

там вы идете !


у меня была такая же проблема в Mac OS, но я легко установил PostgreSQL gem, используя следующее в терминале:

ARCHFLAGS="-arch x86_64" gem install pg

(Я установил PostgreSQL сначала с brew install postgresql.)


Я нашел этот ответ, и это был единственный, который работал для меня (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...

см. вопрос переполнения стека не удается найти клиентскую библиотеку PostgreSQL (libpq).


недавно я обновился до Mac OS X v10.10 (Йосемити) и испытывал трудности с построением pg камень.

ошибка типичная:

Using config values from /usr/local/bin/pg_config
checking for libpq-fe.h... *** extconf.rb failed ***

моим решением было gem uninstall pg а то bundle update pg заменить гем с последними. Я бежал brew update; brew upgrade после установки Yosemite, чтобы получить последние версии пакетов, которые я установил ранее.


на Mac я решил его с помощью этого кода:

gem install pg -v '0.18.4' -- --with-pg-config=/Applications/Postgres.app/Contents/Versions/9.4/bin/pg_config

на CentOS,я установил libpq-dev package используя следующую команду

yum install postgresql-devel

выполнения gem install pg возвращает ту же ошибку, что и "No pg_config... trying anyway. If building fails, please try again with --with-pg-config=/path/to/pg_config".

установка Gem, как ниже решена моя проблема

gem install pg -- --with-pg-config=/usr/pgsql-x.x/bin/pg_config

Я запускаю Postgres.app на Mac, и я должен был

export PATH=$PATH:/Applications/Postgres.app/Contents/Versions/9.4/bin

первый. Тогда

bundle install

работал для меня.


на в macOS без установки сервера PostgreSQL:

brew install libpq
gem install pg -- --with-pg-config="/usr/local/Cellar/libpq/9.6.6/bin/pg_config"

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

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


On Debian 7.0, 64-бит (хриплый), просто запустите:

sudo apt-get install libpq-dev

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

bundle install

под CentOS 6.5 (Squeeze) я создал файл:

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

содержание:

pathmunge /usr/pgsql-9.3/bin

Примечание здесь, вы должны установить свой путь PostgreSQL с файлом pg_config. Вы можете найти это с помощью команды:

$ sudo find / -iname pg_config

сохраните файл:

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

и попробуйте снова выполнить команду.

Примечание: в любое время можно изменить Баш настройки - изменить профиль.D конфигурация - вы должны перезагрузить Bash.


расположение 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, будет находиться в том же каталоге, что


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

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

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

  2. затем brew install postgresql опять

  3. brew link postgresql

  4. gem install pg


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

мое решение было такое:

CONFIGURE_ARGS="with-pg-include=/usr/local/opt/postgresql@9.4/include/" bundle install

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

sudo apt-get install libpq-dev

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

apt-get install postgresql9.5-devel

Я решил эту установку пакета "postgresql-common". Этот пакет предоставляет pg_config binary, который, скорее всего, вам не хватало.


У меня была аналогичная проблема, и это фиксированная это для меня:

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


On OS X 10.9 (Маверикс), Я brew-installed postgresql, и мне тогда пришлось rvm reinstall мой Рубин. Я счастлив сейчас:)