无法在 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 查看lib
和include
目录的同一目录
【讨论】:
【参考方案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/2.0/mysql2 (LoadError)”。在带有 Ruby 2.0.0 的 Windows XP 上
如何在 Ubuntu 16.04 上安装 mysql2 [错误:安装 mysql2 时出错:错误:无法构建 gem 本机扩展。] [重复]