[英]Installing MySQL and mysql gem on Snow Leopard
弄清楚如何在Snow Leopard 10.6.2上启动并运行MySQL和mysql gem,这确实是一项艰巨的工作。 我遵循了各种职位的指示,但尚未成功:
我从源代码构建MySQL版本5.1.39,并成功安装。 尝试使用(mysql -u root -p)登录时,mysql返回以下错误:
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)
这显然意味着MySQL Server(mysqld)没有运行。
which mysql: /usr/local/mysql/bin/mysql
which ruby: ruby 1.8.7 (2009-04-08 patchlevel 160) [i686-darwin9])
gem -v: 1.3.5
mysql: Server version: 5.1.39 MySQL Community Server (GPL)
经过大量的搜寻,我发现
这个命令可以启动mysqld:
sudo /usr/local/mysql/bin/mysqld_safe --user=mysql &
在Mac OS X 10.5和更高版本中,“首选项窗格MySQL工具”可能已损坏
此命令应在Snow Leopard上正确安装mysql gem:
sudo gem uninstall mysql sudo env ARCHFLAGS="-arch x86_64" gem install mysql -- --with-mysql-config=/usr/local/mysql/bin/mysql_config
最后,我使用rake db:create之类的东西得到了以下错误:
dyld: lazy symbol binding failed: Symbol not found: _mysql_init
Referenced from: /opt/local/lib/ruby/gems/1.8/gems/mysql-2.8.1/lib/mysql_api.bundle
Expected in: flat namespace
dyld: Symbol not found: _mysql_init
Referenced from: /opt/local/lib/ruby/gems/1.8/gems/mysql-2.8.1/lib/mysql_api.bundle
Expected in: flat namespace
这个错误使我引至以下文章: http : //cho.hapgoods.com/wordpress/?p=158 ,基本上告诉我与XCode 3.0一起提供的Ruby版本在64位环境中不起作用,安装32位版本的MySQL。
有什么建议,如何进行?
尽管从源代码构建不一定是一个坏主意,即使官方发行版是使用更好的编译器构建的,但是使用MacPorts( http://www.macports.org/install.php )进行构建可能比自建安装。
尽管您可以纠结OS X提供的Ruby和MySQL,但以我的经验来看,完全在MacPorts领域(/ opt)中工作并保持原始发行版本更加容易。
另一个优点是您可以获得更新的Ruby可执行文件。 10.6随附1.8.7p72,其中MacPorts提供了1.8.7p174。
例:
sudo port install mysql5
sudo port install mysql5-server
sudo port install rb-mysql
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.