Ответ 1
Вам может потребоваться удалить и переустановить gem pg
, поэтому он скомпилирован против правильной версии Postgres.
У меня есть приложение, в котором работают Ruby 1.9.2, Rails 3 и postgreSQL 8.3. Первоначально он был настроен и работал с postgreSQL 9.1, но я удалил 9.1 и установил и изменил его на 8.3, чтобы обеспечить совместимость с общей настройкой базы данных Heroku. Он работает нормально, но это не сейчас
Теперь, когда я работаю над этим приложением, когда я запускаю обновление базы данных, я получаю эту ошибку:
dlopen(/Users/michaeljmccoy/.rvm/gems/ruby-1.9.2-p290/gems/pg-0.12.2/lib/pg_ext.bundle, 9): Library not loaded: libpq.5.dylib
Referenced from: /Users/michaeljmccoy/.rvm/gems/ruby-1.9.2-p290/gems/pg-0.12.2/lib/pg_ext.bundle
Reason: no suitable image found. Did find:
/usr/lib/libpq.5.dylib: no matching architecture in universal wrapper - /Users/michaeljmccoy/.rvm/gems/ruby-1.9.2-p290/gems/pg-0.12.2/lib/pg_ext.bundle
И когда я пытаюсь запустить сервер, я получаю следующее сообщение об ошибке:
/Users/michaeljmccoy/.rvm/gems/ruby-1.9.2-p290/gems/pg-0.12.2/lib/pg.rb:4:in `require': dlopen(/Users/michaeljmccoy/.rvm/gems/ruby-1.9.2-p290/gems/pg-0.12.2/lib/pg_ext.bundle, 9): Library not loaded: libpq.5.dylib (LoadError)
Referenced from: /Users/michaeljmccoy/.rvm/gems/ruby-1.9.2-p290/gems/pg-0.12.2/lib/pg_ext.bundle
Reason: no suitable image found. Did find:
/usr/lib/libpq.5.dylib: no matching architecture in universal wrapper - /Users/michaeljmccoy/.rvm/gems/ruby-1.9.2-p290/gems/pg-0.12.2/lib/pg_ext.bundle
from /Users/michaeljmccoy/.rvm/gems/ruby-1.9.2-p290/gems/pg-0.12.2/lib/pg.rb:4:in `<top (required)>'
from /Users/michaeljmccoy/.rvm/gems/[email protected]/gems/bundler-1.0.21/lib/bundler/runtime.rb:68:in `require'
from /Users/michaeljmccoy/.rvm/gems/[email protected]/gems/bundler-1.0.21/lib/bundler/runtime.rb:68:in `block (2 levels) in require'
from /Users/michaeljmccoy/.rvm/gems/[email protected]/gems/bundler-1.0.21/lib/bundler/runtime.rb:66:in `each'
from /Users/michaeljmccoy/.rvm/gems/[email protected]/gems/bundler-1.0.21/lib/bundler/runtime.rb:66:in `block in require'
from /Users/michaeljmccoy/.rvm/gems/[email protected]/gems/bundler-1.0.21/lib/bundler/runtime.rb:55:in `each'
from /Users/michaeljmccoy/.rvm/gems/[email protected]/gems/bundler-1.0.21/lib/bundler/runtime.rb:55:in `require'
from /Users/michaeljmccoy/.rvm/gems/[email protected]/gems/bundler-1.0.21/lib/bundler.rb:122:in `require'
from /Users/michaeljmccoy/www/mikemccoy/config/application.rb:7:in `<top (required)>'
from /Users/michaeljmccoy/.rvm/gems/ruby-1.9.2-p290/gems/railties-3.2.0.rc2/lib/rails/commands.rb:53:in `require'
from /Users/michaeljmccoy/.rvm/gems/ruby-1.9.2-p290/gems/railties-3.2.0.rc2/lib/rails/commands.rb:53:in `block in <top (required)>'
from /Users/michaeljmccoy/.rvm/gems/ruby-1.9.2-p290/gems/railties-3.2.0.rc2/lib/rails/commands.rb:50:in `tap'
from /Users/michaeljmccoy/.rvm/gems/ruby-1.9.2-p290/gems/railties-3.2.0.rc2/lib/rails/commands.rb:50:in `<top (required)>'
from script/rails:6:in `require'
from script/rails:6:in `<main>'
Я знаю, что они очень похожие ошибки и, вероятно, связаны с отсутствующим путем. Однако, когда я добавляю путь к моему файлу .profile и перезапускаю окно терминала, я получаю те же ошибки.
Вам может потребоваться удалить и переустановить gem pg
, поэтому он скомпилирован против правильной версии Postgres.
Для всех, кто видит эту ошибку и запускает PostgresApp, это известная проблема, которая была исправлена в версии 9.2.4.3:
Обсуждение: https://github.com/PostgresApp/PostgresApp/issues/109
Установщик: https://github.com/PostgresApp/PostgresApp/releases/tag/9.2.4.3
Конечно, вы могли бы просто взять последнюю версию (http://postgresapp.com/). Обе версии заставили меня работать и работать с Rails 3.2.14 и Ruby 2.0.0. Обратите внимание, что когда я установил 9.2.4.3, мои базы данных по-прежнему были перечислены в psql, но когда я установил 9.3.0 (текущая версия на данный момент), мои базы данных больше не указывались.