我正在尝试将Rails应用程序部署到Heroku。自从我在那里部署任何东西已经有一段时间了,但是我对这里发生的事情感到茫然。
这是一个相当基本的Rails 5应用程序。部署顺利通过Gemfile,然后失败,并出现错误,要求我安装Bundler v 2.0.1。这是日志的有趣之处:
remote: Fetching devise 4.6.2
remote: Installing sass-rails 5.0.7
remote: Installing devise 4.6.2
remote: Bundle complete! 26 Gemfile dependencies, 78 gems now installed.
remote: Gems in the groups development and test were not installed.
remote: Bundled gems are installed into `./vendor/bundle`
remote: Post-install message from i18n:
remote:
remote: HEADS UP! i18n 1.1 changed fallbacks to exclude default locale.
remote: But that may break your application.
remote:
remote: Please check your Rails app for 'config.i18n.fallbacks = true'.
remote: If you're using I18n (>= 1.1.0) and Rails (< 5.2.2), this should be
remote: 'config.i18n.fallbacks = [I18n.default_locale]'.
remote: If not, fallbacks will be broken in your app by I18n 1.1.x.
remote:
remote: For more info see:
remote: https://github.com/svenfuchs/i18n/releases/tag/v1.1.0
remote:
remote: Post-install message from sass:
remote:
remote: Ruby Sass has reached end-of-life and should no longer be used.
remote:
remote: * If you use Sass as a command-line tool, we recommend using Dart Sass, the new
remote: primary implementation: https://sass-lang.com/install
remote:
remote: * If you use Sass as a plug-in for a Ruby web framework, we recommend using the
remote: sassc gem: https://github.com/sass/sassc-ruby#readme
remote:
remote: * For more details, please refer to the Sass blog:
remote: https://sass-lang.com/blog/posts/7828841
remote:
remote: Removing bundler (2.0.1)
remote: Bundle completed (47.21s)
remote: Cleaning up the bundler cache.
remote: -----> Installing node-v10.14.1-linux-x64
remote: Detected manifest file, assuming assets were compiled locally
remote: -----> Detecting rails configuration
remote: -----> Detecting rake tasks
remote:
remote: !
remote: ! Could not detect rake tasks
remote: ! ensure you can run `$ bundle exec rake -P` against your app
remote: ! and using the production group of your Gemfile.
remote: ! Activating bundler (2.0.1) failed:
remote: ! Could not find 'bundler' (2.0.1) required by your /tmp/build_94d6a4f5d4fbb862672998d5d06d2506/Gemfile.lock.
remote: ! To update to the latest version installed on your system, run `bundle update --bundler`.
remote: ! To install the missing version, run `gem install bundler:2.0.1`
remote: ! Checked in 'GEM_PATH=/tmp/build_94d6a4f5d4fbb862672998d5d06d2506/vendor/bundle/ruby/2.7.0', execute `gem env` for more information
remote: !
remote: ! To install the version of bundler this project requires, run `gem install bundler -v '2.0.1'`
remote: !
remote: /app/tmp/buildpacks/b7af5642714be4eddaa5f35e2b4c36176b839b4abcd9bfe57ee71c358d71152b4fd2cf925c5b6e6816adee359c4f0f966b663a7f8649b0729509d510091abc07/lib/language_pack/helpers/rake_runner.rb:106:in `load_rake_tasks!': Could not detect rake tasks (LanguagePack::Helpers::RakeRunner::CannotLoadRakefileError)
remote: ensure you can run `$ bundle exec rake -P` against your app
remote: and using the production group of your Gemfile.
remote: Activating bundler (2.0.1) failed:
remote: Could not find 'bundler' (2.0.1) required by your /tmp/build_94d6a4f5d4fbb862672998d5d06d2506/Gemfile.lock.
remote: To update to the latest version installed on your system, run `bundle update --bundler`.
remote: To install the missing version, run `gem install bundler:2.0.1`
remote: Checked in 'GEM_PATH=/tmp/build_94d6a4f5d4fbb862672998d5d06d2506/vendor/bundle/ruby/2.7.0', execute `gem env` for more information
remote:
remote: To install the version of bundler this project requires, run `gem install bundler -v '2.0.1'`
我不知道发生了什么,因为Heroku似乎在整个部署过程中都运行良好,然后删除了捆绑程序,然后在rake任务上引发错误并再次请求捆绑程序。我已经执行过RAILS_ENV=production bundle exec rake assets:precompile
,并且它是最新的。我必须在这里丢失一些东西,希望对Heroku有较新经验的人可以指出。
修改
我也运行了bundle exec rake -P
命令,没有失败
答案 0 :(得分:9)
我通过升级到Ruby 2.6.3和Bundler 2.0.2修复了在Heroku上的构建。
我们在Heroku上进行的构建在最近几天开始中断,并显示类似的错误消息:
Could not find 'bundler' (2.0.1) required by your ... Gemfile.lock.
我们在本地版本的Ruby 2.6.1和Bundler 2.0.1上运行良好。直到几天前,此组合在Heroku上也能正常工作。
在搜索Heroku文档时,我注意到此Dev Center article,它于2019年6月26日更新。它指出:
捆绑器2.0.2 查看2.0.1。的问题。
许多人都遇到了问题4,该问题仅在发布新的Bundler版本时触发。它的发生是由于Rubygems中的一个错误,可以通过升级到2.5.5+或2.6.3+来解决。
2.0.1状态下的问题4:
由于Rubygems捆绑程序版本检查代码中的错误,[您可能会得到错误]。为避免此问题,请升级您的Ruby版本。它在2.5.5+和2.6.3+中已修复。如果不更新,则为Ruby版本,则Bundler 2.x的每个新发行版都会触发此问题。
Bundler 2.0.2已于2019年6月13日发布,看来Heroku已开始使用它。
我注意到您正在从日志中使用Ruby 2.7。我建议在您的Gemfile中指定ruby '2.6.3'
,安装Bundler 2.0.2,并使用该组合捆绑/生成Gemfile.lock
。然后,您应该在锁定文件的底部看到此内容,并希望您的应用程序可以在Heroku上成功构建:
RUBY VERSION
ruby 2.6.3p62
BUNDLED WITH
2.0.2
答案 1 :(得分:4)
最可能需要解决的是gem install bundler -v 2.0.2
,然后是bundle update --bundler
。提交在您的Gemfile.lock中所做的更改,然后您的下一次Heroku推送将顺利进行。