jvm内存使用上限
来源:互联网 发布:农村淘宝黄岩服务中心 编辑:程序博客网 时间:2024/05/01 04:08
最近为了解决一个问题(使用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内存 + 线程使用内存 = 进程使用内存
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和线程的内存分析
0 0
- jvm内存使用上限
- java -Xmxn 虚拟机内存使用上限的上限
- 详解Linux系统中JVM内存2GB上限
- win7 exe 修改程序内存使用2G上限问题
- Android进程内存上限
- jvm虚拟机内存使用
- JVM内存使用观测
- jvm内存使用情况
- GlobalAlloc 分配的内存上限
- JVM基础-JVM内存使用和配置
- 查看JVM内存使用情况
- 查看jvm内存使用情况
- 查看JVM内存使用情况
- 使用jstat分析JVM内存
- JVM内存分析工具使用
- JVM内存分析工具使用
- 查看jvm内存使用情况
- 查看jvm内存使用命令
- 关于tomcat+MyEclipse的安装与配置
- POJ 2409-Let it Bead(Polya计数)
- HDU - 5067 Harry And Dig Machine (bfs + 状态压缩)
- string 简单实现
- IOS 界面传值
- jvm内存使用上限
- Model绑定机制2:数组
- Linux: /dev/random , /dev/urandom
- hdu5289 2015多校联合第一场1002 Assignment
- 连接查询,条件在on和where后面的区别
- 使用Profiler工具分析内存占用情况
- 美图内网漫游(沦陷大量内部系统、内部服务器权限、企业架构、企业邮箱等敏感信息) - rsync,fastcgi
- UITableView 使用 selectRowAtIndexPath 不能默认选中cell的问题
- JAVA最多支持多少个线程