排除 MySQL 中常见错误的实用招术,什么是微服务扩展性和高可用、可扩展性
图 1. 无法连接到本地 MySQL 服务器
该错误表示主机系统上没有 MySQL 服务器(mysqld)在运行,或者尝试连接到服务器时指定了错误的 Unix 套接字文件名或 TCP/IP 端口。
结合使用
ps 命令和 grep 命令,检查数据库服务器主机上名为 mysqld 的进程,以此确保服务器在运行,如图所示。
$ ps xa | grep mysqld | grep -v mysqld
如果上述命令未显示输出,则表示数据库服务器没在运行。因此客户机无法连接到它。要启动服务器,运行下列 systemctl 命令。
$ sudo systemctl start mysql #Debian/Ubuntu
$ sudo systemctl start mysqld #RHEL/CentOS/Fedora
要验证 MySQL 服务状态,请使用下列命令。
$ sudo systemctl status mysql #Debian/Ubuntu
$ sudo systemctl status mysqld #RHEL/CentOS/Fedora
图 2. 检查 MySQL 状态
可以从上述命令的输出看出,MySQL 服务失败。这种情况下,你可以尝试重新启动,再次检查状态。
$ sudo systemctl restart mysql
$ sudo systemctl status mysql
图 3. 重新启动 MySQL 并验证状态
此外,如果服务器在运行,如下列命令所示,但你仍看到上述错误,还应验证 TCP/IP 端口是否被防火墙阻止或任何端口在阻止服务。
$ ps xa | grep mysqld | grep -v mysqld
要找到服务器在侦听的端口,使用 netstat 命令,如下所示。
$ sudo netstat -tlpn | grep “mysql”
2. 无法连接到 MySQL 服务器
另一个常遇到的连接错误是“(2003) Can’t connect to MySQL server on ‘server’ (10061)”,这意味着网络连接被拒绝。
在这里,先检查 MySQL 服务器是否在系统上运行,如上所示。还要确保服务器已启用网络连接,用于连接的网络端口是服务器上配置的那个端口。
试图连接到 MySQL 服务器时可能会遇到的其他常见错误有:
ERROR 2003: Can’t connect to MySQL server on ‘host_name’ (111)
ERROR 2002: Can’t connect to local MySQL server through socket ‘/tmp/mysql.sock’ (111)
这些错误表明服务器可能在运行,但你试图使用有别于服务器在侦听的 TCP/IP 端口、命名管道或 Unix 套接字文件来进行连接。
MySQL 中访问被拒绝错误
在 MySQL 中,用户帐户是根据用户名和用户连接到服务器所用的客户机主机或主机来定义的。此外,帐户还可能拥有身份验证凭据,比如密码。
虽然“访问被拒绝”错误有许多不同的原因,但一个常见原因与服务器允许客户机程序在连接时使用的 MySQL 帐户有关。它表示连接中指定的用户名没有访问数据库的权限。
MySQL 允许创建使客户机用户能够连接到服务器并访问服务器管理的数据的帐户。在这方面,如果你遇到访问被拒绝错误,检查是否允许用户帐户通过你所使用的客户机程序连接到服务器。
可以通过运行 SHOW GRANTS 命令查看某个特定帐户拥有的权限,如图所示。
SHOW GRANTS FOR ‘tecmint’@‘localhost’;
可以在 MySQL shell 中使用下列命令,将特定数据库上特定用户的权限授予远程 IP 地址。
grant all privileges on *.test_db to ‘tecmint’@‘192.168.0.100’;
flush privileges;
此外,访问被拒绝错误也可能由连接到 MySQL 时遇到的问题引起,请参阅前面解释的错误。
与 MySQL 服务器的连接断开
由于下列原因,你可能会遇到该错误:网络连接不早畅、连接超时或 BLOB 值出现问题(值大于 max_allowed_pa??cket)。如果出现网络连接问题,确保你有良好的网络连接,访问远程数据库服务器时尤为如此。
如果是连接超时问题,尤其是 MySQL 试图与服务器初始连接时,加大 connect_timeout 参数的值。但是如果 BLOB 值大于 max_allowed_pa??cket,需要在/etc/my.cnf 中的[mysqld]或[client]部分下面为 max_allowed_pa??cket 设置更高的值,如图所示。
[mysqld]
connect_timeout=100
max_allowed_packet=500M
如果你无法访问 MySQL 配置文件,可以在 MySQL shell 中使用下列命令来设置该值。
SET GLOBAL connect_timeout=100;
SET GLOBAL max_allowed_packet=524288000;
MySQL 连接太多
如果 MySQL 客户机遇到“太多连接”错误,表示所有可用连接被其他客户机使用。连接数量(默认为 151)由 max_connections 系统变量控制;可以通过在/etc/my.cnf 配置文件中加大值、允许更多连接来解决问题。
[mysqld]
max_connections=1000
6. 溢出内存 MySQL
评论