在tomcat中,我们可能希望一个变量对于request有效,通过设置filter把变量值保存到threadlocal当中,程序里面再进行使用是一个解决方法。
最近碰到一个问题,由于filter退出的时候没有清理,在某些不应当获得threadlocal值的场合,也能获得值!
通过研究发现,这根tomcat的线程池有关。新来一个request以后,tomcat通过线程池获得一个线程,对request进行处理。由于threadlocal变量在filter中进行设置,实际上是设置到tomcat线程当中。当该线程被其他的request使用的时候,就获得该结果了。
因此我们要注意threadlocal的使用,注意它不是和request生命期相同,而是挂到tomcat thread当中。