Tomcat性能优化及常用命令整理
1汤姆猫性能优化
1.1连接参数
1.1.1默认连接配置
1.1.2连接参数调优
|
参数配置
|
参数含义
|
|
maxProcessors
|
Tomcat4 支持
|
|
minProcessors
|
Tomcat4 支持
|
|
maxThreads="300"
|
最大线程数
|
|
minSpareThreads="50"
|
初始化时创建的线程数
|
|
maxSpareThreads="100"
|
一旦创建的线程超过这个值, Tomcat 就会关闭不再需要的 socket线程
|
|
acceptCount="1000"
|
指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理
|
1.1.3非阻塞式IO配置
1.2 JVM参数
1.2.1堆大小
1.2.2方法区大小
1.2.3垃圾回收策略
|
参数配置
|
参数含义
|
|
-XX:+UseParNewGC
|
新生代采用 ParNewGC 多线程收集器
|
|
-XX:+UseConcMarkSweepGC
|
老年代采用 CMS 收集器,降低 GC停顿时间
|
|
-XX:+CMSParallelRemarkEnabled
|
降低标记阶段的停顿时间
|
|
-XX:+UseCMSCompactAtFullCollection
|
CMS 基于标记- 清除,会产生碎片,通过此配置在 CMS 收集后做一次压缩整理
|
|
-XX:CMSFullGCsBeforeCompaction=0
|
配置多少次 CMS GC 后,做一次压缩整理,就不用每次都做压缩整理了
|
|
-XX:+UseCMSInitiatingOccupancyOnly -XX:CMSInitiatingOccupancyFraction=80
|
当老年代使用 80 %后开始CMS 收集,默认值为 68% 。因为CMS 收集会有延迟,所以不能等到老年代占满时再收集
|
|
-XX:+CMSClassUnloadingEnabled
|
允许CMS 收集方法区 (PermGen) 。
JDK6 Update 3 及之前版本还需指定 -XX:+CMSPermGenSweepingEnabled参数
|
----------------------------------------------
1: 226810 34953232 <constMethodKlass>
2: 226810 30857024 <methodKlass>
3: 23748 25330568 <constantPoolKlass>
4: 23748 18308832 <instanceKlassKlass>
5: 127546 17364792 [C
6: 18895 14344152 <constantPoolCacheKlass>
7: 23805 13295216 [I
8: 31302 12693272 [B
9: 179826 10561520 <symbolKlass>
10: 140792 4505344 java.lang.String
11: 24852 2584608 java.lang.Class
12: 3056 2019600 <methodDataKlass>
13: 60750 1944000 java.util.HashMap$Entry
14: 31562 1892608 [S
15: 19211 1813536 [Ljava.util.HashMap$Entry;
16: 37068 1746912 [[I
17: 22808 1268080 [Ljava.lang.Object;
18: 14385 1265880 java.lang.reflect.Method
19: 18487 887376 org.apache.catalina.loader.ResourceEntry
20: 20590 823600 java.util.LinkedHashMap$Entry
21: 1075 627800 <objArrayKlassKlass>
22: 12469 598512 java.util.HashMap
23: 14416 576640 java.lang.ref.SoftReference
24: 11032 441280 java.util.concurrent.ConcurrentHashMap$Segment
jstat -compiler pid:显示VM实时编译的数量等信息。
jstat -gc pid:可以显示gc的信息,查看gc的次数,及时间。其中最后五项,分别是young gc的次数,young gc的时间,full gc的次数,full gc的时间,gc的总时间。
jstat -gccapacity:可以显示,VM内存中三代(young,old,perm)对象的使用和占用大小,如:PGCMN显示的是最小perm的内存使用量,PGCMX显示的是perm的内存最大使用量,PGC是当前新生成的perm内存占用量,PC是但前perm内存占用量。其他的可以根据这个类推, OC是old内纯的占用量。
jstat -gcnew pid:new对象的信息。
jstat -gcnewcapacity pid:new对象的信息及其占用量。
jstat -gcold pid:old对象的信息。
jstat -gcoldcapacity pid:old对象的信息及其占用量。
jstat -gcpermcapacity pid: perm对象的信息及其占用量。
jstat -util pid:统计gc信息统计。
jstat -printcompilation pid:当前VM执行的信息。
java -cp .:/export/servers/jdk1.6.0_25/lib/sa-jdi.jar DirectMemorySize -e [pid]
Tomcat性能优化及常用命令整理的更多相关文章
- MySQL性能优化以及常用命令
1.将查询操作SELECT中WHERE条件后面和排序字段建立索引 2.按需查询,需要哪个字段就查哪个字段,禁止使用"SELECT * " 3.数据库引擎最好选用InnoDB,少用M ...
- tomcat 性能优化(内存优化 线程优化)
转自:http://blog.sina.com.cn/s/blog_4b5bc01101014s81.html tomcat 性能优化 linux修改TOMCAT_HOME/bin/catalina. ...
- Tomcat性能优化(转载)
出处:微信订阅号GitChat精品课程 — Tomcat性能优化 Tomcat 简单介绍 Sun 公司创建了第一个 Servlet 容器,即 Java Web Server,但 JWS 只是为了演示 ...
- Linux 系统基础优化和常用命令
目录 Linux 系统基础优化和常用命令 软连接 tar解压命令 gzip命令 netstart命令 ps命令 kill命令 killall命令 SELinux功能 iptables防火墙 Linux ...
- 运维 07 Linux系统基础优化及常用命令
Linux系统基础优化及常用命令 Linux基础系统优化 引言没有,只有一张图. Linux的网络功能相当强悍,一时之间我们无法了解所有的网络命令,在配置服务器基础环境时,先了解下网络参数设定命令 ...
- tomcat 性能优化
tomcat 性能优化tomcat默认参数是为开发环境制定,而非适合生产环境,尤其是内存和线程的配置,默认都很低,容易成为性能瓶颈. tomcat内存优化linux修改TOMCAT_HOME/bin/ ...
- 【linux】---常用命令整理
linux常用命令整理 一.ls命令 就是list的缩写,通过ls 命令不仅可以查看linux文件夹包含的文件,而且可以查看文件权限(包括目录.文件夹.文件权限)查看目录信息等等 常用参数搭配: l ...
- linux 服务器常用命令整理
linux 服务器常用命令整理 目录 网络分析 - tcpdump \ telnet \ (netstat \ ss \ lsof) \ nload 网络传输 - scp \ rsync \ (rz ...
- (小组)Git 常用命令整理
Git 常用命令整理 取得Git仓库 初始化一个版本仓库 git init Clone远程版本库 git clone git@xbc.me:wordpress.git 添加远程版本库origin,语法 ...
随机推荐
- 例10-5 uva12716
题意:gcd(a,b) = a^b,( 1≤ a , b ≤ n) 思路: ① a^b = c, 所以 a^c = b,而且c是a的约数,枚举a,c,再gcd判断 ② 打表可知 a-b = c,而且a ...
- splay模板(BZOJ3224)
用splay实现二叉搜索树的模板,支持插入,删除,找前缀后缀,x的排名以及第x名的数. #include <cstdio> #define l(x) t[x].s[0] #define r ...
- 毕业回馈-89C51之GPIO使用(流水灯)
今天分享一个89c51制作的8位流水灯案例.使用Proteus仿真. 同上一遍文章不同.上一篇文章中对于GPIO操作主要是位操作,即sbit led1=P0^0;其中P0^0代表p0.0这个引脚,然后 ...
- DELL、HP、IBM X86服务器命名规则
DELL.HP.IBM X86服务器命名规则 各大服务器厂家对于自己的服务器命名都有一定的规则,通常会根据服务器的外观(如塔式.机架式.刀片等).处理器(如Intel或者AMD等).架构等信息来命名. ...
- 14_Python将列表作为栈和队列_Python编程之路
上一篇文章跟大家介绍了列表的一些方法,这一节我们还是讲列表 只是这一节我们要联系一些数据结构,来讲列表 栈 首先我们要理解一下栈是一种什么数据结构 栈(stack)又名堆栈,它是一种运算受限的线性表. ...
- mybatis choose标签的使用
MyBatis 提供了 choose 元素.if标签是与(and)的关系,而 choose 是或(or)的关系. choose标签是按顺序判断其内部when标签中的test条件出否成立,如果有一个成立 ...
- nginx模块,模块的配置使用
nginx模块官方模块(默认支持的)第三方模块 1. --with-http_stub_status_module nginx的客户端状态 配置syntax: sub_status;default:- ...
- Hive中yyyymmdd和yyyy-mm-dd日期之间的切换
以2017-12-05和20171205相互转换为例说明 方法1: from_unixtime+ unix_timestamp --20171205转成2017-12-05 ','yyyymmdd') ...
- CODEVS3269混合背包+二进制优化
codevs 3296 http://codevs.cn/problem/3269/ 题目描述 Description 背包体积为V ,给出N个物品,每个物品占用体积为Vi,价值为Wi,每个物品要么至 ...
- Docker常见仓库CentOS
CentOS 基本信息 CentOS 是流行的 Linux 发行版,其软件包大多跟 RedHat 系列保持一致. 该仓库提供了 CentOS 从 5 ~ 7 各个版本的镜像. 使用方法 默认会启动一个 ...