无法在 Windows 7 上安装 MySQL2 gem

Posted

技术标签:

【中文标题】无法在 Windows 7 上安装 MySQL2 gem【英文标题】:Unable to install MySQL2 gem on Windows 7 【发布时间】:2011-07-19 01:29:39 【问题描述】:

我在安装时收到以下错误消息,如果我需要发布更多详细信息,请告诉我。

我按照以下位置的说明进行操作: https://github.com/oneclick/rubyinstaller/wiki/Development-Kit

我正在使用 ruby​​ 1.9.2p136 (2010-12-25) [i386-mingw32]。

这是我得到的:

E:\work_desk\trunk>gem install mysql2 -v 0.2.4
Temporarily enhancing PATH to include DevKit...
Building native extensions.  This could take a while...
ERROR:  Error installing mysql2:
        ERROR: Failed to build gem native extension.

C:/Ruby192/bin/ruby.exe extconf.rb
checking for rb_thread_blocking_region()... yes
checking for main() in -llibmysql... no
*** 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=C:/Ruby192/bin/ruby
        --with-mysql-dir
        --without-mysql-dir
        --with-mysql-include
        --without-mysql-include=$mysql-dir/include
        --with-mysql-lib
        --without-mysql-lib=$mysql-dir/lib
        --with-libmysqllib
        --without-libmysqllib


Gem files will remain installed in C:/Ruby192/lib/ruby/gems/1.9.1/gems/mysql2-0.
2.4 for inspection.
Results logged to C:/Ruby192/lib/ruby/gems/1.9.1/gems/mysql2-0.2.4/ext/mysql2/ge
m_make.out

【问题讨论】:

如果您,亲爱的读者,刚刚开始处理这个问题...准备受苦。 windows ror 对 mysql 的支持很糟糕。 【参考方案1】:

从这里:

checking for main() in -llibmysql... no

您似乎尚未安装 MySQL 驱动程序和应用程序。如果是这样,是否允许他们安装到默认位置?如果服务器在另一台机器上运行,您至少需要客户端软件。

【讨论】:

嗨,我有 mysql 应用程序,我只将它们安装在默认位置,但我的操作系统是 64 位版本(windows 7),所以我所有的安装都将转到程序文件(x86)文件夹一个问题,我尝试使用以下命令行选项 E:\work_desk\trunk>gem install mysql2 -- '--with-mysql-lib="C:\Program Files (x8 6)\MySQL\MySQL Server 5.5\lib" --with-mysql-include="C:\Program Files (x86)\MySQ L\MySQL Server 5.5\include"' 错误:执行 gem ... (Errno::EACCES) 权限被拒绝 - C:/Ruby192/ lib/ruby/gems/1.9.1/gems/mysql2-0.2.6-x86-min gw32/lib/mysql2/1.9/mysql2.so 但我仍然收到错误,但这次它说权限被拒绝? 如果您的机器有一个管理帐户,您可能需要使用它来运行 gem 安装程序。另外,我通常不会尝试强制使用 gem 版本,而是让 gem 决定加载什么,这应该是默认/当前版本。而且,您确定要mysql2 而不是当前的mysql 我对我的帐户有管理权限,我也尝试使用管理员,结果相同,我使用的是 rails 3.0.5,所以我需要 mysql2。 为什么 ruby​​ on rails 这么难?我有同样的问题,我几乎要放弃了......无法让 Rails 与 mysql 对话......这令人沮丧......【参考方案2】:

您尝试安装的特定版本的 mysql2 gem (0.2.4) 不仅缺少适用于 Windows 的二进制文件,而且在 Windows 上也存在问题。

请安装mysql2 gem,不注明版本:

gem install mysql2

它将安装最新版本(在我发布此内容时为 0.2.6),并且还为 Windows 提供跳过编译步骤的二进制文件。

如果您仍想强制编译(因为您的 MySQL 版本与用于生成二进制 gem 的版本不同,您需要从 RubyInstaller 网站安装 RubyInstaller 的 DevKit:

http://rubyinstaller.org/downloads

并关注我们 wiki 中的 DevKit installation instructions(从下载页面链接)

您需要在 gem 安装过程中提供头文件和库的路径,并根据以下说明调整 MySQL 安装位置:

subst X: "C:\Program Files (x86)\MySQL\MySQL Server 5.1" 
gem install mysql2 --platform=ruby -- --with-mysql-dir=X: --with-mysql-lib=X:\lib\opt 
subst X: /D

上述命令使用subst 来避免路径带有空格的问题,您应该始终避免

希望这会有所帮助。

【讨论】:

令人印象深刻!这对我来说是一种魅力。它绝对应该被视为这个问题的答案。 我尝试了同样的方法但失败了:我只是输入了“gem install mysql2”,没有任何版本,但还是抛出了同样的错误。 路易斯,我做到了。我安装了Mysql Server,但最新版本:5.5。但是,即使我安装了所有功能和库,其中也没有 lib/opt 文件夹。 不,没什么。我安装了 MySQL 连接器 C 6.0.2,它确实包含头文件和 lib/opt 文件夹,但什么也没有。它仍然会导致 libmysql 的测试崩溃。似乎忽略了 --with-mysql-dir 和 --with-mysql-lib 参数。 这对我不起作用——我做了一个简单的gem install mysql2,它起作用了,但是来自 JetBrains RubyMine 的bundle install 仍然尝试安装 gem 并且失败了。我尝试使用上面的命令构建本机扩展,但也失败了:“ISO C90 禁止混合声明和代码”。 :-/【参考方案3】:

如果仍然无法在 windows7 上安装 mysql2 gem 或者对后续步骤不是很清楚,那么请阅读这篇文章,它将帮助您逐步安装 - http://rorguide.blogspot.com/2011/03/installing-mysql2-gem-on-ruby-192-and.html

对于 mysql_api.so 错误 (C:/Ruby192/lib/ruby/gems/1.9.1/gems/mysql-2.8.1-x86-mingw32/lib/1.9/mysql_api.so),将“libmySQL.dll”文件从 C:\Program Files\MySQL\MySQL Server 5.1\bin 复制到 C:\Ruby192\bin

安装路径可能会有所不同,详情请参考这篇文章-http://rorguide.blogspot.com/2011/03/getting-error-specified-module-could.html。

希望这将帮助您解决问题。

【讨论】:

指南中提到的是 mySql 5.1,而不是 5.5。 5.5 不包含 lib/opt 文件夹,即使您选择安装 msi 中包含的所有功能。 本指南现在也包含 mysql5.5 :) 您可以使用命令安装:gem install mysql2 -- '--with-mysql-lib="c:\Program Files\MySQL\MySQL Server 5.5 \lib" --with-mysql-include="c:\Program Files \MySQL\MySQL Server 5.5\include"'【参考方案4】:

在四处寻找让它工作的方法后,我终于在命令提示符下安装了它:

gem install mysql2 -v 0.2.6

结果如下:

Fetching: mysql2-0.2.6-x86-mingw32.gem (100%)
Successfully installed mysql2-0.2.6-x86-minw32
1 gem installed
Installing ri documentation for mysql2-0.2.6-x86-mingw32...
Enclosing class/module 'mMysql2' for class Client not known
Installing RDoc documentation for mysql2-0.2.6-x86-mingw32...
Enclosing class/module 'mMysql2' for class Client not known

试试看。它应该可以工作。

【讨论】:

这需要我们的 gemfile 有gem 'mysql2', '0.2.6' 我从版本列表中选择了一个更高版本,包括 win 二进制文件。 rubygems.org/gems/mysql2/versions【参考方案5】:
    安装 32 位 mysql 连接器/c 在here 获取 将 libmysql.dll 从您安装 connector/c 的目录复制到 %installed ruby​​ 目录%/bin/

然后重新安装 gem。

【讨论】:

【参考方案6】:

我已经尝试过@Mrk Fldig 的解决方案,但没有奏效... 那么解决问题的是:

    为 windows 7 32 位下载了最新的 MySQL Installer 使用以下命令安装 gem:gem install mysql2 --platform=ruby -- '--with-mysql-dir="C:/Program Files/MySQL/MySQL Connector C 6.1 6.1.2/"'

需要注意的一个陷阱是我将反斜杠 (\) 更改为普通斜杠 (/)。我用反斜杠尝试了相同的过程,但没有成功。

安装程序已在MySQL Connector C 6.1 6.1.2 目录中包含 MySQL 的 C 连接器。因此,只传递--with-mysql-dir 参数而不传递--with-mysql-lib--with-mysql-include 参数,会使gem 查看libinclude 目录的同一目录

【讨论】:

【参考方案7】:

从 RailsInstaller 开始。

这是假设您在本地运行 mysql 服务器(本地开发),并且您的 Ruby 是 32 位编译的。 (检查ruby -v.x64 || i386。)

下载 mysql-community-web-installer。在右上角选择 32 位。你几乎只需要服务器。工作台也很方便。

gem命令需要不带空格的路径,所以使用subst:

subst X: "C:\Program Files (x86)\MySQL\MySQL Server 5.6"
gem install mysql2 -v=0.3.13 --platform=ruby -- --with-mysql-dir=X:

你将需要在 PATH 中的 libmysql.dll -- 最简单的方法就是将它复制到 Ruby 的 bin 目录:

copy "C:\Program Files (x86)\MySQL\MySQL Server 5.6\lib\libmysql.dll" "C:\RailsInstaller\Ruby2.0.0\bin"

注意事项

不要从 PowerShell 执行此操作! (DevKit 无法在 powershell 中更改路径信息。)

确保所有库都是 32 位的,因为 RailsInstaller 的 ruby​​ 等都是 32 位编译的,需要链接到 32 位库。

如果您不想要本地服务器,只需安装 C 连接器,然后使用该目录和 libmysql.dll 执行这些说明。不要混用 - 确保 .dll 与您编译 gem 时所针对的版本相匹配。

【讨论】:

以上是关于无法在 Windows 7 上安装 MySQL2 gem的主要内容,如果未能解决你的问题,请参考以下文章

无法安装旧的 mysql2 gem

错误“...无法加载此类文件 -- mysql2/2.0/mysql2 (LoadError)”。在带有 Ruby 2.0.0 的 Windows XP 上

如何在windows里面安装MySQL

如何在 Ubuntu 16.04 上安装 mysql2 [错误:安装 mysql2 时出错:错误:无法构建 gem 本机扩展。] [重复]

无法在 Bigsur 上安装 mysql2 Gem

无法安装 mysql2 gem