无法通过套接字'/tmp/mysql.sock'连接到本地MySQL服务器

Ste*_*res 2 mysql ruby-on-rails-3

我是网络开发和RoR的全新手 - 一个超级棒! - 我正在通过lynda.com参加在线RoR课程.很高兴加入StackOverflow社区,非常感谢路障的一些帮助.

当我设置我的基本应用程序并成功运行一些迁移时,MySQL和localhost工作了好几周,但今天我在启动我的rails服务器时遇到这个MySQL错误并在我的浏览器中查看http:// localhost:3000 /:

Mysql2 :: Error(无法通过套接字'/tmp/mysql.sock'连接到本地MySQL服务器'(2)):

我不认为我已经改变了我的环境中的任何相关内容,所以我想知道我是否需要更新宝石或类似的东西?

我已经在谷歌和StackOverflow上找了好几个小时了,现在仍然无法弄清楚这里出了什么问题,以及如何解决它.其他解决方案似乎与新设置有关,而不是与莫名其妙地打破的工作设置有关.

这是一些背景:


从我的config/database.yml:

development:
  adapter: mysql2
  encoding: utf8
  reconnect: false
  database: simple_cms_development
  pool: 5
  username: simple_cms
  password: XXXXXXXXX
  socket: /tmp/mysql.sock
Run Code Online (Sandbox Code Playgroud)

几周前,当MySQL和localhost工作正常时,我保存了一个命令行:

Last login: Mon Aug 15 21:34:23 on ttys000
sdemessieres$ cd sites/simple_cms
sdemessieres$ pwd
/Users/sdemessieres/sites/simple_cms
sdemessieres$ rails server
=> Booting WEBrick
=> Rails 3.0.7 application starting in development on http://0.0.0.0:3000
=> Call with -d to detach
=> Ctrl-C to shutdown server
[2011-08-22 22:28:01] INFO  WEBrick 1.3.1
[2011-08-22 22:28:01] INFO  ruby 1.8.7 (2009-06-12) [universal-darwin10.0]
[2011-08-22 22:28:01] INFO  WEBrick::HTTPServer#start: pid=66952 port=3000


Started GET "/" for 127.0.0.1 at Mon Aug 22 22:28:20 -0400 2011
  Processing by DemoController#index as HTML
Run Code Online (Sandbox Code Playgroud)

等......(从这里工作得很好)


但是今天我尝试了相同的命令并收到错误:

Last login: Mon Sep  5 12:13:22 on ttys000
sdemessieres$ cd sites/simple_cms
sdemessieres$ pwd
/Users/sdemessieres/sites/simple_cms
sdemessieres$ rails server
=> Booting WEBrick
=> Rails 3.0.7 application starting in development on http://0.0.0.0:3000
=> Call with -d to detach
=> Ctrl-C to shutdown server
[2011-09-05 12:33:09] INFO  WEBrick 1.3.1
[2011-09-05 12:33:09] INFO  ruby 1.8.7 (2009-06-12) [universal-darwin10.0]
[2011-09-05 12:33:09] INFO  WEBrick::HTTPServer#start: pid=11027 port=3000


Started GET "/" for 127.0.0.1 at Mon Sep 05 12:33:41 -0400 2011

Mysql2::Error (Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)):


Rendered /Library/Ruby/Gems/1.8/gems/actionpack-3.0.7/lib/action_dispatch/middleware/templates/rescues/_trace.erb (0.8ms)
Rendered /Library/Ruby/Gems/1.8/gems/actionpack-3.0.7/lib/action_dispatch/middleware/templates/rescues/_request_and_response.erb (1.7ms)
Rendered /Library/Ruby/Gems/1.8/gems/actionpack-3.0.7/lib/action_dispatch/middleware/templates/rescues/diagnostics.erb within rescues/layout (6.3ms)
Run Code Online (Sandbox Code Playgroud)

所以我从训练中回到了数据库笔记,并尝试从我以前运行但不再使用的命令行连接到MySQL:

sdemessieres$ pwd
/Users/sdemessieres/sites/simple_cms
sdemessieres$ which mysql
/usr/local/mysql/bin/mysql
sdemessieres$ mysql --version
mysql  Ver 14.14 Distrib 5.5.13, for osx10.6 (i386) using readline 5.1
sdemessieres$ mysql -u root -p
Enter password: 
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
sdemessieres$ 
Run Code Online (Sandbox Code Playgroud)

一个StackOverflow 线程给了我这个线索,但它似乎只是强调了我的设置是正确的.

sdemessieres$ mysql_config |grep -- --socket
        --socket         [/tmp/mysql.sock]
Run Code Online (Sandbox Code Playgroud)

正如我所说,我是一个初学者,所以任何帮助将不胜感激,谢谢!

小智 6

这个问题有些过时,但我在研究类似问题时遇到过这个问题.使用mysql_config命令确认套接字位置和名称有助于解决我的问题.

我得到了相同的错误,并调整了套接字入口路径config/database.yml以匹配我找到.sock文件的位置.

但是,除了路径更改之外,我的database.yml文件中的套接字条目也被引用"mysql.sock",就像我在搜索期间与此问题相关的大多数讨论一样.

输出mysql_config略有不同.它显示文件名是"mysqld.sock"......注意'd',而不是mysql.sock.我错过了,因为我专注于这条道路.

mysql装置是一台服务器只VPS,没有客户端,这可以解释在套接字文件名的差别上.