jvm内存使用上限

最近为了解决一个问题(使用32位JDK),查了查jvm使用内存的相关资料,发现了java服务程序使用内存的几个制约因素
1、jvm使用内存限制
在32位windows的机器上,堆最大可以达到1.4G至1.6G。
在32位solaris的机器上,堆最大可以达到2G
而在64位的操作系统上,32位的JVM,堆大小可以达到4G

2、线程不使用jvm内存,而是向操作系统申请内存
在java中每new一个线程,jvm都是向操作系统请求new一个本地线程,此时操作系统会使用剩余的内存空间来为线程分配内存,而不是使用jvm的内存。
这样,当操作系统的可用内存越少,则jvm可用创建的新线程也就越少。

3、系统进程最大内存限制
主要是32位进程的限制
32位Windows上,最大为3G(执行程序加编译参数,系统修改启动3G设置)
64位Windows上,最大为4G (执行程序加编译参数)
Linux上,
32位和64位理论上 最大都可达到 4G
总结
由此可以得出公式:
JVM内存 + 线程使用内存 = 进程使用内存

因此如果是线程很多的服务,就得根据需要调小JVM内存,以给线程留出足够的内存空间


相关资料:
Memory Limits for Windows and Windows Server Releases

jvm32位、64位区别

Java调优之jvm和线程的内存分析


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值