спасибо за продолжение. Поскольку я использую figaro, а не dotenv, я прибег к удалению гема rb-readline, который является первым вариантом. И теперь работает нормально. Спасибо!

аюсь развернуть свой код в AWS, используя эластичный beanstalk, но продолжаю сталкиваться с ошибками при развертывании.

Я добавил гем 'rb-readline', и когда я проверяю логи, я вижу, что с этим гемом произошла ошибка при развертывании. Я не могу вспомнить, какая ошибка при добавлении гема 'rb-readline' исправлена, но я не знаю, устранит ли этот камень эту проблему. Вот ссылка на камень:https://github.com/ConnorAtherton/rb-readline

вот журнал ошибок от развертывания.

Application update failed at 2017-10-24T19:27:36Z with exit status 1 and error: Hook /opt/elasticbeanstalk/hooks/appdeploy/pre/11_asset_compilation.sh failed.

++ /opt/elasticbeanstalk/bin/get-config container -k script_dir
+ EB_SCRIPT_DIR=/opt/elasticbeanstalk/support/scripts
++ /opt/elasticbeanstalk/bin/get-config container -k app_staging_dir
+ EB_APP_STAGING_DIR=/var/app/ondeck
++ /opt/elasticbeanstalk/bin/get-config container -k app_user
+ EB_APP_USER=webapp
++ /opt/elasticbeanstalk/bin/get-config container -k support_dir
+ EB_SUPPORT_DIR=/opt/elasticbeanstalk/support
+ . /opt/elasticbeanstalk/support/envvars
++ export RACK_ENV=production
++ RACK_ENV=production
++ export RAILS_SKIP_ASSET_COMPILATION=false
++ RAILS_SKIP_ASSET_COMPILATION=false
++ export RAILS_SKIP_MIGRATIONS=false
++ RAILS_SKIP_MIGRATIONS=false
++ export BUNDLE_WITHOUT=test:development
++ BUNDLE_WITHOUT=test:development
++ export RDS_PORT=5432
++ RDS_PORT=5432
++ export RDS_HOSTNAME=aa16lalntiz6vr0.cghvpjf0tzo5.us-east-1.rds.amazonaws.com
++ RDS_HOSTNAME=aa16lalntiz6vr0.cghvpjf0tzo5.us-east-1.rds.amazonaws.com
++ export RDS_USERNAME=theasteve
++ RDS_USERNAME=theasteve
++ export RDS_DB_NAME=ebdb
++ RDS_DB_NAME=ebdb
++ export RDS_PASSWORD=Colombia1
++ RDS_PASSWORD=Colombia1
+ RAKE_TASK=assets:precompile
+ . /opt/elasticbeanstalk/support/scripts/use-app-ruby.sh
++ . /usr/local/share/chruby/chruby.sh
+++ CHRUBY_VERSION=0.3.9
+++ RUBIES=()
+++ for dir in '"$PREFIX/opt/rubies"' '"$HOME/.rubies"'
+++ [[ -d /opt/rubies ]]
++++ ls -A /opt/rubies
+++ [[ -n ruby-1.9.3-p551
ruby-2.0.0-p648
ruby-2.1.10
ruby-2.2.8
ruby-2.3.5
ruby-2.4.2
ruby-current ]]
+++ RUBIES+=("$dir"/*)
+++ for dir in '"$PREFIX/opt/rubies"' '"$HOME/.rubies"'
+++ [[ -d /.rubies ]]
+++ unset dir
+++ cat /etc/elasticbeanstalk/.ruby_version
++ chruby 2.3.5
++ case "$1" in
++ local dir match
++ for dir in '"${RUBIES[@]}"'
++ dir=/opt/rubies/ruby-1.9.3-p551
++ case "${dir##*/}" in
++ for dir in '"${RUBIES[@]}"'
++ dir=/opt/rubies/ruby-2.0.0-p648
++ case "${dir##*/}" in
++ for dir in '"${RUBIES[@]}"'
++ dir=/opt/rubies/ruby-2.1.10
++ case "${dir##*/}" in
++ for dir in '"${RUBIES[@]}"'
++ dir=/opt/rubies/ruby-2.2.8
++ case "${dir##*/}" in
++ for dir in '"${RUBIES[@]}"'
++ dir=/opt/rubies/ruby-2.3.5
++ case "${dir##*/}" in
++ match=/opt/rubies/ruby-2.3.5
++ for dir in '"${RUBIES[@]}"'
++ dir=/opt/rubies/ruby-2.4.2
++ case "${dir##*/}" in
++ for dir in '"${RUBIES[@]}"'
++ dir=/opt/rubies/ruby-current
++ case "${dir##*/}" in
++ [[ -z /opt/rubies/ruby-2.3.5 ]]
++ shift
++ chruby_use /opt/rubies/ruby-2.3.5 ''
++ [[ ! -x /opt/rubies/ruby-2.3.5/bin/ruby ]]
++ [[ -n '' ]]
++ export RUBY_ROOT=/opt/rubies/ruby-2.3.5
++ RUBY_ROOT=/opt/rubies/ruby-2.3.5
++ export RUBYOPT=
++ RUBYOPT=
++ export PATH=/opt/rubies/ruby-2.3.5/bin:/opt/elasticbeanstalk/lib/ruby/bin:/usr/local/sbin:/usr/local/bin:/usr/bin:/usr/sbin:/sbin:/bin
++ PATH=/opt/rubies/ruby-2.3.5/bin:/opt/elasticbeanstalk/lib/ruby/bin:/usr/local/sbin:/usr/local/bin:/usr/bin:/usr/sbin:/sbin:/bin
+++ /opt/rubies/ruby-2.3.5/bin/ruby -
++ eval 'export RUBY_ENGINE=ruby;
export RUBY_VERSION=2.3.5;
export GEM_ROOT="/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0";'
+++ export RUBY_ENGINE=ruby
+++ RUBY_ENGINE=ruby
+++ export RUBY_VERSION=2.3.5
+++ RUBY_VERSION=2.3.5
+++ export GEM_ROOT=/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0
+++ GEM_ROOT=/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0
++ (( 0 != 0 ))
+ cd /var/app/ondeck
+ su -s /bin/bash -c 'bundle exec /opt/elasticbeanstalk/support/scripts/check-for-rake-task.rb assets:precompile' webapp
`/home/webapp` is not a directory.
Bundler will use `/tmp/bundler/home/webapp' as your home directory temporarily.
+ '[' false == true ']'
+ su -s /bin/bash -c 'bundle exec rake assets:precompile' webapp
`/home/webapp` is not a directory.
Bundler will use `/tmp/bundler/home/webapp' as your home directory temporarily.
rake aborted!
Bundler::GemRequireError: There was an error while trying to load the gem 'rb-readline'.
Gem Load Error is: HOME environment variable (or HOMEDRIVE and HOMEPATH) must be set and point to a directory
Backtrace for gem load error is:
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/rb-readline-0.5.4/lib/rbreadline.rb:1097:in `<module:RbReadline>'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/rb-readline-0.5.4/lib/rbreadline.rb:17:in `<top (required)>'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/rb-readline-0.5.4/lib/readline.rb:10:in `require'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/rb-readline-0.5.4/lib/readline.rb:10:in `<module:Readline>'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/rb-readline-0.5.4/lib/readline.rb:8:in `<top (required)>'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/rb-readline-0.5.4/lib/rb-readline.rb:16:in `require'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/rb-readline-0.5.4/lib/rb-readline.rb:16:in `<top (required)>'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/bundler-1.15.0/lib/bundler/runtime.rb:82:in `require'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/bundler-1.15.0/lib/bundler/runtime.rb:82:in `block (2 levels) in require'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/bundler-1.15.0/lib/bundler/runtime.rb:77:in `each'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/bundler-1.15.0/lib/bundler/runtime.rb:77:in `block in require'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/bundler-1.15.0/lib/bundler/runtime.rb:66:in `each'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/bundler-1.15.0/lib/bundler/runtime.rb:66:in `require'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/bundler-1.15.0/lib/bundler.rb:108:in `require'
/var/app/ondeck/config/application.rb:17:in `<top (required)>'
/var/app/ondeck/Rakefile:4:in `require_relative'
/var/app/ondeck/Rakefile:4:in `<top (required)>'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/rake-12.0.0/lib/rake/rake_module.rb:28:in `load'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/rake-12.0.0/lib/rake/rake_module.rb:28:in `load_rakefile'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/rake-12.0.0/lib/rake/application.rb:687:in `raw_load_rakefile'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/rake-12.0.0/lib/rake/application.rb:96:in `block in load_rakefile'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/rake-12.0.0/lib/rake/application.rb:178:in `standard_exception_handling'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/rake-12.0.0/lib/rake/application.rb:95:in `load_rakefile'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/rake-12.0.0/lib/rake/application.rb:79:in `block in run'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/rake-12.0.0/lib/rake/application.rb:178:in `standard_exception_handling'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/rake-12.0.0/lib/rake/application.rb:77:in `run'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/rake-12.0.0/exe/rake:27:in `<top (required)>'
/opt/rubies/ruby-2.3.5/bin/rake:23:in `load'
/opt/rubies/ruby-2.3.5/bin/rake:23:in `<top (required)>'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/bundler-1.15.0/lib/bundler/cli/exec.rb:74:in `load'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/bundler-1.15.0/lib/bundler/cli/exec.rb:74:in `kernel_load'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/bundler-1.15.0/lib/bundler/cli/exec.rb:27:in `run'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/bundler-1.15.0/lib/bundler/cli.rb:360:in `exec'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/bundler-1.15.0/lib/bundler/vendor/thor/lib/thor/command.rb:27:in `run'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/bundler-1.15.0/lib/bundler/vendor/thor/lib/thor/invocation.rb:126:in `invoke_command'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/bundler-1.15.0/lib/bundler/vendor/thor/lib/thor.rb:369:in `dispatch'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/bundler-1.15.0/lib/bundler/cli.rb:20:in `dispatch'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/bundler-1.15.0/lib/bundler/vendor/thor/lib/thor/base.rb:444:in `start'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/bundler-1.15.0/lib/bundler/cli.rb:10:in `start'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/bundler-1.15.0/exe/bundle:35:in `block in <top (required)>'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/bundler-1.15.0/lib/bundler/friendly_errors.rb:121:in `with_friendly_errors'
/opt/rubies/ruby-2.3.5/lib/ruby/gems/2.3.0/gems/bundler-1.15.0/exe/bundle:27:in `<top (required)>'
/opt/rubies/ruby-2.3.5/bin/bundle:23:in `load'
/opt/rubies/ruby-2.3.5/bin/bundle:23:in `<main>'
Bundler Error Backtrace:
/var/app/ondeck/config/application.rb:17:in `<top (required)>'
/var/app/ondeck/Rakefile:4:in `require_relative'
/var/app/ondeck/Rakefile:4:in `<top (required)>'
/opt/rubies/ruby-2.3.5/bin/bundle:23:in `load'
/opt/rubies/ruby-2.3.5/bin/bundle:23:in `<main>'
HOME environment variable (or HOMEDRIVE and HOMEPATH) must be set and point to a directory
/var/app/ondeck/config/application.rb:17:in `<top (required)>'
/var/app/ondeck/Rakefile:4:in `require_relative'
/var/app/ondeck/Rakefile:4:in `<top (required)>'
/opt/rubies/ruby-2.3.5/bin/bundle:23:in `load'
/opt/rubies/ruby-2.3.5/bin/bundle:23:in `<main>'
(See full trace by running task with --trace).
Incorrect application version "app-cd09-171024_152653" (deployment 3). Expected version "app-cd09-171024_150253" (deployment 2).
100 % of CPU is in use.

Ответы на вопрос(1)

Решение Вопроса

мог бы быть той же основной причиной.

Оказалось, потому что$HOME не был установлен AWS во время развертывания, и вызовFile.expand_path умирает, когда он не установлен.

Возможные исправления:

Удалить rbreadlineДобавитьHOME переменная окружения в вашей конфигурации EB илиeb setenv (и перераспределить)Добавьте файл конфигурации, который перезаписывает существующий сценарий развертывания и добавляет переменную $ HOME перед выполнением команды bundle install

Я успешно попробовал первый и последний вариант, и согласился с использованием раздвоенной версии Gem, которая обработала недостающий$HOME правильно.

Я подозреваю, что 2-я версия является более правильным способом сделать это, но, честно говоря, неясно, почему Amazon не установил$HOME для начала, и что это должно быть на самом деле.

Приложение будет существовать либо в/var/app/ondeck или же/var/app/current так что либо одна из этих двух папок, либо/home/webapp (за ошибку) все может быть хорошим значением для начала.

Это не может быть на 100% основной причиной, потому что мне повезло с разной степенью репликации локально с различными версиями Ruby. Однакоexpand_path документы говорятHOME должны быть установлены правильно, так что это может быть причиной.

https://ruby-doc.org/core-2.4.2/File.html#method-c-expand_path

Подробнее о рабочих решениях:

Я нашел два решения, которые работали (попробуйте одно или другое)

В какой-то момент я отправил пиар с dotenv, чтобы исправить эту проблему.https://github.com/bkeepers/dotenv/pull/314, Насколько я помню, это исправляет и больше ничего не ломает. Проблема была помечена какwontfix автоматическим ботом, но недавно был вновь открыт новыми сопровождающими

В конце концов я вернулся к подходу ebextensions после того, как стало ясно, что мой PR не будет объединен, но в последний раз я вспоминаю, что он функционировал как ожидалось (и я думаю, что лучший подход)

Другое решение, которое я использовал, было создать новый файл конфигурации, который заменил/opt/elasticbeanstalk/hooks/appdeploy/pre/10_bundle_install.sh файл.

Получить текущую версию этого файла с существующего сервера приложенийСоздайте конфигурацию ebextension, которая создает этот файл (он перезапишет исходный файл), но содержит строку для установки$HOME переменная передbundle install команда запускается.Установить$HOME значение того, что было бы для пользователя по умолчанию

Документация по созданию такого файла с использованием расширений находится здесь:

https://docs.aws.amazon.com/elasticbeanstalk/latest/dg/customize-containers-ec2.html#linux-files

 hudarsono16 апр. 2018 г., 08:03
спасибо за продолжение. Поскольку я использую figaro, а не dotenv, я прибег к удалению гема rb-readline, который является первым вариантом. И теперь работает нормально. Спасибо!
 hudarsono13 апр. 2018 г., 12:01
Привет, Джей, не мог бы ты сказать немного подробнее о том, как выполнить вариант 3? У меня та же проблема, и я попробовал вариант 2, но он не работал. все та же ошибка.
 Jay Dorsey15 апр. 2018 г., 20:46
@hudarsono новые сопровождающие объединили мой запрос на получение. Вы можете попробовать использовать последний мастер dotenv (еще не был упакован и опубликован в rubygems)
 Jay Dorsey13 апр. 2018 г., 20:48
@hudarsono Прошло так много времени с тех пор, как я сталкивался с этим, я не помню точных деталей и у меня нет кода, с которого я столкнулся с этим. Я добавлю обновление в свой ответ с деталями, которые я помню
 Jay Dorsey13 апр. 2018 г., 21:20
@hudarsono Я обновил немного новой информации. Кроме того, у драгоценного камня dotenv есть новые сопровождающие, и они вновь открыли проблему, которую я подал, чтобы они, возможно, объединились, чтобы исправить это. Если они это сделают, это будет решение, которое вы хотели бы. Если они этого не сделают, я бы предложил вилку. Изменения незначительны и просты в обслуживании, и должны быть совместимы с изменениями EB. Удачи, дайте мне знать, если вам нужно что-нибудь еще

Ваш ответ на вопрос