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的大小,能禁用则一定要禁用。

posted @ 2017-06-26 10:51  wzjhoutai  阅读(2282)  评论(0编辑  收藏  举报