tomcat 禁用session

我们先来做一个实验,用jmeter对tomcat下的一个jsp页面做压测:

(1)jsp的内容非常简单,1.jsp:


[html] view plain copy

  1. <%@ page language="java" pageEncoding="utf-8" contentType="text/html;charset=utf-8"%>  

  2. <html>  

  3.     <head><title>1.jsp</title></head>  

  4.     <body>  

  5.         this is 1.jsp  

  6.     </body>  

  7. </html>  

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


(2)我们给tomcat设置启动参数,修改catalina.bat,添加:

set JAVA_OPTS=%JAVA_OPTS% -Xms64m -Xmx64m

(3)启动jmeter,设置100个线程模拟100个用户,然后不停的访问这个页面,观察结果:

图中可以看出来,在请求数目到达33165的时候,tomcat已经内存溢出了。

(4)导出tomcat的内存映像文件:

jps -v:找到tomcat的pid

jmap -dump:format=b,file=tomcat.bin 6616

(5)用mat打开tomcat.bin:

有没有很吃惊,StandardSession竟然有33197个,所占内存达到了52M!这是因为对每个请求tomcat都会为其创建一个session导致的。

这里也说明一个问题:就算session里面什么也不存,默认就会占差不多1.5K!所以,Session据对是一个重量级的对象!

(6)那么如果jsp中不生成Session是不是就不会有这个问题了?我们改一下jsp页面:

重新做压测:

tomcat表示很轻松,毫无压力!

结论:tomcat的session是一个非常重量级的对象,能禁用则一定要禁用。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章