资讯专栏INFORMATION COLUMN

Tomcat优化笔记

Coding01 / 933人阅读

摘要:不同的应用场景,不同的架构,不同的需求,都会对优化设置有不同要求。在这里我所记述的只是我自己在一些应用中所设置的优化项,以备不时之需,并不是放之四海而皆准的准则。为了消除这些警告,还需要根治。

一千个人眼中就有一千个哈姆雷特。——伪西方谚语

关于Tomcat的优化点之多,我估计没有上万,也有成千。不同的应用场景,不同的架构,不同的需求,都会对优化设置有不同要求。在这里我所记述的只是我自己在一些Tomcat应用中所设置的优化项,以备不时之需,并不是放之四海而皆准的准则。

pom.xml

对于maven项目来说,pom.xml设置是整个设置的核心,如果pom.xml设置不当,虽然有时候也可以编译运行,但总是会出现一些令人讨厌的警告。为了消除这些警告,还需要根治pom.xml

重复依赖

首先要解决的是重复依赖问题,有时候我们会在编译项目时遇到下面的这样的警告:

[WARNING]
[WARNING] Some problems were encountered while building the effective model for com.qiban.supplier:saas-supplier:war:1.0-SNAPSHOT
[WARNING] "dependencies.dependency.(groupId:artifactId:type:classifier)" must be unique: commons-codec:commons-codec:jar -> duplicate declaration of version 1.9 @ line 264, column 21
[WARNING]
[WARNING] It is highly recommended to fix these problems because they threaten the stability of your build.
[WARNING]
[WARNING] For this reason, future Maven versions might no longer support building such malformed projects.
[WARNING]

解决的方法很简单:在pom.xml中搜索出现重复依赖的jar包名称,你肯定会发现对于同一个jar包,重复引用了多次,也许版本相同,也许版本不同,只要删除掉那些重复的就可以了。

maven编译器版本

有时候会遇到下面这样的错误:

[WARNING]
[WARNING] Some problems were encountered while building the effective model for com.qiban.supplier:saas-supplier:war:1.0-SNAPSHOT
[WARNING] "build.plugins.plugin.version" for org.apache.maven.plugins:maven-compiler-plugin is missing. @ line 297, column 21
[WARNING]
[WARNING] It is highly recommended to fix these problems because they threaten the stability of your build.
[WARNING]
[WARNING] For this reason, future Maven versions might no longer support building such malformed projects.
[WARNING]

这意思是说你没有在pom.xml里指定maven的版本,在pom.xml里添加maven的版本就可以了:

    
        saas-supplier
        
            
                org.apache.maven.plugins
                maven-compiler-plugin
                3.5.1
                
                    1.8
                    1.8
                
            
        
    

重点是上面那个3.5.1

jdom

有的时候会遇到一行简单的警告:

[WARNING] The artifact jdom:jdom:jar:1.1 has been relocated to org.jdom:jdom:jar:1.1

这个的意思是说在你的pom.xml里,你需要把jdomgroupId改为org.jdom

       
            org.jdom
            jdom
            1.1
        
activemq-spring

下面这个警告不会在编译时出现,但是会在运行时出现,也非常恶心:

SLF4J: Class path contains multiple SLF4J bindings

我们需要把pom.xml里的activemq-all改成activemq-spring

        
            org.apache.activemq
            activemq-spring
            5.11.1
        

详细解释可以看我的这篇文章。

log4j.properties

终于改完了pom.xml,我们开始处理log4j。

xmemcached

如果你使用了xmemcached,那么日志里会不断地出现xmemcached的警告,而这些警告对我们来说根本就不是警告,毫无意义,并且会掩盖真正的错误,所以我们通过修改log4j.properties文件屏蔽它:

# xmemcached
log4j.logger.com.google.code=OFF
log4j.logger.net.rubyeye.xmemcached=OFF

我这里比较野蛮粗暴地直接使用了OFF选项,如果你不放心,可以改成ERROR选项,效果是一样的。

webapp名称+%c

如果你有多个webapp,为了准确显示到底是哪个webapp的哪个class报的错,我们需要在log4j.properties文件里注明我们的webapp名称,再加上一个%c符号:

log4j.appender.STDOUT.layout.ConversionPattern=[%d{yyyy-MM-dd HH:mm:ss}] %-5p - activity - %c - %m%n

这样下回再有任何错误,我们可以第一时间迅速定位到到底是哪个webapp的哪个class出的错误。

logrotate

如果我们不管不顾的话,Tomcat的日志文件几乎会无限制增长,最终会耗尽我们的硬盘空间,所以我们需要用logrotate来限制它一下,在/etc/logrotate.d文件夹下创建一个文件tomcat

/opt/tomcat1/logs/catalina.out
/opt/tomcat2/logs/catalina.out
{
   copytruncate
   daily
   rotate 7
   compress
   missingok
   size 10M
}
setenv.sh

Tomcat不问青红皂白,上来就要占领我们主机整个物理内存的四分之一,我们需要限制它的大小,宁可浪费一些CPU和硬盘的时间去让它不断地垃圾回收,也不想让它占用这么多的内存,所以我们需要在/opt/tomcat/bin下建立一个setenv.sh文件,强制让它最多占用1G内存:

export CATALINA_OPTS="$CATALINA_OPTS -Xms512m"
export CATALINA_OPTS="$CATALINA_OPTS -Xmx1024m"

这样我们一台16G内存的主机,可以同时运行16Tomcat,而不像以前,最多只能同时运行4Tomcat

jarsToSkip

Tomcat启动时会不断地扫描所有.jar文件,并且报一些不知所谓的警告:

09-Dec-2017 20:03:14.289 FINE [localhost-startStop-1] org.apache.jasper.servlet.TldScanner$TldScannerCallback.scan No TLD files were found in [file:/home/apache-tomcat-8.5.4/lib/tomcat-redis-session-manager-master-2.0.0.jar]. Consider adding the JAR to the tomcat.util.scan.StandardJarScanFilter.jarsToSkip property in CATALINA_BASE/conf/catalina.properties file.

直接在/opt/tomcat/conf/catalina.properties文件里把这一句话改成:

tomcat.util.scan.StandardJarScanFilter.jarsToSkip=*.jar

这个世界终于清静了,扫什么扫,有什么可扫的!

startStopThreads

当你有多个webapp的时候,Tomcat缺省会启完一个webapp再启下一个,这样太慢了,不可忍受,我们在/opt/tomcat/conf/server.xml文件里把它的启动线程数直接干到20个:

Dubbo

有时候Dubbo也会跳出来捣乱,在每一个不同的webapp下的consumer.xml文件里指定file

每个webappfile名称各不相同,它们再也不会互相打架了。

结语

以上所述也不过只是冰山之一角,好记性不如烂笔头,记录下来作为以后每次优化时的依据,也许对遇到类似问题的你也略有启发吧。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/77225.html

相关文章

  • Tomcat调优笔记

    摘要:在利用收集了两次的相关数据,发现这和的存在关系,图表如下在第一次的前期,动作比较多,此时的吞吐量一直维持在比较低的水平。第二次几乎没有的动作,此时的吞吐量一直维持在比较高的水平。 本文是在Tomcat调优过程中得到的心得(会持续更新),相关环境: java version 1.8.0_131 Tomcat 8.5.14 Jmeter 3.1 Jmeter参数: 300线程 100...

    nanchen2251 评论0 收藏0

发表评论

0条评论

Coding01

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<