Не могу найти ' libpq-fe.H заголовок при попытке установить pg gem
Я использую Ruby on Rails 3.1 pre version. Мне нравится использовать 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 (Осознанные Рысь), 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.4(Я Ubuntu 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Это будет держать ваш
pggem синхронизируется с точно установленной версией PostgreSQL. Установка чего-то из доморощенного-это трата времени в данном случае.
у меня была такая же проблема на 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 install pg -- --with-pg-config=/usr/pgsql-x.x/bin/pg_config
Я запускаю Postgres.приложение на 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.hThe
binкаталог, который содержитpg_config, будет находиться в том же каталоге, что
Я наконец-то решил эту проблему, но не используя ранее описанные методы.
используя
brew install postgresql, Я узнаю, что он уже был установлен, но не связан.
узнайте, где установлен PostgreSQL, и удалите его,
затем
brew install postgresqlопять
brew link postgresql
gem install pg
у меня только что было это на OSX работает brew и
[email protected].мое решение было такое:
CONFIGURE_ARGS="with-pg-include=/usr/local/opt/[email protected]/include/" bundle install
на
AltLinuxпакетаpostgresqlx.x-devel(в моем случаеpostgresql9.5-devel) должны быть установлены:apt-get install postgresql9.5-devel
Я решил эту проблему, установив пакет "postgresql-common". Этот пакет предоставляет
pg_configдвоичный файл, который, скорее всего, то, что вы пропустили.
У меня была аналогичная проблема, и это фиксированная это для меня:
gem install do_postgres -- --with-pgsql-server-dir=/Applications/Postgres.app/Contents/MacOS --with-pgsql-server-include=/Applications/Postgres.app/Contents/MacOS/include/serverисточник:
On OS X 10.9 (Маверикс), Я
brew-installed postgresql, а мне тогда пришлосьrvm reinstallмой Рубин. Теперь я счастлив:)
Comments