你知道 Boolean#getBoolean(String) 干了什么吗?

事情是这样的,周末晚上群里有人说后台菜单刷不出来了,刷了几次就好了。

今早到公司,查看服务器日志,定位到如下异常:

这个问题是使用的connection空闲时间超过了MySQL的wait_timeout,该连接被断开。数据库连接池这里使用的是Druid,查看配置项没问题:
你知道 Boolean#getBoolean(String) 干了什么吗?_第1张图片

接下来查看DataSource的初始化:

DruidDataSource dds = new DruidDataSource();
...
dds.setTestWhileIdle(Boolean.getBoolean(this.props.getProperty("testWhileIdle")));

看起来似乎没有问题,打个断点查看DataSource初始化完的属性:
你知道 Boolean#getBoolean(String) 干了什么吗?_第2张图片

明明设置了testWhileIdle=true,这里为什么是false呢。

打个断点查看一下发现如下,果然testWhileIdle被设置成了false
你知道 Boolean#getBoolean(String) 干了什么吗?_第3张图片

直觉告诉我这个Boolean#getBoolean(String)可能有问题,继续深入方法,当看到这个就知道问题出现在哪了。

Boolean#getBoolean(String)并不是将字符串转换为boolean值,而是从System properties中查询该key,将查询到的value转换为boolean值。

你知道 Boolean#getBoolean(String) 干了什么吗?_第4张图片

Boolean#parseBoolean(String)或者Boolean#valueOf(String)才是“想”使用的方法,世界和平。

你知道 Boolean#getBoolean(String) 干了什么吗?_第5张图片

写这个代码的同学已经拖出去揍了?,但是没揍他之前我也不知道这个坑?

看起来没问题,也就是看起来而已。。。

你可能感兴趣的:(JavaWeb)