tomcat为什么要禁用session?
转载请标明出处:http://blog.csdn.net/goldenfish1919/article/details/47829755
我们先来做一个实验,用jmeter对tomcat下的一个jsp页面做压測:
(1)jsp的内容很easy,1.jsp:
<%@ page language="java" pageEncoding="utf-8" contentType="text/html;charset=utf-8"%> <html> <head><title>1.jsp</title></head> <body> this is 1.jsp </body> </html>没有不论什么复杂的处理。仅仅是一个很easy的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是一个很重量级的对象,初始化就占几乎相同1.5K的大小,能禁用则一定要禁用。