Хобрук: Ваш путь к мастерству в программировании

Ошибка о nokogiri при развертывании capistrano на сервере ubuntu

Во время bundle:install фазы после deploy:finalize_update я получаю сообщение об ошибке nokogiri. Это предполагает,

 ** [out :: *******] Make sure that `gem install nokogiri -v '1.6.0'` succeeds before bundling.

Поэтому я попытался установить nokogiri самостоятельно на сервер. Но выдает следующую ошибку:

Building native extensions.  This could take a while...
ERROR:  Error installing nokogiri:
    ERROR: Failed to build gem native extension.

    /home/deployer/.rvm/rubies/ruby-2.0.0-p0/bin/ruby extconf.rb
Extracting libxml2-2.8.0.tar.gz into tmp/x86_64-linux-gnu/ports/libxml2/2.8.0... OK
Running 'configure' for libxml2 2.8.0... OK
Running 'compile' for libxml2 2.8.0... ERROR, review 'tmp/x86_64-linux-gnu/ports/libxml2/2.8.0/compile.log' to see what happened.
*** 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/deployer/.rvm/rubies/ruby-2.0.0-p0/bin/ruby
/home/deployer/.rvm/rubies/ruby-2.0.0-p0/lib/ruby/gems/2.0.0/gems/mini_portile-0.5.0/lib/mini_portile.rb:235:in `block in execute': Failed to complete compile task (RuntimeError)
    from /home/deployer/.rvm/rubies/ruby-2.0.0-p0/lib/ruby/gems/2.0.0/gems/mini_portile-0.5.0/lib/mini_portile.rb:227:in `chdir'
    from /home/deployer/.rvm/rubies/ruby-2.0.0-p0/lib/ruby/gems/2.0.0/gems/mini_portile-0.5.0/lib/mini_portile.rb:227:in `execute'
    from /home/deployer/.rvm/rubies/ruby-2.0.0-p0/lib/ruby/gems/2.0.0/gems/mini_portile-0.5.0/lib/mini_portile.rb:61:in `compile'
    from /home/deployer/.rvm/rubies/ruby-2.0.0-p0/lib/ruby/gems/2.0.0/gems/mini_portile-0.5.0/lib/mini_portile.rb:101:in `cook'
    from extconf.rb:101:in `block in <main>'
    from extconf.rb:119:in `call'
    from extconf.rb:119:in `block in <main>'
    from extconf.rb:109:in `tap'
    from extconf.rb:109:in `<main>'


Gem files will remain installed in /home/deployer/.rvm/gems/ruby-2.0.0-p0/gems/nokogiri-1.6.0 for inspection.
Results logged to /home/deployer/.rvm/gems/ruby-2.0.0-p0/gems/nokogiri-1.6.0/ext/nokogiri/gem_make.out

Это только началось сегодня. Также libxml2 уже установлен.

Есть идеи?

Спасибо.

EDIT: я не требую явного указания nokogiri в моем gemfile.


  • У меня есть идея: просмотрите 'tmp/x86_64-linux-gnu/ports/libxml2/2.8.0/compile.log', чтобы узнать, что произошло. 20.06.2013
  • :) файл не существует 20.06.2013
  • Я добавил nokogiri в свой файл драгоценных камней, и это было решено. Но предупреждает меня. ПРЕДУПРЕЖДЕНИЕ: Nokogiri был создан для LibXML версии 2.9.1, но имеет динамическую загрузку 2.8.0. 21.06.2013

Ответы:


1

Я столкнулся с той же проблемой с Nokogiri 1.6.0. Проблема, как видно из журналов, вызвана неудачной компиляцией libxml2, которая вместе с libxslt теперь поставляется встроенной в гем и компилируется при его установке.

Чтобы выяснить, что именно пошло не так при компиляции, посмотрите предлагаемый файл compile.log, который в вашем случае можно найти по адресу:

/home/deployer/.rvm/gems/ruby-2.0.0-p0/gems/nokogiri-1.6.0/ext/nokogiri/tmp/x86_64-linux-gnu/ports/libxml2/2.8.0/compile.log

В качестве обходного пути (при условии, что у вас установлены libxml2-dev и libxslt-dev) вы можете сделать:

NOKOGIRI_USE_SYSTEM_LIBRARIES=1 bundle install

Я надеюсь, что это помогает.

24.06.2013
  • Спасибо за обходной путь! Я думаю, что для меня это определенно проблема с домашним пивом, но нет времени искать исправление в Google-Fu. 05.08.2013
  • ваш обходной путь сработал и для меня. но все же предупреждая меня. любой открытый вопрос об этом? может быть, мы можем прикрепить этот вопрос к нему. 20.08.2013
  • Его следует расширить, включив в него ответ от @tiago. 21.10.2014

  • 2

    Если вы используете Capistrano 3.x, вы можете сделать следующее в своем файле deploy.rb (или файле для конкретной среды, например deploy/production.rb)

    set :bundle_env_variables, { 'NOKOGIRI_USE_SYSTEM_LIBRARIES' => 1 }
    

    Таким образом вы избежите переопределения задачи bundle install. Это установит заданные переменные env при запуске bundle install.

    27.03.2014

    3

    Основываясь на ответе @zekus, я создал новую задачу в capistrano следующим образом:

      task :custom_bundle_install, roles: :app do
        run "cd /home/#{user}/apps/#{application}/releases/#{release_name} && NOKOGIRI_USE_SYSTEM_LIBRARIES=1 bundle install --gemfile /home/#{user}/apps/#{application}/releases/#{release_name}/Gemfile --path /home/#{user}/apps/#{application}/shared/bundle --deployment --quiet --without development test"
      end
      before "bundle:install", "deploy:custom_bundle_install"
    

    Это сработало для меня очень хорошо.

    01.11.2013

    4

    Подключитесь к вашему хосту с пользователем deployer, затем попробуйте установить пакет самостоятельно:

    cd {your last release path}
    bundle config build.nokogiri --with-xml2-include=/usr/include/libxml2/libxml
    bundle install --gemfile Gemfile --path shared/bundle --deployment --quiet --without development test
    

    Чем запустить capistrano вручную.

    Это сработало для меня.

    29.04.2015
    Новые материалы

    Не зря же это называют интеллектом
    Стек — C#, Oracle Опыт — 4 года Работа — Разведывательный корпус Мне пора служить Может быть, я немного приукрашиваю себя, но там, где я живу, есть обязательная военная служба на 3..

    LeetCode Проблема 41. Первый пропущенный положительный результат
    LeetCode Проблема 41. Первый пропущенный положительный результат Учитывая несортированный массив целых чисел, найдите наименьшее пропущенное положительное целое число. Пример 1: Input:..

    Расистский и сексистский робот, обученный в Интернете
    Его ИИ основан на предвзятых данных, которые создают предрассудки. Он словно переходит из одного эпизода в другой из серии Черное зеркало , а вместо этого представляет собой хронику..

    Управление состоянием в микрофронтендах
    Стратегии бесперебойного сотрудничества Микро-фронтенды — это быстро растущая тенденция в сфере фронтенда, гарантирующая, что удовольствие не ограничивается исключительно бэкэнд-системами..

    Декларативное и функциональное программирование в стиле LINQ с использованием JavaScript с использованием каррирования и генератора ...
    LINQ - одна из лучших функций C #, которая обеспечивает элегантный способ написания кода декларативного и функционального стиля, который легко читать и понимать. Благодаря таким функциям ES6,..

    Структуры данных в C ++ - Часть 1
    Реализация общих структур данных в C ++ C ++ - это расширение языка программирования C, которое поддерживает создание классов, поэтому оно известно как C с классами . Он используется для..

    Как я опубликовал свое первое приложение в App Store в 13 лет
    Как все началось Все началось три года назад летом после моего четвертого класса в начальной школе. Для меня, четвертого класса, лето кажется бесконечным, пока оно не закончится, и мой отец..