无法通过套接字'/tmp/mysql.sock连接到本地MySQL服务器
当我在测试套件中尝试连接到本地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该异常的子句中打开调试器,则可以使用完全相同的参数可靠地进行连接。
这个问题可以相当可靠地重现,但是似乎不是100%,因为每当我遇到一次蓝月亮时,我的测试套件就可以运行而不会遇到此错误。当我尝试运行sudo dtruss
时没有复制。
所有客户端代码都在Python中,尽管我不知道这是如何相关的。
切换为使用主机127.0.0.1
会产生错误:
DatabaseError: Can't connect to MySQL server on '127.0.0.1' (61)
回答:
MySQL手册的相关部分在这里。我首先要完成列出的调试步骤。
另外,请记住,在这种情况下,localhost和127.0.0.1是不同的:
- 如果host设置为
localhost
,则使用套接字或管道。 - 如果将host设置为
127.0.0.1
,则客户端将被强制使用TCP / IP。因此,例如,你可以检查数据库是否正在侦听TCP连接
vi netstat -nlp
。它似乎正在侦听TCP连接,因为你说这mysql -h 127.0.0.1
很好。要检查是否可以通过套接字连接到数据库,请使用mysql -h localhost
。
如果以上方法均无济于事,那么你可能需要发布有关MySQL配置,实例化连接的确切方式等的更多详细信息。
以上是 无法通过套接字'/tmp/mysql.sock连接到本地MySQL服务器 的全部内容, 来源链接: utcz.com/qa/423045.html