Rails 5 - LoadError: Error loading the 'mysql2' Active Record adapter. mysql2 is not part of the bundle

Rails 5 - LoadError: Error loading the 'mysql2' Active Record adapter. mysql2 is not part of the bundle

我有一个长期稳定的 Rails 5.1 应用程序部署到 Ubuntu 18.04.3 使用 MySQL.

我昨天来部署一个普通的更新,但由于某种原因我开始收到错误,

LoadError:加载 'mysql2' Active Record 适配器时出错。少了一个gem就靠什么了? mysql2 不是捆绑包的一部分。将它添加到您的 Gemfile。

当然,gem 已经在我的 Gemfile 中(和 Gemfile.lock),并且已安装在部署机器上。我做了一些不相关的 Gemfile 更改(切换到 mini_racer 并添加了 bcrypt),这要求我在 2.0.1 上更新到 Bundler 2.0.2,但仅此而已。

我尝试过的事情:

  1. 我已经尝试在任何 gem 更改之前返回到代码库并切换回 bundler 2.0.1,但我在部署时仍然遇到同样的问题 - 现在它坏了, 好像一直坏掉。

  2. 我尝试部署到我设置的完全独立的服务器(仍在 Ubuntu 18.04 上),现在看到同样的问题。

  3. 我找到了这些 ,那里的修复是回到 mysql2 gem 的早期版本(我试过 0.3.20 作为我看到提到 0.3.21 不起作用),但这并不能解决我的问题。我试过在服务器端卸载所有其他版本。

  4. 围绕上述链接问题的评论说这将在 Rails 5 中修复(我已经在使用 5.1)但我完成了更新我的 Rails 的练习应用程序到 5.2 以获得最新的 gems,并指定 mysql 0.5.2 以查看我是否可以跳过 mysql2 的版本来解决这个问题,但我仍然遇到了同样的问题问题。

我的 'current' Gemfile.lock 文件粘贴在下面,但是这个问题从 Rails 5.1.7 和 Bundler 2.0.1 开始,我已经尝试了 [=52 的所有排列=] 0.3.18、0.3.20 和 0.5.2。

如果没有修复,我无法部署 Rails 应用程序更新,因此非常感谢任何关于如何解决此部署问题的建议。

GEM
  remote: https://rubygems.org/
  specs:
    actioncable (5.2.3)
      actionpack (= 5.2.3)
      nio4r (~> 2.0)
      websocket-driver (>= 0.6.1)
    actionmailer (5.2.3)
      actionpack (= 5.2.3)
      actionview (= 5.2.3)
      activejob (= 5.2.3)
      mail (~> 2.5, >= 2.5.4)
      rails-dom-testing (~> 2.0)
    actionpack (5.2.3)
      actionview (= 5.2.3)
      activesupport (= 5.2.3)
      rack (~> 2.0)
      rack-test (>= 0.6.3)
      rails-dom-testing (~> 2.0)
      rails-html-sanitizer (~> 1.0, >= 1.0.2)
    actionview (5.2.3)
      activesupport (= 5.2.3)
      builder (~> 3.1)
      erubi (~> 1.4)
      rails-dom-testing (~> 2.0)
      rails-html-sanitizer (~> 1.0, >= 1.0.3)
    activejob (5.2.3)
      activesupport (= 5.2.3)
      globalid (>= 0.3.6)
    activemodel (5.2.3)
      activesupport (= 5.2.3)
    activerecord (5.2.3)
      activemodel (= 5.2.3)
      activesupport (= 5.2.3)
      arel (>= 9.0)
    activestorage (5.2.3)
      actionpack (= 5.2.3)
      activerecord (= 5.2.3)
      marcel (~> 0.3.1)
    activesupport (5.2.3)
      concurrent-ruby (~> 1.0, >= 1.0.2)
      i18n (>= 0.7, < 2)
      minitest (~> 5.1)
      tzinfo (~> 1.1)
    addressable (2.7.0)
      public_suffix (>= 2.0.2, < 5.0)
    airbrussh (1.4.0)
      sshkit (>= 1.6.1, != 1.7.0)
    arel (9.0.0)
    autoprefixer-rails (9.7.1)
      execjs
    bcrypt (3.1.13)
    bindex (0.8.1)
    bootstrap-sass (3.3.7)
      autoprefixer-rails (>= 5.2.1)
      sass (>= 3.3.4)
    builder (3.2.3)
    byebug (11.0.1)
    capistrano (3.11.2)
      airbrussh (>= 1.0.0)
      i18n
      rake (>= 10.0.0)
      sshkit (>= 1.9.0)
    capistrano-bundler (1.6.0)
      capistrano (~> 3.1)
    capistrano-rails (1.4.0)
      capistrano (~> 3.1)
      capistrano-bundler (~> 1.1)
    capybara (2.18.0)
      addressable
      mini_mime (>= 0.1.3)
      nokogiri (>= 1.3.3)
      rack (>= 1.0.0)
      rack-test (>= 0.5.4)
      xpath (>= 2.0, < 4.0)
    childprocess (3.0.0)
    coffee-rails (4.2.2)
      coffee-script (>= 2.2.0)
      railties (>= 4.0.0)
    coffee-script (2.4.1)
      coffee-script-source
      execjs
    coffee-script-source (1.12.2)
    concurrent-ruby (1.1.5)
    crass (1.0.5)
    erubi (1.9.0)
    execjs (2.7.0)
    ffi (1.11.1)
    font-awesome-rails (4.7.0.5)
      railties (>= 3.2, < 6.1)
    globalid (0.4.2)
      activesupport (>= 4.2.0)
    httparty (0.17.1)
      mime-types (~> 3.0)
      multi_xml (>= 0.5.2)
    i18n (1.7.0)
      concurrent-ruby (~> 1.0)
    jbuilder (2.9.1)
      activesupport (>= 4.2.0)
    jquery-rails (4.3.5)
      rails-dom-testing (>= 1, < 3)
      railties (>= 4.2.0)
      thor (>= 0.14, < 2.0)
    libv8 (7.3.492.27.1)
    loofah (2.3.1)
      crass (~> 1.0.2)
      nokogiri (>= 1.5.9)
    mail (2.7.1)
      mini_mime (>= 0.1.1)
    marcel (0.3.3)
      mimemagic (~> 0.3.2)
    method_source (0.9.2)
    mime-types (3.3)
      mime-types-data (~> 3.2015)
    mime-types-data (3.2019.1009)
    mimemagic (0.3.3)
    mini_mime (1.0.2)
    mini_portile2 (2.4.0)
    mini_racer (0.2.6)
      libv8 (>= 6.9.411)
    minitest (5.13.0)
    multi_xml (0.6.0)
    mysql2 (0.3.20)
    net-scp (2.0.0)
      net-ssh (>= 2.6.5, < 6.0.0)
    net-ssh (5.2.0)
    nio4r (2.5.2)
    nokogiri (1.10.5)
      mini_portile2 (~> 2.4.0)
    public_suffix (4.0.1)
    rack (2.0.7)
    rack-test (1.1.0)
      rack (>= 1.0, < 3)
    rails (5.2.3)
      actioncable (= 5.2.3)
      actionmailer (= 5.2.3)
      actionpack (= 5.2.3)
      actionview (= 5.2.3)
      activejob (= 5.2.3)
      activemodel (= 5.2.3)
      activerecord (= 5.2.3)
      activestorage (= 5.2.3)
      activesupport (= 5.2.3)
      bundler (>= 1.3.0)
      railties (= 5.2.3)
      sprockets-rails (>= 2.0.0)
    rails-dom-testing (2.0.3)
      activesupport (>= 4.2.0)
      nokogiri (>= 1.6)
    rails-html-sanitizer (1.3.0)
      loofah (~> 2.3)
    railties (5.2.3)
      actionpack (= 5.2.3)
      activesupport (= 5.2.3)
      method_source
      rake (>= 0.8.7)
      thor (>= 0.19.0, < 2.0)
    rake (13.0.0)
    rb-fsevent (0.10.3)
    rb-inotify (0.10.0)
      ffi (~> 1.0)
    rubyzip (2.0.0)
    sass (3.7.4)
      sass-listen (~> 4.0.0)
    sass-listen (4.0.0)
      rb-fsevent (~> 0.9, >= 0.9.4)
      rb-inotify (~> 0.9, >= 0.9.7)
    sass-rails (5.1.0)
      railties (>= 5.2.0)
      sass (~> 3.1)
      sprockets (>= 2.8, < 4.0)
      sprockets-rails (>= 2.0, < 4.0)
      tilt (>= 1.1, < 3)
    selenium-webdriver (3.142.6)
      childprocess (>= 0.5, < 4.0)
      rubyzip (>= 1.2.2)
    sprockets (3.7.2)
      concurrent-ruby (~> 1.0)
      rack (> 1, < 3)
    sprockets-rails (3.2.1)
      actionpack (>= 4.0)
      activesupport (>= 4.0)
      sprockets (>= 3.0.0)
    sqlite3 (1.4.1)
    sshkit (1.20.0)
      net-scp (>= 1.1.2)
      net-ssh (>= 2.8.0)
    thor (0.20.3)
    thread_safe (0.3.6)
    tilt (2.0.10)
    turbolinks (5.2.1)
      turbolinks-source (~> 5.2)
    turbolinks-source (5.2.0)
    tzinfo (1.2.5)
      thread_safe (~> 0.1)
    uglifier (4.2.0)
      execjs (>= 0.3.0, < 3)
    web-console (3.7.0)
      actionview (>= 5.0)
      activemodel (>= 5.0)
      bindex (>= 0.4.0)
      railties (>= 5.0)
    websocket-driver (0.7.1)
      websocket-extensions (>= 0.1.0)
    websocket-extensions (0.1.4)
    will_paginate (3.2.1)
    xpath (3.2.0)
      nokogiri (~> 1.8)

PLATFORMS
  ruby

DEPENDENCIES
  bcrypt (~> 3.1.13)
  bootstrap-sass (~> 3.3.7)
  byebug
  capistrano-rails
  capybara (~> 2.13)
  coffee-rails (~> 4.2)
  font-awesome-rails
  httparty
  jbuilder (~> 2.5)
  jquery-rails
  mini_racer
  mysql2 (= 0.3.20)
  rails (~> 5.2)
  sass-rails (~> 5.0)
  selenium-webdriver
  sqlite3
  turbolinks (~> 5)
  uglifier (>= 1.3.0)
  web-console (>= 3.3.0)
  will_paginate

BUNDLED WITH
   2.0.2

这里的部分问题是 mysql2 不会建立在 Ubuntu 上。

原来是升级到 bundle 2.0.2,在我的 Rails 项目中引入了一个新的配置文件,

.bundle/config

其中包含,

BUNDLE_BUILD__MYSQL2: "--with-ldflags=-L/usr/local/opt/openssl/lib --with-cppflags=-I/usr/local/opt/openssl/include"
BUNDLE_WITHOUT: "production"
BUNDLE_WITH: "development"

具体的 BUNDLE_BUILD__MYSQL2 声明很奇怪,结果破坏了 mysql2 在我的 Ubuntu 机器上构建。

要解决此问题,我必须进行两项更改,

BUNDLE_WITHOUT: ""

...又开始包括 mysql2 gem(不知道为什么)。

但这在构建本机 mysql2 扩展时会产生错误,因为找不到 openssl headers / libs,已通过清除值

修复
BUNDLE_BUILD__MYSQL2: ""

我现在可以 运行 Rails 5.2 和 mysql2(使用 Bundler 2.0.2 安装)

希望这对其他人有帮助!