起因
今天在写数据报表的时候,因为多个 controller 都用到了同一个功能:将数据库中的数据查出并以时间为 key 存入 map 中,所以给单独拿出来封装个方法,使用的是new SimpleDateFormat("yyyy-MM-dd").format(date)
进行 date 转年月日存入 key,因为想着前面的new SimpleDateFormat("yyyy-MM-dd")
都是一样的,所以提取为一个成员变量,在本地测试所有接口都没有问题,但是上线后发现数据错误,每次执行的结果都不一样,但是在本地请求多次结果都是相同的。
最后经过多次测试,发现是因为线程安全问题,于是加了synchronized
锁。十个线程跑起,发现并没有什么问题,正当我准备关机睡觉的时候,把线程调到 100 时,依然会有数据不一致的问题,最后定位到问题,发现是SimpleDateFormat
的.format()
出现的线程问题导致的
解决方案
不要使用成员变量,在用到的地方从新 new 对象