nainai1 发表于 2018-11-30 06:30:19

tomcat 禁用session

我们先来做一个实验,用jmeter对tomcat下的一个jsp页面做压测:
(1)jsp的内容非常简单,1.jsp:



   view plain copy

[*]  
[*]  
[*]      1.jsp
[*]     
[*]        this is 1.jsp
[*]     
[*]  
  没有任何复杂的处理,只是一个非常简单的jsp页面。我们知道,tomcat默认会给每一个jsp都启用session的。


(2)我们给tomcat设置启动参数,修改catalina.bat,添加:
set JAVA_OPTS=%JAVA_OPTS% -Xms64m -Xmx64m
(3)启动jmeter,设置100个线程模拟100个用户,然后不停的访问这个页面,观察结果:
http://img.blog.csdn.net/20150821094815321?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center
图中可以看出来,在请求数目到达33165的时候,tomcat已经内存溢出了。
(4)导出tomcat的内存映像文件:

jps -v:找到tomcat的pid
jmap -dump:format=b,file=tomcat.bin 6616
(5)用mat打开tomcat.bin:
http://img.blog.csdn.net/20150821095251739?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center
有没有很吃惊,StandardSession竟然有33197个,所占内存达到了52M!这是因为对每个请求tomcat都会为其创建一个session导致的。
这里也说明一个问题:就算session里面什么也不存,默认就会占差不多1.5K!所以,Session据对是一个重量级的对象!
(6)那么如果jsp中不生成Session是不是就不会有这个问题了?我们改一下jsp页面:
http://img.blog.csdn.net/20150821100044396?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center
重新做压测:
http://img.blog.csdn.net/20150821100111240?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center
tomcat表示很轻松,毫无压力!
结论:tomcat的session是一个非常重量级的对象,能禁用则一定要禁用。
  




页: [1]
查看完整版本: tomcat 禁用session