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


790

Я использую предварительную версию 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

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


можете ли вы доказать, что у вас установлен pg?
затем

Ответы:


1247

В 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 (Бионический Бобр)):

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

Так что попробуйте установить 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

1
не работал для меня на Ubuntu 11.04durrantm@castleLinux2011:~/Dropbox_not_syncd/webs/3/linker$ gem install libpq-dev ERROR: Could not find a valid gem 'libpq-dev' (>= 0) in any repository durrantm@castleLinux2011:~/Dropbox_not_syncd/webs/3/linker$
Майкл Даррант

1
Если вам необходимо установить библиотеку javascript ... gem install 'execjs' и gem install 'therubyracer'
Ник Вудхамс

@TravisR: Спасибо за обновление, я просто превратил его в вики сообщества, чтобы всем было проще его обновлять.
мю слишком коротка

Я использую Ubuntu 12.10, я не могу установить pg gem после установки libpq-dev
vedarthk

2
Пересмотрите свой ответ, чтобы включить в него. apt-get install postgres-server-dev-{pg.version} Ваш ответ больше не работает с postgresql 9.4 в Ubuntu 14.04. См .: stackoverflow.com/a/28837453/75194
Райан Раух,

169

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

brew install postgresql

а затем работает

gem install pg

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

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


5
Это вызывает какие-либо проблемы, если вы также используете Postgres.app?
иконоборчество

3
Для меня после бега brew install postgressqlя бегу ARCHFLAGS="-arch x86_64" gem install pgи отлично работает.
общая дука

5
В качестве альтернативы достаточно просто запустить brew install libpqxxна Mac OSX
Рикардо Сапорта

4
@RicardoSaporta libpqxxустанавливается postgresqlкак зависимость, так что по сути это то же самое, что иbrew install postgresql
Troggy

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

118

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

без проблем.


3
Да, гем Ruby pg оборачивает обычные библиотеки PostgreSQL C, которые поставляются с libpq-devпакетом Ubuntu / Debian / ....
мю слишком коротко

46

Я мог бы решить это по-другому. Я не нашел библиотеку в моей системе. Таким образом, я установил его с помощью приложения с основного сайта 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

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


2
Решение Дэвида сработало для меня. Я отследил libpq-fe.h до «/Applications/Postgres.app/Contents/Versions/9.3/include» и использовал команду экспорта с указанным путем, за которым следовали «gem install pg» и гем, успешно установленный.
Райан Спирс

Спасибо за это, работал для меня, используя:export CONFIGURE_ARGS="with-pg-include=/usr/local/Cellar/postgresql/9.3.1/include/"
Brookr

1
Использование Postgresql 9.3 на CentOS 6 я решил это символическую ссылку на pg_*скрипты в $ PATH следующим образом: ln -s /usr/pgsql-9.3/bin/p* /usr/local/bin. Я установил postgres 9.3 примерно так:yum install http://yum.postgresql.org/9.3/redhat/rhel-6-x86_64/pgdg-redhat93-9.3-1.noarch.rpm && yum install postgresql93 postgresql93-contrib postgresql93-server postgresql93-devel
JoePasq

1
Вы также можете написать какgem install pg -- with-pg-include=/Library/PostgreSQL/9.1/include/
lfender6445

А еще лучше, используйте export CONFIGURE_ARGS="with-pg-config=/path/to/postgres/bin/pg_config". pg_configИсполняемый файл будет называться , чтобы получить все необходимые опции компилятора и компоновщика - вы можете запустить его самостоятельно , чтобы увидеть их.
скозин

29

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

1
очень полезно, спасибо Просто, чтобы добавить примечание о конфигурации пакета ... вы должны выполнить эту команду при входе в систему как пользователь, который будет выполнять следующую команду пакета. Конфигурация компоновщика хранится в ~ / .bundle / config, поэтому она не будет найдена, если вы запустите конфигурацию комплекта при входе в систему от имени пользователя root, но пакет будет запущен (например, с помощью capistrano) пользователем 'deploy'.
Les Nightingill

3
комплектация build.pg --with-pg-config = / usr / pgsql-9.4 / bin / pg_config решить для меня на Centos 7
liloargana

2
комплектация build.pg --with-pg-config = / usr / pgsql-10 / bin / pg_config, если вы используете postgresql10
Махеш Нилаканта


17

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

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

1
Прекрасно работает, если вы используете замечательный Postgres.app . Для Postgres 10 я использовал путь/Applications/Postgres.app/Contents/Versions/10/bin/pg_config
Master of Ducks

13

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

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

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


1
Upvoted. Я установил Postgresql с помощью графического установщика EnterpriseDB . Затем мне нужно найти путь к pg-config sudo find / -name "pg_config", а затем gem install pg -- --with-pg-config=/Library/PostgreSQL/9.4/bin/pg_configиспользовать только что обнаруженный путь.
Йи Цзэн


10

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


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

Источник: Практически идиотское руководство по установке PostgreSQL 9.3, PostGIS 2.1 и pgRouting с Yum


После установки библиотек ... выполните очистку: "make distclean", "make clean", "./configure" и начните компиляцию!
mzalazar

8

Более общий ответ для любого дистрибутива на основе 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

Вот и вы!


«libpq-dev: /usr/include/postgresql/libpq-fe.h» присутствует, тогда как «postgres-xc-server-dev: /usr/include/postgres-xc/server/gtm/libpq-fe.h» есть нету? что мне не хватает?
furiabhavesh

Содержимое файла могло измениться. Похоже, что в пакете postgres -... была закрытая копия libpq-fe.h. В любом случае, libXXX-dev - это то, что вам нужно, если вы хотите что-то скомпилировать.
Винсент Фурмонд

7

Для MacOS без установки сервера PostgreSQL:

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

5

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

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

4

Я запускаю Postgres.app на Mac, и мне пришлось

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

первый. затем

bundle install

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


4

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

ARCHFLAGS="-arch x86_64" gem install pg

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


4

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


4

Недавно я обновил Mac OS X до версии 10.10 (Yosemite), и мне было трудно собрать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, чтобы получить последние версии пакетов, которые я установил ранее.


4

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

sudo apt-get install libpq-dev

Если этого недостаточно, добавьте sudo apt-get install postgresqlраньшеlibpq-dev
Алекс Пока

3

На 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 install pg -- --with-pg-config=/usr/pgsql-x.x/bin/pg_config

2

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

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


2

В Debian 7.0, 64-bit (Wheezy), просто запустите:

sudo apt-get install libpq-dev

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

bundle install

2

Под 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

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

Примечание. Каждый раз, когда вы изменяете конфигурацию Bash - изменяя конфигурацию profile.d - вы должны перезагрузить Bash.


Как вы установили postgres? Я слинкован в pg_*сценарии в пути примерно так: ln -s /usr/pgsql-9.3/bin/p* /usr/local/bin. После этого мне не нужно было никаких дополнительных сценариев или переменных среды.
JoePasq

2

Расположение 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.


Без --до --with-pg-config=...я получаю сообщение об ошибке: ОШИБКА: при выполнении gem ... (OptionParser :: InvalidOption) недопустимая опция: --with-pg-config = / usr / bin / pg_config)
Алексис Уилк

2

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

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

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

  2. Потом brew install postgresqlопять

  3. brew link postgresql

  4. gem install pg


"brew link --force postgresql" работал для меня, но до этого мне нужно было запустить 'export PATH = "/ usr/local/opt/postgresql@9.4/bin: $ PATH"' >> ~ / .bash_profile
Jagdish Narayandasani

2

Я только что это на OSX работает Brew и postgres@9.4.

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

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

2

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

brew upgrade postgresql@9.6
brew link postgresql@9.6 --force
gem install pg

2

Я столкнулся с той же ошибкой с postgres, установленным через asdf. Решения pg-config у меня не сработали. Вместо этого мне пришлось найти папку postgres include, которая содержит файл, и запустить команду с --with-pg-includeфлагом

gem install pg -- --with-pg-include=/<path>/.asdf/installs/postgres/<version>/include

1

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

apt-get install postgresql9.5-devel

Вы также можете установить определенные версии с помощью yum - yum install postgresqlxx-devel, например, yum install postgresql94-devel
dworrad

1

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

Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.