tomcat优化(转)
tomcat优化
本文重点讲解tomcat的优化。
基本优化思路:
1. 尽量缩短单个请求的处理时间。
2. 尽量多的处理并发的请求能力。
3. 一定要做到横向的扩展。
1.1 tomcat优化
tomcat默认的配置已经是经过优化的,留给开发人员优化的空间很小。主要调整的参数如下(实际项目开发中可以根据如下的参数进行测试):
1.1.1 虚拟机优化
根据机器的配置合理的分配tomcat内存。内存的配置在Tomcat启动的时候可以通过catalina.sh脚本中的JAVA_OPTS进行相应的设置。常见的配置如下:
-server 启用jdk 的 server 版;
-Xms Java虚拟机初始化时的最小内存;
-Xmx java虚拟机可使用的最大内存(建议设置到物理内存的80%);
-XX: PermSize 内存永久保留区域
-XX:MaxPermSize 内存最大永久保留区域(默认32M) 。
-XX:MaxNewSize 新生代内存的最大内存(默认16M)
需要注意:Xms 与Xmx最好一致,以避免每次虚拟机GC调整堆的大小。因为默认的空余堆内存小于40%时,JVM就会增大堆的空间,一直到-Xmx的最大限制。空余堆内存大于70%时,JVM就会减少堆的空间,一直到- Xms 的最大限制。
PermSize,MaxPermSize两个参数tomcat8中无需指定。从java8 之后,这两个参数的值如果内存不够,他可以自动扩充,另外,你修改变量值最好不要修改自带的catalina.sh,等脚本,官方说了,新建setenv.sh,每次启动关闭,都会自动调用这个去处理变量问题
观察配置是否生效,可以通过 jmap –heap tomcat的进程号。
我的配置如下:
JAVA_OPTS=" -Xms512m -Xmx8192m -XX:MaxPermSize=256m "
启动tomcat命令如下:
./catalina.sh run
查看tomcat的端口号:
ps -ef|grep /usr/local/devsoftware/apache-tomcat-8.5.11/bin
验证配置的变量是否生效,使用命令如下:
jmap -heap 3503
通过上图可知,配置的变量已经生效。
1.1.2 tomcat优化
tomcat中 server.xml 中Connector的配置,常见的属性如下:
1) maxConnections:最大连接数。Bio模式中默认值等于maxThreads。Nio模式中默认值为10000。对于APR/native默认值为8192。
2) maxThreads:最大线程数。即同时处理任务的个数,默认为200。
3) acceptCount:当处理任务的线程达到最大个数的时候,接受排队的请求格式,默认100。
4) minSpareThreads:最小空闲线程个数,默认为10。
5) compression:是否开启gzip压缩。
6) compressableMimeType:哪些类型需要压缩,默认为text/html,text/xml,text/css,text/plain。
7) compressionMinSize:启用压缩的输出内容大小,默认2048。
8) enableLookups:是否开启反查域名,为了提高处理速度应该设置该值为false。
9) connectionTimeout:网络连接超时时间,单位为毫秒。设置为-1则表示永远不超时,通常设置2000即可。
一、使用注意:如果为了提高并发量,需要提高设置maxThreads和acceptCount,通常两者设置一样即可。WebServer允许的最大连接受制于服务器的处理能力,可以通过ulimit –a命令进行查看。
二、如果配置了Executor ,那么以Executor 属性值为准。
本案例的配置如下:
<Connector port="8080" protocol="HTTP/1.1"
redirectPort="8443"
maxHttpHeaderSize="8192"
maxThreads="1000"
minSpareThreads="100"
maxSpareThreads="1000"
minProcessors="100"
maxProcessors="1000"
enableLookups="false"
compression="on"
compressionMinSize="2048"
compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain"
connectionTimeout="20000"
URIEncoding="utf-8"
acceptCount="1000"
disableUploadTimeout="true"/>
1.1.3 BIO/NIO/APR
1. BIO是最老的最稳定的(默认)的一个连接器。采用阻塞的方式工作。意味着每个连接线程绑定到每一个Http请求。知道Http返回为止。如果Http客户端的请求的是keep-alive连接,那么这些连接会一直保持着知道timeout(过期)。这期间他不会处理任何的请求。
2. NIO使用Java中的异步IO处理技术,不做阻塞。如果要想使用该方式则可以修改protocol属性值为org.apache.coyote.http11.Http11NioProtoco。
3. APR采用原生的c语言IO处理技术,但是需要安装apr和native,直接启动tomcat就支持apr。使用的时候需要设置protocol属性值为org.apache.coyote.http11.Http11AprProtocol。
a) 安装apr
其中apr的下载地址为:http://apr.apache.org/download.cgi
本文使用的apr版本为apr-1.5.2.tar.gz。
将其解压然后
cd apr-1.5.2
./configure --prefix=/usr/local/devsoftware/apr
make make install
即可完成安装
b) 安装apr-iconv
cd apr-iconv-1.2.1
./configure --prefix=/usr/local/devsoftware/apr-iconv --with-apr=/usr/local/devsoftware/apr
make make install
即可完成安装
c) 安装apr-utils
cd apr-util-1.5.4
./configure --prefix=/usr/local/devsoftware/apr-util --with-apr=/usr/local/devsoftware/apr --with-apr-iconv=/usr/local/devsoftware/apr-iconv
make make install
即可完成安装
d) 安装tomcat-native 首先进入tomcat的bin目录
tar -zxvf tomcat-native.tar.gz
cd tomcat-native-1.2.10-src
cd /usr/local/devsoftware/apache-tomcat-8.5.11/bin/tomcat-native-1.2.10-src/native
./configure --with-apr=/usr/local/devsoftware/apr
make make install
即可完成安装
e) 设置apr环境变量
进入tomcat的bin目录,打开catalina.sh。然后在#!/bin/sh中添加如下内容:
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/devsoftware/apr/lib。当然了为了保持tomcat的独立性,配置在期望使用的tomcat最好不过。
再次启动tomcat,如果以上环节安装成功,输出的日志为:
08-Feb-2017 05:38:55.303 INFO [main] org.apache.catalina.core.AprLifecycleListener.lifecycleEvent The APR based Apache Tomcat Native library which allows optimal performance in production environments was not found on the java.library.path: :/usr/local/devsoftware/apr/lib:/usr/java/packages/lib/amd64:/usr/lib64:/lib64:/lib:/usr/lib
tomcat优化(转)的更多相关文章
- tomcat优化
tomcat优化:vim catalina.sh添加:JAVA_OPTS="-Djava.awt.headless=true -Dfile.encoding=UTF-8 -server -X ...
- windows tomcat 优化
windows tomcat 优化 1. tomcat conf server.xml 在server.xml中修改以一部分,增加节点数目,可以很好的提高性能: <Connector port ...
- Tomcat 优化 java.lang.OutOfMemoryError: Java heap space 的解决方法
Tomcat 优化 java.lang.OutOfMemoryError: Java heap space 的解决方法 java.lang.OutOfMemoryError: Java heap sp ...
- tomcat优化-有改protocol 和 缓存 集群方案
tomcat优化 在线上环境中我们是采用了tomcat作为Web服务器,它的处理性能直接关系到用户体验,在平时的工作和学习中,归纳出以下七种调优经验. 1. 服务器资源 服务器所能提供CPU.内存.硬 ...
- tomcat 优化配置 java-8 tomcat-7
tomcat 优化配置 , 说明 一.并发优化 1.JVM调优 以下为1G物理内存tomcat配置: JAVA_OPTS="-server -Xms512M -Xmx512M -Xss256 ...
- Tomcat 优化方案 和 配置详解(转)
转自 Tomcat 优化方案 和 配置详解 http://201605130349.iteye.com/blog/2298985 Server.xml配置文件用于对整个容器进行相关的配置. <S ...
- Tomcat优化之容易集合经验
Tomcat优化1. 如何加大tomcat连接数在tomcat配置文件server.xml中的<Connector ... />配置中,和连接数相关的参数有: maxThreads : t ...
- tomcat优化实例
———————————————————————————————————— 一.运行模式优化 修改tomcat运行模式为nio<Connector port="80" prot ...
- tomcat优化之安装并配置apr库
在谈到tomcat优化时,必然要说到apr库,这个库是C语言实现的,tomcat通过JNI方式使用该库可以大大提高性能. tomcat在使用apr时需要安装apr,apr-util和tomcat-na ...
- tomcat优化和JVM修改内存
Tomcat中的线程池(APR和ThreadPool) 2. 在Connector中指定使用共享线程池: <Connector executor="tomcatThreadPool&q ...
随机推荐
- MVC002之获取当前用户失败(Context.User.Identity.Name)
通过Context.User.Identity.Name想获取当前用户的域帐号信息(如:Greatwall\Snow) 可值等于"",什么原因呢. 该问题和MVC关系不大,主要是I ...
- Redis集群部署及命令
一.简介 redis集群是一个无中心的分布式Redis存储架构,可以在多个节点之间进行数据共享,解决了Redis高可用.可扩展等问题. redis集群提供了以下两个好处: 将数据自动切分(split) ...
- 牛客网练习赛43-C(图论)
题目链接:https://ac.nowcoder.com/acm/contest/548/C 题意:有n个知识点,学会每个知识点花T[i],已经学会了其中k个知识点,有m组关系,t1,t2,t3,表示 ...
- Flask中路由系统、Flask的参数及app的配置
@app.route('/', methods=['GET', 'POST']) 1. @app.route()装饰器中的参数 methods:当前URL地址,允许访问的请求方式 @app.route ...
- 1、str.join() 2、fromkeys() 3、深浅拷贝 4、set()
1. 补充基础数据类型的相关知识点 1. str. join() 把列表变成字符串 2. 列表不能再循环的时候删除. 因为索引会跟着改变 3. 字典也不能直接循环删除. 把要删除的内容记录在列表中. ...
- PAT1135(红黑书的判定)
There is a kind of balanced binary search tree named red-black tree in the data structure. It has th ...
- ATX 安卓设备 WiFi 统一管理以及设备自动化测试
众所周知,安卓单台设备的UI自动化测试已经比较完善了,有数不清的自动化框架或者工具.但是介绍多设备管理的内容并不多,当手里的手机多了之后,要做自动化测试平台,这块的东西又不得不碰,摆脱USB限制,接入 ...
- fbx模型加载的材质球路径
选择Location为外部加载时,会通过搜索来读取外部文件 From Model's Material 搜索项目中Materials文件 [ModelName].mat 会优先搜索当前子文件夹有没有 ...
- JavaScript各种继承方式(三):组合继承(combination inheritance)
一 原理 组合继承仅仅是同时使用了原型链继承和构造函数继承. 具体做法是,将父类的实例作为子类的构造函数的原型对象,并在子类的构造函数中调用父类的构造函数. function Fruit(name){ ...
- 微信小程序开发——前端如何区分小程序运行环境
前言: 之前用vue做h5项目,对于接口请求,都是根据前端访问域名来判断运行环境,然后自动适配对应的服务器地址的.这样的好处就是在开发.测试及发布上线全程都不需要手动去改接口请求地址,只要提前配置好就 ...