最近在维护一个java 程序 有关内存占用的问题,请各位大神科普。
在本地 windows 上 启动tomcat 占用内存 几十 M
期间处理的任务
1.程序向另一个服务器建立 客户端连接 200多条 (netty) 并保持长连 每过80秒发送心跳。可用内存在每一次心跳都会有一定的下降并且没有回升
2.有个Thread 会每过10秒到数据库(mysql)获取记录 ,创建五条Thread(最大5条)对记录获取相关的连接(以上200多条连接中获取)进行处理,可用内存也会下降
在已用内存到达一定高度,可用内存便会回升,这是在windows 测试的结果,内存使用情况我觉得很健康
放在linux 服务器上 tomcat 启动内存就占用了200M多,每次心跳和处理记录也在增加,但内存达到一定高度 可用内存并没有回升,tomcat直接内存溢出了(生产环境)
我把测试环境的监控贴出来唉大家帮帮忙分析一下
linux服务器支持的内存理论上限是4G,修改内核以后能到32G,我的一个朋友做过一台16G的服务器,能认出来。
如果kernel启用了PAE(物理地址扩展),则可以支持 到 64GB 内存。
以前(2009)需要安装PAE-kernel才支持大于4G。
但是,建议装 64bit Linux。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。