mysql 报错 too many connections 或者 processlist中大量 waiting in connection_control plugin
-
原因1.
数据库打开文件数超过linux默认打开文件
数量1024 ulimit -a
查看openfiles数量 -
原因2.
用户名或密码错误,不停连接,默认mysql连接数被耗尽.
根因:链接异常(用户名密码错误)导致connectioncontrol 插件进行拦截,拦截用户身份验证处于 “waiting in connection_control plugin” 的链接延迟状态。 -
解决方案:
-
修改connection_control 插件配置参数 - 可选
SET GLOBAL connection_control.failed_login_threshold = 1000000;
将 connection_control.failed_login_threshold 参数设置为一个非常大的值,这将使插件几乎不再对登录尝试进行限制,从而达到类似禁用的效果。请注意,这种方法并非官方推荐的禁用插件的方式,因此在生产环境中使用时需要谨慎考虑可能的影响
-
也有可能是Mysql密码自动过期了,此时微服务也会报错。
-
提示密码过期: SQLException: Your password has expired. To log in you must change it using a client that supports e
-
由于密码过期导致连接失败,所以也会频繁重连,此时ip可能会被Mysql block 。 此时数据库负载可能也会突然升高。
java.sql.SQLException: null, message from server: “Host ‘172.18.224.48’ is blocked because of many connection errors; unblock with ‘mysqladmin flush-hosts’”) -
解决方案
- 解决密码过期问题 - 重置密码即可
- 或者临时取消过期机制: ALTER USER ‘repl’@‘%’ PASSWORD EXPIRE NEVER;
- 解决黑名单问题 - mysql> FLUSH HOSTS;
- 解决密码过期问题 - 重置密码即可
-
-