问题描述
因为某次新增某个需求,在Controller的公共父类中增加了一个threadLocal,自认为熟练,然后再加了一个@ModelInit注解。
将用户登录信息缓存在 threadLocal, 再次自认为熟练。
随着时间的推移,发现系统变慢了,接口慢慢超时了。
思考
ModelInit方法会在每一个RequestMapping请求之前 调用,何况写在BaseController。目前为止有最多343个Controller。
这每一个请求都去调用这个ModelInit,然后ModelInit里面如果是调用 Redis读取数据,数据库操作等等,可能单个请求没有性能问题,但是只因为这一两个接口的需要,导致几乎所有的请求去调用这些功能,积累下来还是有性能影响的。
解决
移除ModelInit方法,将某个Controller特有的方法下放至子类,不要放在公共父类。