Tomcat项目内存参数调优

一、常见的Java内存溢出有以下三种:
 1. Java.lang.OutOfMemoryError: Java heap space 即JVM Heap溢出

解释说明:JVM在启动的时候会自动设置JVM Heap的值,JVM堆的设置是指java程序运行过程中JVM可以调配使用的内存空间的设置。其初始空间默认是物理内存的1/64,最大空间不可超过物理内存。JVM提供-Xmn -Xms -Xmx等选项来进行设置。

出错场景:在JVM中,如果98%的时间是用于GC,且可用的Heap size不足2%时,将会出现JVM Heap溢出

解决方法:修改JVM Heap的大小。

2.java.lang.OutOfMemoryError: PermGen space 即PermGen space溢出 
解释说明:PermGen space是指内存的永久保存区域。这个区域主要存放Class和Meta信息,Class在被Load时就会被放入PermGen space。
出错场景:如果APP载入很多CLASS,就可能会出现PermGen space溢出。(因为sun的GC不会在程序运行时对PermGen space进行清理)常见于web服务器对JSP进行pre compile的时候

解决方法:修改MaxPermSize大小 
3. java.lang.StackOverflowError 即栈溢出

解释说明:JVM采用的是栈式的虚拟机,函数的调用过程都体现在堆栈和退栈上。

出错场景:通常栈的大小是1-2MB的,如果调用构造函数的 “层”太多,则会出现栈溢出

二、Tomcat的JVM内存溢出解决方法 
在生产环境中,tomcat内存设置不好很容易出现JVM内存溢出,解决方法就是修改Tomcat中的catalina.sh文件。 
在catalina.sh文件中,找到cygwin=false,在这一行的前面加入参数,具体如下

$ vim TOMCAT_HOME/bin/catalina.sh

JAVA_OPTS=”-server -Xms800m -Xmx800m -XX:PermSize=256m -XX:MaxPermSize=512m -XX:MaxNewSize=512m”

其他说明: 
1.“m”说明单位是MB,否则默认是KB 
2.一般使用物理内存的80%作为堆大小 
3.一般把-Xms和-Xmx设为一样大 
4.一般把-Xmn设置为-Xmx值的1/4 
5.一般将堆的总大小的50%到60%分配给新生成的池

三、jvm参数说明: 
-server 一定要作为第一个参数,启用JDK的server版本,在多个CPU时性能佳 
-Xms java Heap初始大小。 默认是物理内存的1/64。 
-Xmx java heap最大值。建议均设为物理内存的80%。不可超过物理内存。 
-Xmn java heap最小值,一般设置为Xmx的3、4分之一。 
-XX:PermSize 设定内存的永久保存区初始大小,缺省值为64M。 
-XX:MaxPermSize 设定内存的永久保存区最大大小,缺省值为64M。 
-XX:SurvivorRatio=2 生还者池的大小,默认是2。如 
-XX:NewSize 新生成的池的初始大小。 缺省值为2M。 
-XX:MaxNewSize 新生成的池的最大大小。 缺省值为32M。 
+XX:AggressiveHeap 让jvm忽略Xmx参数,疯狂地吃完一个G物理内存,再吃尽一个G的swap。 
-Xss 每个线程的Stack大小 
-verbose:gc 现实垃圾收集信息 
-Xloggc:gc.log 指定垃圾收集日志文件 
-XX:+UseParNewGC 缩短minor收集的时间 
-XX:+UseConcMarkSweepGC 缩短major收集的时间 
-XX:userParNewGC 可用来设置并行收集(多CPU) 
-XX:ParallelGCThreads 可用来增加并行度(多CPU) 
-XX:UseParallelGC 设置后可以使用并行清除收集器(多CPU)

原文地址:https://www.cnblogs.com/huangjinyong/p/11794057.html

时间: 2024-08-19 05:00:05

Tomcat项目内存参数调优的相关文章

Oracle 内存参数调优设置

Oracle 数据库系统中起到调节作用的参数叫初始化参数,数据库管理员根据实际情况需要适当调整这些 初始化参数以优化Oracle系统. 1 主要系统参数调优介绍 2 系统内存参数的分配 2.1 Oracle 实例= 内存结构 + 进程结构 内存结构 = SGA + PGA SGA(系统全局区): 用户存储数据库信息的内存区,该区域为数据库进程所共享.它包含服务器的数据和控制信息,主要包含高速数据缓冲区.共享池.重做日志缓存区.Java池,大型池等内存结构. SGA的设置,理论上SGA的大小应该占

mysql 5.6内存参数调优

mysql5.6,数据库自带performance_schema,占用内存400M. my.cnf文档 performance_schema = OFF innodb_buffer_pool_size = 8M innodb_additional_mem_pool_size = 1M innodb_log_buffer_size = 1M 引用:http://nosqldb.org/p/55ceaac5c3f8a8336f3bf727

性能测试三十六:内存溢出和JVM常见参数及JVM参数调优

堆内存溢出: 此种溢出,加内存只能缓解问题,不能根除问题,需优化代码堆内存中存在大量对象,这些对象都有被引用,当所有对象占用空间达到堆内存的最大值,就会出现内存溢出OutOfMemory:Java heap space 永久代溢出 如果发生,则是在初始化的时候,空间太小,解决办法,扩大空间类的一些信息,如类名.访问修饰符.字段描述.方法描述等,所占空间大于永久代最大值,就会出现OutOfMemoryError:PermGen space 内存溢出的检测方法:pid=1730 Jdk/bin目录下

大数据技术之_30_JVM学习_01_JVM 位置+JVM 体系结构概览+堆体系结构概述+堆参数调优入门+JVM 的配置和优化+Tomcat 的配置和优化

1.JVM 位置2.JVM 体系结构概览3.堆体系结构概述4.堆参数调优入门5.JVM 的配置和优化6.Tomcat 的配置和优化 熟悉 JVM 架构与 GC 垃圾回收机制以及相应的 JVM 调优,有过在 Linux 系统下的调优经验. 淘宝的周志明<深入理解 Java 虚拟机>中说 JVM 的优化,其中 99% 优化的是堆,1% 优化的是方法区. 内地女歌手照片--李嘉欣,贴在桌面上. 1.JVM 位置 JVM 是运行在操作系统之上的,它与硬件没有直接的交互 2.JVM 体系结构概览 详解如

JVM参数调优:Eclipse启动实践

本文主要参考自<深入理解 Java 虚拟机>.这本书是国人写的难得的不是照搬代码注释的且不是废话连篇的技术书,内容涵盖了 Java 从源码到字节码到执行的整个过程,包括了 JVM(Java Virtual Machine)的架构,垃圾收集的介绍等.这里摘录出关于配置 JVM 基本参数来调优 Eclipse 启动的过程,比较初级,供初学者参考. 基础知识 针对 JVM 的参数调优主要集中在数据区大小的控制和垃圾回收策略的选择.关于 JVM 运行机制等更多内容可参考其他博文 JVM 的运行时数据区

php-fpm参数调优

关于php-fpm.conf参数调优,只对重要的参数进程调优.其它可参数前辈的. http://php.net/manual/zh/install.fpm.configuration.php (官方的) http://www.cnblogs.com/argb/p/3604340.html http://www.cnblogs.com/jonsea/p/5522018.html https://www.zybuluo.com/phper/note/89081 http://blog.64mazi.

JBOSS参数调优

    阅读目录 JBOSS参数调优 jvm调优讲解1 JVM调优讲解2 JVM常见配置汇总 JBOSS生产环境下JVM调优 JBOSS瘦身 JBoss性能优化:内存紧张的问题终于解决了(转载)----调优实例 Jboss 优化配置 吐血整理了以前Jboss以及JVM在生产环境下的调优参数,各种不同的案例,都是来自网友杜撰.整合后,希望对广大使用jboss作为生产应用服务器的朋友有所帮助. 回到顶部 JBOSS参数调优 配置deploy/jboss-web.deployer/server.xml

Tomcat中常用的调优

在平时使用Apache.Nginx或者是其他的提供相关Web服务软件中都有相应的性能模块调优修改,而在Tomcat中也有相应的性能调优修改的配置,在这里就简单的说一说比较常用的几个Tomcat中的性能调优配置参数,在Tomcat中调优参数可以分为2个部分:1.在 Tomcat中的二进制文件夹bin目录下的catalina.sh或catalina.bat中添加修改配置tomcat使用运行参数:2.在Tomcat的conf文件夹中配置修改server.xml中的容器. 一.tomcat使用运行参数c

JVM参数调优与垃圾回收机制

自动内存管理机制 Java虚拟机原理  所谓虚拟机,就是一台虚拟的机器.他是一款软件,用来执行一系列虚拟计算指令,大体上虚拟机可以分为 系统虚拟机和程序虚拟机, 大名鼎鼎的Visual Box.Vmare就属于系统虚拟机,他们完全是对物理计算的仿真, 提供了一个可以运行完整操作系统的软件平台. 程序虚拟机典型代码就是Java虚拟机,它专门为执行单个计算程序而计算,在Java虚拟机中执行的指令我们成为Java 自己码指令.无论是系统虚拟机还是程序虚拟机,在上面运行的软件都被限制于虚拟机提供的资源中