当我在测试套件中尝试连接到本地MySQL服务器时,它失败并显示以下错误:
OperationalError: (2002, "Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)")
但是,我始终可以通过运行命令行mysql程序连接到MySQL 。A ps aux | grep mysql显示服务器正在运行,并 stat /tmp/mysql.sock确认套接字存在。此外,如果在except该异常的子句中打开调试器,则可以使用完全相同的参数可靠地进行连接。
ps aux | grep mysql
stat /tmp/mysql.sock
这个问题可以相当可靠地重现,但是似乎不是100%,因为每当我遇到一次蓝月亮时,我的测试套件就可以运行而不会遇到此错误。当我尝试运行sudo dtruss时没有复制。
sudo dtruss
所有客户端代码都在Python中,尽管我不知道这是如何相关的。
切换为使用主机127.0.0.1会产生错误:
127.0.0.1
DatabaseError: Can't connect to MySQL server on '127.0.0.1' (61)
MySQL手册的相关部分在这里。我首先要完成列出的调试步骤。
另外,请记住,在这种情况下,localhost和127.0.0.1是不同的:
localhost
vi netstat -nlp
mysql -h 127.0.0.1
mysql -h localhost
如果以上方法均无济于事,那么你可能需要发布有关MySQL配置,实例化连接的确切方式等的更多详细信息。
sudo /usr/local/mysql/support-files/mysql.server start
这对我有用。但是,如果这不起作用,请确保mysqld正在运行并尝试连接。