博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
本机jdbc连接报The user specified as a definer ('root'@'%') does not exist
阅读量:4571 次
发布时间:2019-06-08

本文共 736 字,大约阅读时间需要 2 分钟。

昨晚一台测试服务器连接本机的mysql时,有些调用存储过程报"The user specified as a definer ('root'@'%') does not exist",后来发现root@%用户被删除了,但因为是通过localhost连接的,始终没明白为什么会出现这个问题,后来临时创建了root@%,问题解决了。

早上11点,问题又出现了,一个同事又把root@%给删了,就是因为有几台阿里云上的mysql服务器,因为mysql root密码策略没有启用导致弱密码被攻击了,所以就想着把root远程给删了。经过三四次反复重启应用,发现jdbc连接本机的时候,mysql服务端识别客户端来源纯粹取决于jdbc连接建立的时候,socket获取主机信息的时候传递的是localhost/127.0.0.1还是eth0网卡的ip,不能保证连接localhost,mysql服务器就当这个jdbc连接就来自localhost/127.0.0.1,所以就会出现标题中所说的问题。找到根本原因后,解决就很容易了。通知运维组,把所有线上mysql应用连接全部从root账号换成应用统一账号,并启用强密码策略。

PS:其实root@%本身并没有什么问题,问题在于mysql当前版本没有oracle那么强的密码管理策略,比如一段时间内连续超过N次密码错误账号就被自动lock。root@%只是恰巧躺枪而已。就像在oracle中,其实我们很多的业务用户都是授予dba权限,因为很多时候都是通过navicat/sqlyog类管理,非要建个用户各种授权,新手各种问题、老手闲麻烦。

转载于:https://www.cnblogs.com/zhjh256/p/6117678.html

你可能感兴趣的文章
23醒
查看>>
win7每天出现taskeng.exe进程的解决方案
查看>>
React Children
查看>>
大数据等最核心的关键技术:32个算法
查看>>
Maven多模块项目搭建
查看>>
Scala
查看>>
Android 中LinearLayout控件属性
查看>>
面向对象之多态性
查看>>
树状数组
查看>>
【2019.8.14 慈溪模拟赛 T1】我不是!我没有!别瞎说啊!(notme)(BFS+DP)
查看>>
多任务--进程 及 进程间通信
查看>>
多线程/多进程+QProgressBar实现进度条
查看>>
多任务(进程)案例----- 拷贝文件夹
查看>>
Kotlin的快速入门
查看>>
底层原理
查看>>
21. Merge Two Sorted Lists
查看>>
创建数组
查看>>
dict使用
查看>>
ASP.NET MVC的帮助类HtmlHelper和UrlHelper
查看>>
02_ListActive中响应事件 并LogCat输出
查看>>