[转]Tomcat优化之内存、并发、缓存
1.Tomcat内存优化
Tomcat内存优化主要是对 tomcat 启动参数优化,我们可以在 tomcat 的启动脚本 catalina.sh 中设置 JAVA_OPTS 参数。
JAVA_OPTS参数说明
堆设置-server 启用jdk的 Server 版;一定要作为第一个参数,在多个CPU时性能佳 -Xms Java虚拟机初始化时的最小内存;Server端JVM最好将-Xms和-Xmx设为相同值; -Xmx java虚拟机可使用的最大内存;建议不要超过物理内存的一半; -XX: PermSize 内存永久保留区域; -XX: MaxPermSize 内存最大永久保留区域
服务器参数配置
现公司服务器内存一般都可以加到最大2G ,所以可以采取以下配置:
JAVA_OPTS=’-Xms1024m -Xmx2048m -XX: PermSize=256M -XX:MaxNewSize=256m -XX:MaxPermSize=256m’
配置完成后可重启Tomcat ,通过以下命令进行查看配置是否生效:
首先查看Tomcat 进程号:
sudo lsof -i:9027
我们可以看到Tomcat 进程号是 12222 。
查看是否配置生效:
sudo jmap – heap 12222
我们可以看到MaxHeapSize 等参数已经生效。
**
2.Tomcat并发优化
1.Tomcat连接相关参数
在Tomcat 配置文件 server.xml 中的
<Connector port="9027"protocol="HTTP/1.1"maxHttpHeaderSize="8192"minProcessors="100"maxProcessors="1000"acceptCount="1000"redirectPort="8443"disableUploadTimeout="true"/>
2.调整连接器connector的并发处理能力
1>参数说明
maxThreads 客户请求最大线程数
minSpareThreads Tomcat初始化时创建的 socket 线程数
maxSpareThreads Tomcat连接器的最大空闲 socket 线程数
enableLookups 若设为true, 则支持域名解析,可把 ip 地址解析为主机名
redirectPort 在需要基于安全通道的场合,把客户请求转发到基于SSL 的 redirectPort 端口
acceptAccount 监听端口队列最大数,满了之后客户请求会被拒绝(不能小于maxSpareThreads )
connectionTimeout 连接超时
minProcessors 服务器创建时的最小处理线程数
maxProcessors 服务器同时最大处理线程数
URIEncoding URL统一编码
2>Tomcat中的配置示例
<Connector port="9027" protocol="HTTP/1.1" redirectPort="8443" URIEncoding="utf-8" maxHttpHeaderSize="8192"maxThreads="1000"minSpareThreads="100"maxSpareThreads="1000"minProcessors="100"maxProcessors="1000"enableLookups="false"acceptCount="1000"disableUploadTimeout="true"/>
3.Tomcat缓存优化
1>参数说明
c ompression 打开压缩功能
compressionMinSize 启用压缩的输出内容大小,这里面默认为2KB
compressableMimeType 压缩类型
connectionTimeout 定义建立客户连接超时的时间. 如果为 -1, 表示不限制建立客户连接的时间
2>Tomcat中的配置示例
<Connector port="9027"protocol="HTTP/1.1" connectionTimeout="20000"URIEncoding="utf-8" 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"acceptCount="1000"disableUploadTimeout="true"/>
4.配置案例
1>旧有的配置【谨慎参考,原文没有标服务器环境】
参考网络对服务器做过如下配置,拿出来分享下:
<Connector port="9027" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" URIEncoding="utf-8" maxHttpHeaderSize="8192"maxThreads="1000"minSpareThreads="25"maxSpareThreads="75"enableLookups="false"compression="on"compressionMinSize="2048" compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain"acceptCount="200"disableUploadTimeout="true" />
后来发现在访问量达到3 百万多的时候出现性能瓶颈。
2>更改后的配置
<Connector port="9027" protocol="HTTP/1.1" connectionTimeout="20000" URIEncoding="utf-8" 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"acceptCount="1000"disableUploadTimeout="true"/>
......未完待总结
参考推荐:
http://www.cnblogs.com/starhu/p/5599773.html
http://ajita.iteye.com/blog/1994974
转载于:https://www.cnblogs.com/gsyun/p/6945254.html
[转]Tomcat优化之内存、并发、缓存相关推荐
- tomcat优化-有改protocol 和 缓存 集群方案
tomcat优化 在线上环境中我们是采用了tomcat作为Web服务器,它的处理性能直接关系到用户体验,在平时的工作和学习中,归纳出以下七种调优经验. 1. 服务器资源 服务器所能提供CPU.内存.硬 ...
- tomcat优化-有改protocol 和 缓存 集群方案 转载自http://passover.blog.51cto.com/2431658/732629
tomcat优化 在线上环境中我们是采用了tomcat作为Web服务器,它的处理性能直接关系到用户体验,在平时的工作和学习中,归纳出以下七种调优经验. 1. 服务器资源 服务器所能提供CPU.内存.硬 ...
- 【Android 内存优化】Bitmap 硬盘缓存 ( Google 官方 Bitmap 示例 | DiskLruCache 开源库 | 代码示例 )
文章目录 一.Google 官方 Bitmap 相关示例参考 二.磁盘缓存类 DiskLruCache 三.磁盘缓存初始化 四.存储数据到磁盘缓存中 五.从磁盘缓存中读取数据 六. Android 1 ...
- 深入理解并发内存模型||JMM与内存屏障||多核并发缓存架构 ||JMM内存模型||volatile 关键字的作用 ||JMM 数据原子操作||JMM缓存不一致的问题
深入理解并发内存模型||JMM与内存屏障 多核并发缓存架构 JMM内存模型 volatile 关键字的作用 JMM 数据原子操作 JMM缓存不一致的问题
- 提高网站访问性能——Tomcat优化
一.前言 tomcat 服务器在JavaEE项目中使用率非常高,所以在生产环境对tomcat的优化也变得非常重要了,对于tomcat的优化,主要是从2个方面入手,一是tomcat本身的配置,另一个是t ...
- tomcat优化设置
2019独角兽企业重金招聘Python工程师标准>>> 1. 如何加大tomcat连接数 在tomcat配置文件server.xml中的<Connector ... /> ...
- Tomcat学习总结(3)——Tomcat优化详细教程
Tomcat是我们经常使用的 servlet容器之一,甚至很多线上产品都使用 Tomcat充当服务器.而且优化后的Tomcat性能提升显著,本文从以下几方面进行分析优化. 一.内存优化 默认情况下To ...
- iis7.0 https访问显示403访问被拒绝_提高网站访问性能——Tomcat优化
一.前言 tomcat 服务器在JavaEE项目中使用率非常高,所以在生产环境对tomcat的优化也变得非常重要了,对于tomcat的优化,主要是从2个方面入手,一是tomcat本身的配置,另一个是t ...
- Tomcat7 性能优化,提高并发-NIO模式
1. 目的 通过优化tomcat提高网站的并发能力.当我们今天我们将这个优化讲完之前 优化完成后看能达到什么层次. 2. 服务器资源 服务器所能提供CPU.内存.硬盘的性能对处理能力有决定性影响 ...
最新文章
- 驱动备份工具哪个好_文章原创度检测工具哪个好?这个工具还有其他你不知道的功能...
- 【JavaScript】appendChild一个的注意点之会删除原dom树节点
- 周报_2012第11周(2012/03/11-2012/03/17)
- axios get post下载文件
- 第1章 Ext JS介绍与快速入门[1/4]
- OKHttp源码解析(1)----整体流程
- 如何***内网windows xp的几种思路和方法
- ASP.NET网页显示LED字体 (转)
- 微信小程序对接海康威视摄像头
- 动物电子耳标阅读器|识读器|读卡器L8600系列Modbus RTU通讯协议与二次开发说明
- 亚马逊黑五哑火,中国跨境电商高歌猛进!
- 详解阿里云数据中台,一篇文章全面了解大数据“网红”
- opa学习1--开发环境搭建
- SQL 身份证获取性别
- 【3D目标检测】学习过的论文整理
- 中国行政区划数据下载
- 华强买瓜-梵高星空限定版
- 广工的计算机全国排名,广东工业大学排名2021 广东排名第10全国排名第152
- DIB-R 可微分渲染器使用
- Dropbox OAuth2.0 help for java
热门文章
- Charles调试Https Android
- docker中创建redis及在外部使用rdm连接
- 浅析在公众号中使用弛声sdk为什么上传解析慢
- Android中Intent/Bundle的通信原理及大小限制(Parcelable原理及与Serializable的区别)
- HURST 1116:选美大赛(LIS+路径输出)
- java去除字符串的空格,换行符,水平制表符,回车
- ZOJ 3962:Seven Segment Display(思维)
- 解决Dreamweaver 8打开时闪退的问题
- Spring Data JPA 查询方法支持的关键字
- (转)javascript实现导出Word、Excel