记录:com.mysql.cj.jdbc.exceptions.CommunicationsException...【亲测有效】

168 阅读5分钟

​一起养成写作习惯!这是我参与「掘金日新计划 · 4 月更文挑战」的第9天,点击查看活动详情

前言🔥

👨‍🎓作者:bug菌

✏️博客:CSDN掘金

💌公众号:猿圈奇妙屋

🚫特别声明:原创不易,转载请附上原文出处链接和本文声明,谢谢配合。

🙏版权声明:文章里可能部分文字或者图片来源于互联网或者百度百科,如有侵权请联系bug菌处理。

       哈喽,小伙伴们,我是bug菌呀👀,不知不觉就一年又4月,正是踏青郊游的好时节。可上海疫情,除了在家远程办公就是看点技术顺便卷点文章。这不是4月又出了更文活动,逼自己一把,坚持每天做点内容输出,养成写作习惯,将来你会回来感谢曾经的自己坚持了一把才有此刻的辉煌成就。

       小伙伴们在批阅文章的过程中如果觉得文章对您有一丝丝帮助,还请别吝啬您手里的赞呀,大胆的把文章点亮👍吧,您的点赞三连(收藏⭐️+关注👨‍🎓+留言📃)就是对bug菌我创作道路上最好的鼓励与支持😘。时光不弃🏃🏻‍♀️,掘金不停💕,加油☘️​

一、环境说明🔥

环境:jdk1.8 +mysql 5.6 + 阿里云centos7.6

二、报错内容 🔥

报错完整截图:

com.mysql.cj.jdbc.exceptions.CommunicationsException: Communications link failure

​三、报错排查 🔥

       很离谱,我本地开发与线上测试环境共用一个数据库,上一秒还在本地开发好好的,为何打了个jar包,运行也就报数据库通讯连接故障。我仔细核对了数据库连接等配置信息,与本地完全一致,然后也排查了本地与线上ip及端口,都是能访问的。navicat连接也正常。讲道理,不可能存在问题啊,但是拒绝访问,百思不得其解。

       我再把该jar在本地运行,也是正常的。

​       然后我脑洞突然清奇了一下,该不会是该数据库没有开启远程连接吧?虽然我使用的该服务器ip加端口号,但是数据库如果未开通远程连接,ip它是不认的,只认localhost 与 127.0.0.1,这时我才反应过来,于是我立马去查看了现有用户,密码及允许连接的主机,果不其然,Host对应的就只有localhost 与 127.0.0.1这两,难怪我用ip访问不上。大家可以参考文末的附录。

四、解决方案 🔥

       将ip改成localhost,但这只适用于mysql服务与你部署的后端服务在一台云主机上才行。要不然改成localhost 也于事无补。

       再重新执行启动命令启动一下。

       看到了控制台打印秒数,我就知道,报错果然是ip的问题,虽然不是很难被发现,排查一下问题也容易发现问题点,但是如果你看了我写的,我相信你能在第一时间定位问题并解决问题,这就是看了这篇文章能带给你的东西。

五、附录🔥

       这里多设置了一行host为%。%这里表示的是允许任意host访问。但一般不建议这么设置奥,比较危险,谨慎操作。

... ...

       ok,以上这样就好啦,如果还想学习更多,你可以看看我的往期热文推荐哦,每天积累一个奇淫小知识,日积月累下去,你一定能成为令人敬仰的大佬的。好啦,咱们下期见~

七、往期推荐🔥

八、文末🔥

       如果还想要学习更多,小伙伴们可关注bug菌专门为大家创建的专栏《SpringBoot零基础入门》,从无到有,从零到一!希望能帮到大家。

我是bug菌,一名想走👣出大山改变命运的程序猿。接下来的路还很长,都等待着我们去突破、去挑战。来吧,小伙伴们,我们一起加油!未来皆可期,fighting!

最后送大家两句我很喜欢的话,与诸君共勉!

**************************************************

☘️做你想做的人,没有时间限制,只要愿意,什么时候都可以start,

🍀你能从现在开始改变,也可以一成不变,这件事,没有规矩可言,你可以活出最精彩的自己。

**************************************************

💌如果文章对您有所帮助,就请留下您的吧!(#^.^#);

💝如果喜欢bug菌分享的文章,就请给bug菌点个关注吧!(๑′ᴗ‵๑)づ╭❤~;

💗如果对文章有任何疑问,还请文末留言或者加群吧【QQ交流群:708072830】;

💞鉴于个人经验有限,所有观点及技术研点,如有异议,请直接回复参与讨论(请勿发表攻击言论,谢谢);

💕版权声明:原创不易,转载请附上原文出处链接和本文声明,版权所有,盗版必究!!!谢谢。