1 总是遇到read time out ,socket什么的       
    <Executor name="tomcatThreadPool" namePrefix="catalina-exec-" 
        maxThreads="10000" maxSpareThreads="2000" minSpareThreads="1000" 
  acceptCount="10000" connectionTimeout="20000" URIEncoding="UTF-8" />

调大点吧,量服务器力而行吧

2 有的时候project 的相关应用会执行两次,是host的context的配置的问题

<Host name="localhost"  appBase="webapps/projectName" unpackWARs="true" autoDeploy="true">
    <Context path="/projectName" docBase="." debug="0" reloadable="true" />
   </Host>

3 tomcat优化步骤
第一轮进行了问题的定位,第二轮就是进行了apache+tomcat/weblogic的优化,第三轮是做集群优化,第四轮是sql与codes的优化。
(1) 禁用DNS查询,当web应用程序要记录客户端的信息时,它也会记录客户端的IP地址或者通过域名服务器查找机器名转换为IP地址。
      DNS查询需要占用网络,enableLookups=false
(2) 调整minSpareThreads(初始化线程数)和maxThreads(设置最大可创建的线程数)、maxSpareThreads(设置开始清理空闲线程的阀值)以及acceptCount(排队数)、
     compression、compressionMinSize="2048"
(3) NIO配置
     BIO每个web请求一个单独的线程,所以并发量一旦上去了,线程数就上去了,CPU就忙着线程切换,所以BIO不合适高吞吐量、高可伸缩的web服务器
     而NIO则是使用单线程(单个CPU)或者只使用少量的多线程(多CPU)来接受Socket,而由线程池来处理堵塞在pipe或者队列里的请求.这样的话,只要OS可以接受TCP的连接,web服务器就可以处理该请求。
    Connector设置protocol="org.apache.coyote.http11.Http11NioProtocol" 
(4) 配置负载均衡
(5) 内存设置
  (5.1)
     java.lang.OutOfMemoryError: PermGen space 
     指内存的永久保存区域,这块内存主要是被JVM存放Class和Meta信息的,GC不会在主程序运行期对PermGen space进行清理
     JAVA_OPTS="-server -XX:PermSize=64M -XX:MaxPermSize=128M"
   (5.2)
     java.lang.OutOfMemoryError: Java heap space
     存放类实例(Instance)的Heap区域,初始空间(即-Xms),最大空间(-Xmx)
     JAVA_OPTS="-server -Xms800m -Xmx800m"
    对于SUN和HP等虚拟机,推荐将最小堆大小和最大堆大小设置为同一值,因为这样可以避免浪费用于时常调整堆大小所需的 VM 资源。
    IBM虚拟机推荐把-Xms设置为应用所需的最小值,这样会产生高效的垃圾回收。

4  tomcat监控

4.1 Server端配置修改要监控的TOMCAT/bin/catalina.sh,添加如下配置:
       JAVA_OPTS='-Xms128m -Xmx512m -Dcom.sun.management.jmxremote 
                 -Dcom.sun.management.jmxremote.port=9004 
                 -Dcom.sun.management.jmxremote.authenticate=false 
                 -Dcom.sun.management.jmxremote.ssl=false 
                -Djava.rmi.server.hostname=192.168.19.207'
       其中9004为端口号,192.168.19.207为服务器IP,修改为具体的端口号和服务器IP。
  4.2 CLIENT端配置命令行输入:jconsole 192.168.19.207:9004即:jconsole server IP:PORT的形式

4.3 生成的dump文件

使用jcosole中的MBean,到MBean>com.sun.management>HotSpotDiagnostic>操作>dumpHeap中,在参数p0中填写保存dump文件的路径,

如果要使用Eclipse Memory Analyzer来分析则文件的后缀要为hprof。点击dumpHeap按钮生成dump文件。

4.4 安装使用 MyEclipse Memory Analyzer

    (1) 在http://www.eclipse.org/mat/downloads.php中根据操作系统版本下载相应安装包,Archived Update Site

(2) 连同文件夹一起解压到MyEclipse-8.6\dropins下,在改路径下新建文件mat.link,并写下path=..\\MyEclipse-8.6\\dropins\\MemoryAnalyzer-1.3.0.201305170842

注:Eclipse只要在按照常规安装方式即可 org.eclipse.mat.updatesite    http://download.eclipse.org/mat/1.3/update-site/

http://www.oracle.com/technetwork/java/javase/downloads/index.html

tomcat 调优的更多相关文章

  1. Tomcat调优及JMX监控

    Tomcat调优及JMX监控 实验背景 ====================================================== 系统版本:CentOS release 6.5 ( ...

  2. tomcat调优的几个方面(转)

    tomcat调优的几个方面 和早期版本相比最新的Tomcat提供更好的性能和稳定性.所以一直使用最新的Tomcat版本.现在本文使用下面几步来提高Tomcat服务器的性能. 增加JVM堆内存大小 修复 ...

  3. tomcat 调优-生产环境必备

    目录 1. tomcat 启动慢 1.1 tomcat 获取随机值阻塞 1.2 tomcat 需要部署的web应用程序太多 1.3 tomcat启动内存不足 2 Connector 调优 2.2 Co ...

  4. Tomcat调优总结(Tomcat自身优化、Linux内核优化、JVM优化)

    Tomcat自身的调优是针对conf/server.xml中的几个参数的调优设置.首先是对这几个参数的含义要有深刻而清楚的理解.以tomcat8.5为例,讲解参数. 同时也得认识到一点,tomcat调 ...

  5. 简谈Tomcat调优

    一.Tomcat和apache的比较 共同点:apache和tomcat都是属于web服务器. 不同点:他们是两个不同的容器,承载的东西不一样,tomcat属于一种java应用的服务 器,只针对jav ...

  6. Tomcat 调优技巧

    Tomcat 调优技巧:1.Tomcat自身调优: ①采用动静分离节约Tomcat的性能: ②调整Tomcat的线程池: ③调整Tomcat的连接器: ④修改Tomcat的运行模式: ⑤禁用AJP连接 ...

  7. 一线大厂Java面试必问的2大类Tomcat调优

    一.前言 最近整理了 Tomcat 调优这块,基本上面试必问,于是就花了点时间去搜集一下 Tomcat 调优都调了些什么,先记录一下调优手段,更多详细的原理和实现以后用到时候再来补充记录,下面就来介绍 ...

  8. Tomcat 调优测试

    测试环境: OS: Ubuntu14.04 64位 (运行在Docker1.9) CPU: Intel i3 双核四线程 Mem: 8G Tomcat版本: Tomcat8.5 Java SDK版本: ...

  9. Tomcat 调优的技巧 (转)

    描述 最近在补充自己的短板,刚好整理到Tomcat调优这块,基本上面试必问,于是就花了点时间去搜集一下tomcat调优都调了些什么,先记录一下调优手段,更多详细的原理和实现以后用到时候再来补充记录,下 ...

  10. Tomcat负载均衡、调优核心应用进阶学习笔记(五):Tomcat调优和Tomcat监控(差评)

    文章目录 tomcat调优 tomcat监控 tomcat调优 vi catalina.sh # --------------------------------------------------- ...

随机推荐

  1. 1-Highcharts环境介绍及配置

    Highcharts:功能强大.开源.美观.图表丰富.兼容绝大多数浏览器的纯js图表库,废话不多说,直接进入主题! 首先,下载Highcharts包文件,下载地址如下: 中文网下载中心:http:// ...

  2. WPF 显示初始化界面

    今天在看<WPF编程宝典>时,看到了Application类,该类可以做很多事情,我认为比较实用的是显示初始化界面,因为之前有个项目在打开的时候要加载好多dll,非常耗时,让客户等的蛋疼, ...

  3. Apache Ignite——新一代数据库缓存系统

    [编者按]飞速增长的数据需要大量存储,对这些数据的管理也不是一件容易的事.但相比于存储和管理,如何处理数据才是开发人员真正的挑战.对于TB级别数据的存储和处理通常会让开发人员陷入速度.可扩展性和开销的 ...

  4. AJAX请求也会重新刷新整个页面?

    由于对HTML的一些内置行为不理解,所以面对今天的AJAX请求也会重新绘页面百思不得其解. 后来,请教跟伟哥同属前端组的杨成之后,才知道是由于button的默认行为导致的. 需要阻止这种标签行为,才可 ...

  5. 使用ajax()方法加载服务器数据

    使用ajax()方法加载服务器数据 使用ajax()方法是最底层.功能最强大的请求服务器数据的方法,它不仅可以获取服务器返回的数据,还能向服务器发送请求并传递数值,它的调用格式如下: jQuery.a ...

  6. Makefile笔记

    一个简单的Makefile描述规则组成: TARGET...:PREREQUISITES... COMMANDS... ... target:规则的目标.通常是程序中间或者最后要生成的文件名,也可以是 ...

  7. [mock]7月25日

    1. 将一个数组分成左右两部分,使得右边的某个连续子段和减去左边的某个连续字段和最小[7,8,9,|3,5,-1] sum right - sum left minimal 想到左右分一刀,O(n), ...

  8. 【Linux高频命令专题(16)】less

    概述 less 工具也是对文件或其它输出进行分页显示的工具,应该说是linux正统查看文件内容的工具,功能极其强大.less 的用法比起 more 更加的有弹性.在 more 的时候,我们并没有办法向 ...

  9. Sina App Engine(SAE)教程(11)- Yaf使用

    Yaf参考资料 Yaf(Yet Another Framework)用户手册 想在SAE使用Yaf? 无需申请,sae环境已经全面支持. Yaf 实战 下面是一个运行在SAE的Yaf的hello wo ...

  10. Hibernate逍遥游记-第10章 映射继承关系-001继承关系树中的每个具体类对应一个表

    1. 2. <?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate ...