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