事情是这样的,周末晚上群里有人说后台菜单刷不出来了,刷了几次就好了。
今早到公司,查看服务器日志,定位到如下异常:
这个问题是使用的connection
空闲时间超过了MySQL的wait_timeout
,该连接被断开。数据库连接池这里使用的是Druid,查看配置项没问题:
接下来查看DataSource
的初始化:
DruidDataSource dds = new DruidDataSource();
...
dds.setTestWhileIdle(Boolean.getBoolean(this.props.getProperty("testWhileIdle")));
看起来似乎没有问题,打个断点查看DataSource
初始化完的属性:
明明设置了testWhileIdle=true
,这里为什么是false
呢。
打个断点查看一下发现如下,果然testWhileIdle
被设置成了false
。
直觉告诉我这个Boolean#getBoolean(String)
可能有问题,继续深入方法,当看到这个就知道问题出现在哪了。
Boolean#getBoolean(String)
并不是将字符串转换为boolean值,而是从System properties
中查询该key
,将查询到的value
转换为boolean值。
Boolean#parseBoolean(String)
或者Boolean#valueOf(String)
才是“想”使用的方法,世界和平。
写这个代码的同学已经拖出去揍了?,但是没揍他之前我也不知道这个坑?
看起来没问题,也就是看起来而已。。。