首先需要理解的是现存32bit虚拟机与64bit虚拟机在典型操作系统下(windows,unix)所能使用的最大的内存是多少:
32bit JDK在windows操作系统下最大支持2G内存,理论上堆内存设置为1.5G合适,在unix操作系统下最大能支持4G内存;64bit JDK理论上支持2的64次方内存。
检验JDK支持内存大小的方法:
java -XmxXXXg version,如果能显示版本信息表示支持。
场景描述:
日PV量在10w左右的B/S架构的在线文档网站,之前服务器配置较低,使用32bit JDK,堆内存设置为1.5G,网站用户表示响应缓慢。为了解决此问题,物理服务器升级配置8cpu,16G内存,使用64bit JDK,堆内存设置12G,网站不定期出现长时间失去响应的情况。
故障排查:
发现Full GC时间过长。
分析:
程序将文件从磁盘加载到内存中,内存中出现大量的大文件序列化对象,很快将空间耗尽。
解决方案:
部署方案改为32bit JDK集群,单个虚拟机堆内存设置为1.5G。