java内存泄漏

本文探讨了在使用Tomcat时如何优化性能,包括合理设置连接数、避免过度使用过滤器、管理session超时时间等。同时强调了在技术选型上要根据实际情况选择合适的工具和方法,如在过滤器设置、对象使用和字符串操作等方面提供优化建议。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一.字符串问题

这个也是一个常见的问题,我们相加两个字符串时有几种方法,如new string("test");、"a"+"b",或用stringbuffer等等,至于应该用哪个,这个是应该有讲究的。下面来总结下:1.new基本不可取,除非在需要转码的时候,如new string(str.getbytes("gbk"),"utf-8"),这种情况下就可以使用;2.str1+str2,如果str1和str2都是常量,则用这种方式相加是最好的,也是占用内存最少的,如果是变量,在1.5之前用stringbuffer进行append操作,1.6之后可以使用stringbuilder进行append操作,因为通常情况下stringbuilder比stringbuffer速度快,因为它不执行同步,大多数情况下能满足我们的需求了。3.不要滥用replace,substring等方法,因为它会产生一个新的字符串

二.其它对象问题

不要没事就new一个对象,而你却不使用,这样造成无辜的浪费,当这个方法被频繁调用时,会产生大量这个对象的实例,jvm回收也需要时间啊。还有就是方法执行时间长的问题,tomcat支持的并发不高,如果方法执行时间长,会造成线程等待(在并发高的情况下)

三.过滤器的问题

设置过滤的内容要注意下,像.do,.action,.jsp可以设置过滤,一些资源问题不需要经过过滤器,否则会浪费资源,严重影响性能

四.session超时时间问题

超时时间不能太长,在用户稍微有点多的情况下就会出现严重的性能问题,这些实例都会一直存在,个人建议1个小时足以

五.tomca连接数设置

合理设置能提高性能,如:

maxthreads="500" 表示最多同时处理500个连接

minsparethreads="200" 初始线程数

maxsparethreads="200" 最大空闲线程数

acceptcount="500" 当同时连接的人数达到maxthreads时,还可以接收排队的连接,超过这个连接的则直接返回拒绝连接。

如果单纯的使用tomcat跑的话,并发一大,基本就撑不住了,所以可以使用apache或nginx来做负载,个人建议nginx,内存和cpu消耗和apache不是一个级别的,而且在linux下测试过,并发数远高于apache,nginx是反向代理,配置也简单


======================================================
在最后,我邀请大家参加新浪APP,就是新浪免费送大家的一个空间,支持PHP+MySql,免费二级域名,免费域名绑定 这个是我邀请的地址,您通过这个链接注册即为我的好友,并获赠云豆500个,价值5元哦!短网址是http://t.cn/SXOiLh我创建的小站每天访客已经达到2000+了,每天挂广告赚50+元哦,呵呵,饭钱不愁了,\(^o^)/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值