无法在Windows 7上安装MySQL2 gem

16
我在安装过程中遇到了以下错误信息,请告诉我是否需要提供更多细节。
我按照以下位置的说明进行操作: 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

8
如果您,亲爱的读者,刚开始接触这个问题...请做好遭受痛苦的准备。Windows下Ruby on Rails对mysql的支持很糟糕。 - Pablo Marambio
7个回答

31

您想安装的 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安装说明(该页面链接在下载页面中)

在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来避免路径中的空格问题,这是您应该始终避免的。
希望这可以帮助您。

2
我尝试了相同的方法,但失败了:我只是输入了'gem install mysql2'而没有指定任何版本,但仍然出现了相同的错误。 - Pablo Marambio
3
我已经安装了Mysql Server,但是最新版本是5.5。尽管我安装了所有的功能和库,但它里面没有lib/opt文件夹。 - Pablo Marambio
3
没问题,我安装了MySQL Connector C 6.0.2,它包括头文件和lib/opt文件夹,但还是没有结果。在测试libmysql时,它仍然崩溃。看起来它忽略了--with-mysql-dir和--with-mysql-lib参数。 - Pablo Marambio
2
这对我没用 - 我尝试了一个简单的 gem install mysql2,它起作用了,但是从JetBrains RubyMine中进行的bundle install仍然尝试安装gem并失败了。我尝试使用上面的命令构建本地扩展,但也失败了:“ISO C90禁止混合声明和代码”。 :-/ - Stewart Johnson
@LuisLavena 我很抱歉因为我知道这个帖子非常老,但是我目前正在尝试手动安装mysql2 gem,因为我在工作中的连接不允许我通过cmd提示从外部主机安装软件包,这对于我所有其他gem文件都非常有效。然而,当我尝试为mysql2执行此操作时,它不起作用。我尝试手动安装当前版本(0.3.17)以及在此处建议的版本(0.2.6),但仍然遇到与OP中所述相同的错误。我还尝试查看是否在我的gemfile中指定ver是否有帮助,但没有成功:( - beckah
显示剩余5条评论

18

在搜索了一番后,我终于通过以下命令在命令提示符中安装成功:

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

试一下,应该可以工作。


2
这需要我们的 Gemfile 文件中加入 gem 'mysql2', '0.2.6' - Quv
我从版本列表中选择了一个包含Win二进制文件的较新版本。http://rubygems.org/gems/mysql2/versions - BBQ Chef

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。即使您选择安装 msi 中包含的所有功能,5.5 版本也不包括 lib/opt 文件夹。 - Pablo Marambio
这个指南现在也包含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"' - Ritesh Kumar

2

从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:

您需要将libmysql.dll添加到PATH环境变量中,最简单的方法是将其复制到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的版本匹配。


0

从这里开始:

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

看起来您还没有安装MySQL的驱动程序和应用程序。如果已经安装,它们是否被允许安装到默认位置?最低限度,如果服务器在不同的机器上运行,您需要客户端软件。


嗨,我有一个MySQL应用程序,并且我只安装了默认位置,但我的操作系统是64位版本(Windows 7),因此所有我的安装都在“Program Files(x86)”文件夹中,这会有问题吗?我尝试使用以下命令选项:E:\ work_desk \ trunk> gem install mysql2 - -- '--with-mysql-lib =“C:\ Program Files(x86)\ MySQL \ MySQL Server 5.5 \ lib”--with-mysql-include =“C:\ Program Files(x86)\ MySQL \ 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 - Lohith MV
但我仍然遇到错误,这次它说权限被拒绝了? - Lohith MV
我拥有我的账户的管理员权限,我尝试使用管理员身份,结果相同,我正在使用Rails 3.0.5,所以我需要mysql2。 - Lohith MV
为什么Ruby on Rails这么难?我也有同样的问题,我快要放弃了...无法让Rails与MySQL通信...这太令人沮丧了... - femi
我相信你需要/想要将libmysql.dll文件添加到你的PATH路径中,请参考https://dev59.com/oW435IYBdhLWcg3whQc5#5517200。 - rogerdpack
显示剩余2条评论

0
  1. 安装32位的MySQL Connector/C,可以在这里下载。
  2. 将libmysql.dll从Connector/C安装目录复制到已安装的Ruby目录下的bin文件夹中。

然后重新安装gem包。


0

我尝试了@Mrk Fldig的解决方案,但它没有起作用... 所以解决问题的方法如下:

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

要注意的一个陷阱是,我将反斜杠(\)改为了正斜杠(/)。我用反斜杠尝试了相同的过程,但它没有起作用。

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


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接