Spring Boot启动卡在Root WebApplicationContext: initialization completed in...

Spring Boot启动 打印Root WebApplicationContext: initialization completed in...这行日志完成后需要等很长时间才能真正启动完成。

分析一下发现是连接某个机器的MySQL就会出现这种情况。使用客户端软件连接MySQL时也很慢,但连接完成后执行MySQL各种语句非常看。查看MySQL链接时,发现所有的链接都会出现unauthenticated user,时间较长,过后就正常中了。

将Spring Boot链接池全部改为1,发现可以较快的启动程序。推测MySQL连接时比较慢导致的,在连接MySQL时,会进行反向DNS查找。经查询发现skip-name-resolve有这么一个参数可以控制,打开mysql的配置文件(my.cnf),在[mysqld]下面增加一行:

skip-name-resolve

重新载入配置文件或者重启MySQL服务即可。

在连接MySQL时,不管连接是通过hosts还是ip的方式,MySQL都会对DNS做反查,IP到DNS,由于反查的接续速度过慢,大量的链接建立比较慢,所以出现程序假死。

为什么要使用"skip_name_resolve"参数?

使用"skip_name_resolve"参数可以提高数据库服务器的性能和安全性。当数据库服务器需要进行用户认证和授权操作时,通常需要获取客户端的IP地址,这样才能判断用户的身份和访问权限。而获取IP地址的常用方式是通过进行DNS解析,将客户端的域名解析为IP地址。然而,DNS解析是一个耗时的过程,可能会对数据库服务器的性能产生一定影响。

此外,启用"skip_name_resolve"参数还可以增强数据库服务器的安全性。在某些情况下,可能存在域名解析的风险,例如,当域名被劫持或者DNS服务器受到攻击时,可能会导致数据库服务器将域名解析为错误的IP地址。这样一来,可能会导致数据库服务器错误地认证和授权了非法用户。通过禁用域名解析,即启用"skip_name_resolve"参数,可以减少被域名劫持和DNS攻击的风险。

参考:

https://www.cnblogs.com/BY1314/p/17946371

https://www.cnblogs.com/_Chill/p/3890339.html

https://wenku.baidu.com/view/b2b5a8405cbfc77da26925c52cc58bd6318693b2.html?wkts=1725269215116&bdQuery=skip-name-resolve

相关推荐
疯狂的程序猴1 分钟前
完整指南:iPhone崩溃日志查看与分析方法及低内存崩溃处理
后端
秧歌star51911 分钟前
PageHelper 分页失效原因分析与正确实践
后端
疯狂的程序猴16 分钟前
苹果iOS应用签名与上架App Store完整指南包括注意事项
后端
回家路上绕了弯16 分钟前
生产环境服务器变慢?从应急到根因的全流程诊断处理指南
分布式·后端
小胖霞16 分钟前
Node+Express+MySQL 后端生产环境部署,实现注册功能(三)
前端·后端
一 乐17 分钟前
农产品电商|基于SprinBoot+vue的农产品电商系统(源码+数据库+文档)
java·前端·javascript·数据库·vue.js·spring boot
aiopencode23 分钟前
抓包技术全面指南:原理、工具与应用场景
后端
烤麻辣烫42 分钟前
23种设计模式(新手)-7迪米特原则 合成复用原则
java·开发语言·学习·设计模式·intellij-idea
该用户已不存在44 分钟前
Gemini 3.0 发布,Antigravity 掀桌,程序员何去何从?
后端·ai编程·gemini
aiopencode1 小时前
软件苹果商城上架的流程与团队协作模式 一个项目从开发到发布的完整经历
后端