原文链接:http://www./detail.html?id=8732 背景最近在工作中,发现一个filter处理HttpServletRequest,处理完之后在把一些结果setAttribute到request中,供后续使用,但是发现这个filter中的逻辑很多情况下都是不必要的,而且这个filter使用非常广泛,这么多次不必要的逻辑处理,导致了某个服务的QPS高的可怕,保守估计,至少有60%的服务调用都是没有意义的。 解决但是这个filter作为一个基础SDK,已经被接近200个业务方使用,所以不得不考虑升级的成本,为了使得推动升级的过程可以较为顺利,所以希望尽量减少业务方升级的成本(最好是只需要改一下POM文件中的版本就可以)。
在XXXRequest的getAttribute时,才会真正的来调用服务,进行原先的逻辑处理。可以理解为懒处理了,只有在真正需要的时候才走这块逻辑。 问题暴露开始推动业务方升级了,一开始兴高采烈,直到有一天一个人来找我,说,升级完之后项目启动不了了。自己debug完之后,发现:
盯着代码沉默一会,我觉得自己的代码没有问题,自信是程序员的本能!但是,问题就是这么发生了!本人有个习惯,电脑上必装jdk6,jdk7,jdk8,tomcat6,tomcat7,tomcat8,就是为了这一刻。于是尝试了不同的环境,发现在tomcat7下,会报上面的错,如果是tomcat6的话:
好吧,还是NoClassDefFoundError。可是我的POM里是有依赖的啊:
去看了看Tomcat官网的介绍,才明白,不同版本的Tomcat支持的Servlet规范的版本是不一样的: 错竟然就是我用的javax.servlet-api版本太高,只有Tomcat8.0.x之后才支持。 于是试了Tomcat8,果然可以!当然,解决方案其实是降低我这个sdk中的javax.servlet-api的版本。 |
|