- 浏览: 565397 次
- 性别:
- 来自: 南京
文章分类
- 全部博客 (350)
- Sybase (30)
- SQL SERVER2005 (14)
- 数据库 (27)
- SSH框架 (27)
- WebService (21)
- 下载-软件收藏 (15)
- 随笔-日常使用 (9)
- Flex 相关 (13)
- Linux (11)
- Web (64)
- XML相关 (9)
- Socket相关 (1)
- Elipse (3)
- 统计报表 (11)
- 线程相关 (3)
- Java相关 (37)
- JAVASCRIPT (19)
- JAVA反射 (3)
- JSP标签 (3)
- 随笔-其他 (2)
- 随笔-设计模式 (3)
- 随笔-架构师相关 (1)
- 下载-源码 (7)
- 下载-帮助文档 (1)
- 下载-插件 (6)
- 技术-.NET (2)
- 技术-Excel VBA (8)
- 应用-地图相关 (2)
- 应用-GSM短信猫 (5)
- 应用-单点登录 (3)
- Android相关 (3)
最新评论
-
sucheng2016:
发现jconn4.jar 里面有getBlob(String) ...
Sybase15驱动包的问题com.sybase.jdbc3.jdbc.SybDriver -
sucheng2016:
java.lang.UnsupportedOperationE ...
Sybase15驱动包的问题com.sybase.jdbc3.jdbc.SybDriver -
ok123zxx:
没下文了吗
通过 Tomcat Advanced I/O 获得高性能的 Ajax tocmat6+CometProcessor -
q1345111:
大家这个问题 尚未完成方法 com.sybase.jdbc3. ...
Sybase15驱动包的问题com.sybase.jdbc3.jdbc.SybDriver -
bdk82924:
heshujing217187 写道问题同1楼一样,求解!换j ...
Sybase15驱动包的问题com.sybase.jdbc3.jdbc.SybDriver
转:http://58.248.14.72:8080/showtopic-59.aspx
1、 Tomcat的外部调优
JAVA虚拟机(JVM)性能优化,可以通过以下两个参数来设置虚拟机使用内存的大小,-Xms<size>(JVM初始化堆的大小)和-Xmx<size>(JVM堆的最大值)。
这两个值的大小一般根据需要进行设置。初始化堆的大小执行了虚拟机在启动时向系统申请的内存的大小。一般而言,这个参数不重要。但是有的应用程序在大负载的情况下会急剧地占用更多的内存,此时这个参数就是显得非常重要,如果虚拟机启动时设置使用的内存比较小而在这种情况下有许多对象进行初始化,虚拟机就必须重复地增加内存来满足使用。由于这种原因,我们一般把-Xms和-Xmx设为一样大,而堆的最大值受限于系统使用的物理内存。一般使用数据量较大的应用程序会使用持久对象,内存使用有可能迅速地增长。当应用程序需要的内存超出堆的最大值时虚拟机就会提示内存溢出,并且导致应用服务崩溃。因此一般建议堆的最大值设置为可用内存的最大值的80%。
Tomcat默认可以使用的内存为128MB,在较大型的应用项目中,这点内存是不够的,需要调大。
Windows下,在文件{tomcat_home}/bin/catalina.bat,Unix下,在文件{tomcat_home}/bin/catalina.sh的前面,增加如下设置:
JAVA_OPTS='-Xms【初始化内存大小】-Xmx【可以使用的最大内存】'
需要把这个两个参数值调大。例如:AVA_OPTS='-Xms256m-Xmx512m',表示初始化内存为256MB,可以使用的最大内存为512MB。
另外需要考虑的是Java提供的垃圾回收机制。虚拟机的堆大小决定了虚拟机花费在收集垃圾上的时间和频度。收集垃圾可以接受的速度与应用有关,应该通过分析实际的垃圾收集的时间和频率来调整。如果堆的大小很大,那么完全垃圾收集就会很慢,但是频度会降低。如果你把堆的大小和内存的需要一致,完全收集就很快,但是会更加频繁。调整堆大小的的目的是最小化垃圾收集的时间,以在特定的时间内最大化处理客户的请求。在基准测试的时候,为保证最好的性能,要把堆的大小设大,保证垃圾收集不在整个基准测试的过程中出现, 如果系统花费很多的时间收集垃圾,请减小堆大小。一次完全的垃圾收集应该不超过3-5秒。如果垃圾收集成为瓶颈,那么需要指定代的大小,检查垃圾收集的详细输出,研究垃圾收集参数对性能的影响。一般说来,你应该使用物理内存的80%作为堆大小。当增加处理器时,记得增加内存,因为分配可以并行进行,而垃圾收集不是并行的。
2、 Tomcat的内部调优
(一)禁止DNS查找
有时候我们的应用可能要记录客户端的信息,两种方式,一是记录客户端的数字IP地址,另一个是在DNS数据中查找真实的主机名。DNS查找会增加网络通信,以致造成了网络延迟。要消除这个延迟,我们可以禁掉DNS查找。这时我们的应用再调用getRemoteHost( )方法时,它就只会得到数字IP地址。这个配置是在Tomcat的serve.xml文件中,Connector对象的enableLookups属性,如下:
<!--
Define a non-SSLCoyote HTTP/1.1 Connector on port 8080
-->
<Connector
className="org.apache.coyote.tomcat4.CoyoteConnector"
port="8080"minProcessors="5" maxProcessors="75"
enableLookups="true" redirectPort="8443"
acceptCount="10" debug="0" connectionTimeout="20000"
useURIValidationHack="false"
/>
在生产系统中,除非应用要得到所有客户端真实的主机名,这个通常是建议禁掉的。实在不行这样的工作我们可以在Tomcat的外面做。在一个流量较小的Servr这种修改的效果可能不是十分明显,但是对于某些站点来说,也许突然之间流量暴增也说不定呢,比如,前段时间的奥运票务网站,哈哈!
(二)调整线程数
另一个影响性能的是Connector所使用的进程数。Tomcat使用一个线程池来提高请求响应的速度。Java中的一个线程单独同操作系统交互,并且有它自己的本地内存,以及同进程内的其他线程分享部分共享内存。
我们可以通过修改Connector对象的minProcessors和maxProcessors来控制线程数。这个数字也许在刚上线的时候进行了适当的设置,可是当用户数变多的时候我们就要增加配置数了。minProcessors值应该设置的足够大来处理最小负载。当用户变多的时候,Tomcat会分配更多的线程,不超过maxProcessors。上限也一定要设置的适当,以免使server的内存超过JVM的内存限制而挂掉。
(三)加速JSP的编译
第一次访问JSP的时候,它会被转换成Java servlet源码,然后编译成二进制代码。这个过程中,我们是可以控制所使用的编译器的。默认情况,Tomcat所使用的是和命令行上执行javac时同样的编译器。其实有更快的编译器的,我们可以利用这些来提高JSP的编译速度。
五、Tomcat服务器的监控
1、Tomcat自带的监控指标servelet
第一步:在配置文件中增加用户访问的权限。修改conf/tomcat-users.xml文件,在其中加入一行 <user username="用户名" password="密码" roles="manager"/>
第二步:在IE浏览器中输入http://IP地址:端口号/manager/status
第三步:在弹出的对话框中输入第一步设置的用户名和密码,即可查看到应用服务器的相关性能指标数据。
2、使用专门的工具进行监控,网上很多在此就不再赘述。
在tomcat配置文件server.xml中的配置中,和连接数相关的参数有:
minProcessors:最小空闲连接线程数,用于提高系统处理性能,默认值为10
maxProcessors:最大连接线程数,即:并发处理的最大请求数,默认值为75
acceptCount:允许的最大连接数,即等待队列,指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理。应大于等于maxProcessors,默认值为100,
enableLookups:是否反查域名,取值为:true或false。为了提高处理能力,应设置为false
connectionTimeout:网络连接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。
和最大连接数相关的参数为maxProcessors和acceptCount。如果要加大并发连接数应同时加大这两个参数。
web server允许的最大连接数还受制于操作系统的内核参数设置,通常Windows是2000个左右,Linux是1000个左右。
3、server.xml配置简介
下面讲述这个文件中的基本配置信息,更具体的配置信息请参考tomcat的文档:
server:
1、port指定一个端口,这个端口负责监听关闭tomcat的请求
2、shutdown指定向端口发送的命令字符串
service:
1、name指定service的名字
Connector(表示客户端和service之间的连接):
1、port指定服务器端要创建的端口号,并在这个断口监听来自客户端的请求
2、minProcessors服务器启动时创建的处理请求的线程数
3、maxProcessors最大可以创建的处理请求的线程数
4、enableLookups如果为true,则可以通过调用request.getRemoteHost()进行DNS查询来得到远程客户端的实际主机名,若为false则不进行DNS查询,而是返回其ip地址
5、redirectPort指定服务器正在处理http请求时收到了一个SSL传输请求后重定向的端口号
6、acceptCount指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理
7、connectionTimeout指定超时的时间数(以毫秒为单位)
线程数可以大致上用“同时在线人数*每秒用户操作次数(每秒的连接数)*系统平均操作时间(服务器的处理时间)”来计算。
Engine(表示指定service中的请求处理机,接收和处理来自Connector的请求):
1、defaultHost指定缺省的处理请求的主机名,它至少与其中的一个host元素name属性值是一样的。
Context(表示一个web应用程序):
1、docBase应用程序的路径或者是WAR文件存放的路径
2、path表示此web应用程序的url的前缀,这样请求的url为
http://localhost:8080/path/****
3、reloadable这个属性非常重要,如果为true,则tomcat会自动检测应用程序的/WEB-INF/lib和/WEB-INF/classes目录的变化,自动装载新的应用程序,我们可以在不重起tomcat的情况下改变应用程序
host(表示一个虚拟主机):
1、name指定主机名
2、appBase应用程序基本目录,即存放应用程序的目录
3、unpackWARs如果为true,则tomcat会自动将WAR文件解压,否则不解压,直接从WAR文件中运行应用程序
Logger(表示日志,调试和错误信息):
1、className指定logger使用的类名,此类必须实现org.apache.catalina.Logger接口
2、prefix指定log文件的前缀
3、suffix指定log文件的后缀
4、timestamp如果为true,则log文件名中要加入时间,例:localhost_log.2001-10-04.txt
Realm(表示存放用户名,密码及role的数据库):
1、className指定Realm使用的类名,此类必须实现org.apache.catalina.Realm接口
Valve(功能与Logger差不多,其prefix和suffix属性解释和Logger中的一样):
1、className指定Valve使用的类名,如用org.apache.catalina.valves.AccessLogValve
类可以记录应用程序的访问信息
directory(指定log文件存放的位置):
1、pattern有两个值,common
发表评论
-
Docker 开源的应用容器引擎
2015-05-17 21:15 810Docker 是一个开源的应用容器引擎,让开发者可以打包他们 ... -
Ext Textfield框必填项 *号
2014-03-10 16:59 2670方法1:在items中加*号 var shortNam ... -
Struts2中查看Action配置的插件 -- Config Browser Plugin
2014-03-06 09:38 968(摘自官方介绍: http://struts.apache.o ... -
基于Spring的Rest服务中乱码问题
2013-12-10 18:45 15612Spring搭建的Rest服务端 在使用客户端调用Rest ... -
tomcat 报 “too many open files Too many open files" 问题的解决思路
2013-11-03 01:43 1623转:http://blog.csdn.net/big1980/ ... -
jsp的合并单元格
2013-05-27 08:59 1569合并单元格 <!DOCTYPE HTML PUBL ... -
tomcat 启动报错,日志不全如何检查
2013-04-10 15:30 1965有的时候由于某个配置错误,导致tomcat启动失败,但是呢日志 ... -
通过 Tomcat Advanced I/O 获得高性能的 Ajax tocmat6+CometProcessor
2013-03-20 16:02 2970最近项目上有个需求用到了Tomcat的后台推送技术,采用了非阻 ... -
表头固定表格jquery.chromatable
2013-03-09 14:08 1384直接上图吧 -
Spring MVC的使用
2013-02-07 15:42 839以前一直使用Struct2的MVC框架,感觉挺好用的,也 ... -
转 TortoiseSVN中分支和合并实践
2013-01-31 11:13 869转 TortoiseSVN中分支和合并实践 http://p ... -
Git的使用
2013-01-31 09:24 1763版本控制 从最早使用vs ... -
管理JDBC连接池jar包c3p0
2013-01-29 11:45 1560com.mchange.v2.c3p0.ComboPooled ... -
DbUtils的使用
2013-01-28 19:56 1254DbUtils的使用 今天在看一段源码的时候,看到了可以使用 ... -
Sybase15驱动包的问题com.sybase.jdbc3.jdbc.SybDriver
2013-01-28 19:48 13280com.sybase.jdbc3.jdbc.SybDriver ... -
Apache+tomcat配置集群
2013-01-22 19:30 1011直接上图 下载 http://download.cs ... -
Apache + Tomcat 配置多个应用
2013-01-22 19:05 1148今天在网上发现一篇帖子 ,Apache + Tomcat 配置 ... -
RSS的读取和发布
2013-01-22 15:53 1717这几天研究了RSS RSS(简易信息聚合,也叫聚合内容)是 ... -
短网址的原理和实现
2013-01-22 15:36 15376微博上经常会看到类似 http://t.cn/Afafhe 这 ... -
一个统一管理的例子,用观察者模式实现
2013-01-11 17:47 985如有这么一个需求 平台中需要实现一个统一管理的功能 ...
相关推荐
开发者可以根据需求调整相关参数,如增大最大连接数、设置线程池大小、配置SSL连接器以支持HTTPS等。同时,合理配置Valves和Realms能提供更安全的应用环境。 总之,server.xml是Tomcat的灵魂,它定义了服务器的架构...
配置数据源通常在`context.xml`或`server.xml`文件中完成,包括设置数据库URL、用户名、密码、最大连接数、最小连接数等参数。配置完成后,应用可以通过JNDI查找来获取数据源,然后通过数据源创建和管理数据库连接。...
- 调整`conf/server.xml`中的线程池设置,如最大连接数、空闲超时等,以适应不同负载。 - 使用JVM的性能调优选项,例如调整堆大小和垃圾回收策略。 **9. 监控与日志** - Tomcat的日志文件位于`logs`目录下,用于...
2. **性能优化**:可以调整`conf/server.xml`中的连接器设置,如最大线程数、超时时间等,以提高并发处理能力。 3. **JVM调优**:通过设置`JAVA_OPTS`环境变量,可以传递JVM参数,例如增加堆内存大小、开启G1垃圾...
### Tomcat7 优化与性能调优 #### 一、引言 在现代Web应用开发中,Apache Tomcat因其轻量级、灵活且易于部署的特点成为开发者们的首选应用服务器之一。然而,在面对高并发访问场景时,如何有效地优化Tomcat以提高...
5. **性能调优**:根据服务器硬件资源和负载情况,适当调整`conf/server.xml`中的参数,如最大线程数、最小空闲线程数等,以优化性能。 6. **备份与升级**:定期备份Tomcat的配置文件和应用程序,以便在出现问题时...
2. **连接池**:Tomcat的连接池(`conf/server.xml`中的`<Executor>`元素)可以配置以提高并发性能,例如设置最大线程数和空闲线程存活时间。 3. **性能调优**:根据应用负载调整参数,如增大堆内存、优化JVM设置、...
- `maxThreads`: 最大线程数,用于处理并发连接。 - `minSpareThreads`: 最小空闲线程数。 - `connectionTimeout`: 连接超时时间,单位为毫秒。 - `enableLookups`: 是否执行DNS查询,默认为true。 ```xml ...
`port`属性定义监听的端口号,`protocol`属性定义使用的协议,`maxThreads`定义最大线程数以处理并发请求。 四、`<Engine>`元素 `<Engine>`元素代表一个Servlet容器,它包含了多个`<Host>`(主机)元素。引擎处理...
- 调整`conf/server.xml`中的线程池参数,如最大线程数和空闲线程存活时间,以适应不同负载。 - 使用JVM内存调优,合理设置`JAVA_OPTS`,如-Xms和-Xmx。 7. **日志管理**: - Tomcat的日志文件默认位于`logs`...
7. **性能优化**:Tomcat允许调整各种性能参数,如最大线程数、空闲超时时间等。此外,还可以通过启用NIO(非阻塞I/O)或多线程模式来提高并发性能。 8. **监控与管理**:Tomcat内置了一个管理Web应用,通过`...
例如,增加`maxThreads`可以提高并发处理能力,调整`MaxConnections`限制同时连接数。 8. **监控与日志**:Tomcat提供了丰富的监控工具,如JMX(Java Management Extensions)和MBeans,可以监控服务器状态。`logs`...
1. **连接器配置**:可以通过调整连接器的并发参数来优化性能,如`maxThreads`(最大线程数)和`minSpareThreads`(最小空闲线程数),以适应不同的负载情况。 2. **超时设置**:`connectionTimeout`属性定义了...
在实际部署和管理过程中,了解如何配置`context.xml`来设置全局资源,或者通过修改`server.xml`中的Connector元素调整服务器性能(如最大连接数、线程池大小等)是非常重要的。同时,理解如何使用Tomcat的Manager...
另外,对于大型应用程序,可以通过调整`context.xml`和`server.xml`中的参数来进一步提升性能,比如增加连接器的最大连接数,或者启用HTTP/2协议以利用多路复用技术。 在开发和调试过程中,Tomcat提供了丰富的工具...
通过修改Connector配置来设定最大线程数(maxThreads)、最小空闲线程数(minSpareThreads)、线程预启动数量(prestartminSpareThreads)以及最大请求等待队列(maxQueueSize)。其中,maxThreads一般建议设置在500至1000...
- 调整`conf/context.xml`和`conf/server.xml`中的参数,例如最大线程数、连接超时等,以适应不同负载。 - 使用JVM的内存调优选项(如-Xms, -Xmx)来优化性能。 9. **故障排查:** - 查看`logs/catalina.out`...
- **maxProcessors**:最大允许创建的处理器线程数,控制并发请求的能力。 - **enableLookups**:决定是否通过DNS查找远程客户端的主机名,若设为false,将直接返回IP地址。 - **redirectPort**:当收到SSL请求时,...
6. **性能优化**:Tomcat可以通过调整JVM参数、限制并发连接数、启用连接池等方式进行性能优化。`context.xml`和`server.xml`中的配置可以影响这些性能指标。 7. **故障排查**:通过检查`logs`目录下的日志文件,如...
9. **性能调优**: 根据实际负载,可能需要调整Tomcat的配置参数,如最大线程数、最小空闲线程数、JVM堆大小等,以优化服务器性能。 10. **更新和维护**: 由于Tomcat是开源软件,定期检查并更新到最新版本是必要的,...