在本地主机上连接到 MySQL 时排除 PyMySQL 连接错误
当尝试使用 PyMySQL 连接到本地主机上的 MySQL 数据库时,您可能会遇到错误消息:
socket.error: [Errno 111] Connection refused pymysql.err.OperationalError: (2003, "Can't connect to MySQL server on 'localhost' (111)")
要解决此问题,请考虑以下故障排除步骤:
验证 MySQL 服务状态
确保 MySQL服务正在运行。您可以通过命令提示符进行检查:
mysqladmin -u root -p status
网络连接
确认可以从您的计算机访问数据库主机(通常是 localhost)。运行以下命令:
ping localhost
检查 MySQL 套接字位置
执行以下命令以确定 MySQL 套接字的路径:
mysqladmin variables | grep socket
将 PyMySQL 连接字符串中的 unix_socket 参数设置为检索到的路径。例如:
<code class="python">pymysql.connect(db='base', user='root', passwd='pwd', unix_socket="/tmp/mysql.sock")</code>
验证 MySQL 端口
使用以下命令检查 MySQL 服务器使用的端口:
mysqladmin variables | grep port
如果端口不是默认的 3306,请在 PyMySQL 连接字符串中设置端口参数:
<code class="python">pymysql.connect(db='base', user='root', passwd='pwd', host='localhost', port=XXXX)</code>
其他故障排除提示
以上是为什么使用 PyMySQL 连接到本地主机上的 MySQL 时出现“连接被拒绝”错误?的详细内容。更多信息请关注PHP中文网其他相关文章!