Проблемы с установкой pg gem - PullRequest
8 голосов
/ 24 марта 2012

Попытка установить гем pg выдает ошибки.

Я использую Ruby 1.9.3-p125, собранный с использованием rbenv / ruby-build. Я установил PostgreSQL с помощью установщика в один клик. Я могу подключиться к БД с помощью pgAdmin. У меня заканчиваются идеи.

% gem install pg                                                                                                                                                                                                      ~
Building native extensions.  This could take a while...
ERROR:  Error installing pg:
    ERROR: Failed to build gem native extension.

        /Users/sandropadin/.rbenv/versions/1.9.3-p125/bin/ruby extconf.rb
checking for pg_config... yes
Using config values from /usr/bin/pg_config
checking for libpq-fe.h... yes
checking for libpq/libpq-fs.h... yes
checking for pg_config_manual.h... yes
checking for PQconnectdb() in -lpq... yes
checking for PQconnectionUsedPassword()... yes
checking for PQisthreadsafe()... yes
checking for PQprepare()... yes
checking for PQexecParams()... yes
checking for PQescapeString()... yes
checking for PQescapeStringConn()... yes
checking for PQgetCancel()... yes
checking for lo_create()... yes
checking for pg_encoding_to_char()... yes
checking for pg_char_to_encoding()... yes
checking for PQsetClientEncoding()... yes
checking for rb_encdb_alias()... yes
checking for rb_enc_alias()... yes
checking for struct pgNotify.extra in libpq-fe.h... yes
checking for unistd.h... yes
checking for ruby/st.h... yes
creating extconf.h
creating Makefile

make
compiling pg.c
compiling pg_connection.c
pg_connection.c: In function ‘pgconn_wait_for_notify’:
pg_connection.c:1986: warning: ‘rb_thread_select’ is deprecated (declared at /Users/sandropadin/.rbenv/versions/1.9.3-p125/include/ruby-1.9.1/ruby/intern.h:379)
pg_connection.c: In function ‘pgconn_block’:
pg_connection.c:2512: warning: ‘rb_thread_select’ is deprecated (declared at /Users/sandropadin/.rbenv/versions/1.9.3-p125/include/ruby-1.9.1/ruby/intern.h:379)
compiling pg_result.c
linking shared-object pg_ext.bundle
ld: in /usr/local/lib/libssl.0.9.8.dylib, missing required architecture x86_64 in file for architecture x86_64
collect2: ld returned 1 exit status
make: *** [pg_ext.bundle] Error 1


Gem files will remain installed in /Users/sandropadin/.rbenv/versions/1.9.3-p125/lib/ruby/gems/1.9.1/gems/pg-0.13.2 for inspection.
Results logged to /Users/sandropadin/.rbenv/versions/1.9.3-p125/lib/ruby/gems/1.9.1/gems/pg-0.13.2/ext/gem_make.out

1 Ответ

14 голосов
/ 25 марта 2012

Не уверен, какой из следующих шагов окончательно решил эту проблему.Но так как мю слишком коротко упомянуто, проблема заключалась в смешивании 32-битных и 64-битных двоичных файлов.

  • 1-й, я установил эту 64-битную версию PostgreSQL
  • 2-й, я удалил любую старую установку Homebrew OpenSSL

    $ brew uninstall openssl

  • 3-й, я установил 64-битную версию OpenSSLс Homebrew

    $ brew install --64-bit openssl

  • Наконец, при установке гема pg я изменил LDFLAGS так, чтобы он указывал на64-битная версия OpenSSL

    $ gem install pg - --with-ldflags = '- L / usr / local / Cellar / openssl / 0.9.8s'

...