前言🔥
👨🎓作者:bug菌
💌公众号:猿圈奇妙屋
🚫特别声明:原创不易,转载请附上原文出处链接和本文声明,谢谢配合。
🙏版权声明:文章里可能部分文字或者图片来源于互联网或者百度百科,如有侵权请联系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,以上这样就好啦,如果还想学习更多,你可以看看我的往期热文推荐哦,每天积累一个奇淫小知识,日积月累下去,你一定能成为令人敬仰的大佬的。好啦,咱们下期见~
七、往期推荐🔥
- 如何使用Mybatis-plus实现字段内容的自动填充?不会我就教你。
- 如何在swagger2中配置header请求头等参数信息?(若不会,我便手把手教你)
- Springboot系列(十六):集成easypoi实现word模板内循环导出多数据
- Springboot系列(十六):集成easypoi实现word模板图片导出
- Springboot系列(十六):集成easypoi实现excel多sheet表导入
- Springboot系列(十六):集成easypoi实现excel多sheet表导出
八、文末🔥
如果还想要学习更多,小伙伴们可关注bug菌专门为大家创建的专栏《SpringBoot零基础入门》,从无到有,从零到一!希望能帮到大家。
我是bug菌,一名想走👣出大山改变命运的程序猿。接下来的路还很长,都等待着我们去突破、去挑战。来吧,小伙伴们,我们一起加油!未来皆可期,fighting!