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

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

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

49 ответов

Решение

В 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 или его эквивалент для вашей ОС:

  • Для систем Ubuntu: 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

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

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, я мог указать 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

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

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

Для CentOS 6.4,

yum install postgresql-devel
gem install pg

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

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

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

Это только проблема отсутствия libpq-fe.h

На ubuntu нам просто нужно запустить: sudo apt-get install libpq-dev

Вышеупомянутая команда установит НОВЫЙ пакет libpq-dev и после этого вы снова можете выполнить bundle install чтобы возобновить установку пакета.

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

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

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

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

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

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

Мое решение для Fedora 30:

sudo dnf install /usr/include/libpq-fe.h

Правильный ответ для пользователей Mac с Postgres.app - это построить против 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

Там вы идете!

В Debian Bullseye ни один из существующих ответов не решил проблему для меня.

В случае, если это поможет кому-то с такой же конфигурацией, как у меня:

  1. Используйте репозиторий apt PostgreSQL: 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

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

sudo apt-get install libpq-dev

В Fedora 32 мне удалось решить ту же проблему, установив конкретно.

Если вы установите postgresql из официального репозитория, у вас будет несколько версий, которые не решат проблему, поэтому на самом деле нужно попробовать, какая из них нужна.

Решено на MacOS M1:

      brew install libpq

Затем я вставил свой PATH

      echo 'export PATH="/opt/homebrew/opt/libpq/bin:$PATH"' >> ~/.zshrc

И:

      gem install pg

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

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

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

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

Недавно я обновил 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, чтобы получить последние версии пакетов, которые я установил ранее.

Я решил это, создав символическую ссылку на MacOS Ventura.

если postgresql уже установлен;

      brew link postgresql@12 --force

Эта команда даст путь к каталогу, как показано ниже.

      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

вам нужно добавить zsh или bash_profile на свой компьютер, в зависимости от того, что вы используете

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

ARCHFLAGS="-arch x86_64" gem install pg

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

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

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

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

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

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

bundle install

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

На 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

В Ubuntu 20.04 у меня уже была libpq5:amd64 версии 13.2-1.pgdg20.04+ 1. Теперь, когда я пытался установить libpq-dev из репозитория apt, я получал

      The following packages have unmet dependencies:
libpq-dev : Depends: libpq5 (= 12.6-0ubuntu0.20.04.1) but 13.2-1.pgdg20.04+1 is to be installed

Я взял дебют из http://ftp.us.debian.org/debian/pool/main/p/postgresql-13/libpq-dev_13.2-1_amd64.deb и сделал следующее:

      mkdir -p /tmp/libpq-dev
dpkg-deb -R libpq-dev_13.2-1_amd64.deb /tmp/libpq-dev
sed -i 's|= 13.2-1|= 13.2-1.pgdg20.04+1|' /tmp/libpq-dev/DEBIAN/control
dpkg-deb -b /tmp/libpq-dev /tmp/libpq-dev-new.deb
sudo dpkg -i /tmp/libpq-dev-new.deb

После этого я с удовольствием использовал драгоценный камень. Никаких дополнительных установок или чего-то подобного.

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

Другие вопросы по тегам