Java应用容器介绍以及tomcat优化实战

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
容器镜像服务 ACR,镜像仓库100个 不限时长
简介:

     java开发语言在软件开发里面是比较火的,特别涉及到一些大型架构,一般都会使用java来开发软件,所以java容器使用和选型不一样。

    1. Tomcat是Apache鼎力支持的Java Web应用服务器,由于它优秀的稳定性以及丰富的文档资料,广泛的使用人群,从而在开源领域受到最广泛的青睐。

    2. Jboss作为Java EE应用服务器,它不但是Servlet容器,而且是EJB容器,从而受到企业级开发人员的欢迎,从而弥补了Tomcat只是一个Servlet容器的缺憾。

    3. Resin也仅仅是一个Servlet容器,然而由于它优秀的运行速度,使得它在轻量级Java Web领域备受喜爱,特别是在互联网Web服务领域,众多知名公司都采用其作为他们的Java Web应用服务器,譬如163、ku6等。商用应用服务器里主要有:Weblogic、Websphere,Weblogic 同等条件下,在性能及易用性等方面,要比Tomcat优秀很多。

    4.glassfish是Sun公司推出的Java EE服务器,一个比较活跃的开源社区,不断的通过社区的反馈来提高其的可用性,经过glassfish v1 glassfish v2 到今天的glassfish v3 ,它已经走向成熟.Glassfish是一个免费、开放源代码的应用服务,它实现了Java EE 5,Java EE 5 平台包括了以下最新技术:EJB 3.0、JSF 1.2、Servlet 2.5、JSP 2.1、JAX-WS 2.0、JAXB 2.0、 Java Persistence 1.0、Common Annonations 1.0、StAX 1.0等

    支持集群,通过内存中会话状态复制,增强了部署体系结构的可用性与可伸缩性,它对集群有着很好的支持,可以简单到通过添加机器,就可轻松的提高网站的带负载能力,在解析能力方面,它对html的吞吐能力与apache服务器不分上下,就是tomcat所不能比的,支持目录部署,热部署,解决了tomcat对热部署能力的缺陷.在版本方面做的更加人性化,有开发时用的简化版,专门用于部署web项目的版本,还要完全符合j2ee标准的版本。

 

   公司在业务平台重构的时候就选用java,在开发以及测试等环节都没有参与,只是在产品上线过程中参与项目中,对于相关的软件选型等问题没有更多的参与,所有的java容器全部选用tomcat 。所以只能将tomcat优化使用,以后在优化等问题时可以考虑使用其他的应用容器,像resin等在一些大型企业使用较多,而tomcat一些小型的架构使用较多,本次项目使用tomcat,中间遇到了很多问题,也学习到了很多东西。

(1)软件选型以及安装

      apache-tomcat-7.0.68   由于公司的项目是采用模块化开发,主要包含计费模块、用户模块等多个功能模块,由于系统架构等问题,基本上都是多实例部署tomcat,通过设置不同的端口,启动不同的服务。软件就选择免安装版本,配置与管理方面。

(2)jvm的优化与配置

    JAVA_OPTS="-Djava.awt.headless=true -Dfile.encoding=UTF-8  
    -server -Xms1024m -Xmx1024m  
    -XX:NewSize=512m -XX:MaxNewSize=512m -XX:PermSize=512m  
    -XX:MaxPermSize=512m -XX:+DisableExplicitGC"
 
 CATALINA_OPTS="$CATALINA_OPTS -Xms256M -Xmx512M -Xmn256M"

 

(3)部分设置与优化

                <Connector port="8028" protocol="org.apache.coyote.http11.Http11NioProtocol"
                           
                           connectionTimeout="30000"
                           useBodyEncodingForURI="true"
                           enableLookups="false"
                           maxThreads="500"
                           minProcessors="50"
                           maxProcessors="400"
                           acceptCount="400"
                           redirectPort="8443" URIEncoding="UTF-8" />

(4)隐藏软件版本信息

        在线上生产环境中,一般都会隐藏软件版本信息,因为部分软件存在漏洞,而这些信息是公开的,所以会做一些工作隐藏版本信息。

    我们可以看到没隐藏的情况,会显示7.0.68等信息。

wKiom1gr4p_CNsyQAABDYTzVXTQ118.png-wh_50

隐藏方法:

      

cd      $#/tomcat/lib/ #进入tomcat下的lib目录 
    unzip catalina.jar #解压catalina.jar包 
    cd org/apache/catalina/util/ #进入加压目录 
    vim ServerInfo.properties #编辑该文件,修改ServerInfo信息

修改前的值:

server.info=Apache Tomcat/8.0.28 
 





      server.number=8.0.28.0 















                server.built=Oct 7 2015 18:25:21 UTC

 

修改后的值:

server.info=Apache Tomcat/Version 
server.number=Version 
 
 
server.built=Oct 7 2015 18:25:21 UTC 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

重启tomcat后,版本信息隐藏

wKioL1gr4p_xzOzZAABQD1VEKE8123.png-wh_50



本文转自 tianya1993 51CTO博客,原文链接:http://blog.51cto.com/dreamlinux/1873419,如需转载请自行联系原作者

相关文章
|
18小时前
|
关系型数据库 Java 分布式数据库
PolarDB产品使用问题之部署到服务器上的Java应用(以jar包形式运行)无法连接,如何解决
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。
|
4天前
|
缓存 安全 算法
Java内存模型深度解析与实践应用
本文深入探讨Java内存模型(JMM)的核心原理,揭示其在并发编程中的关键作用。通过分析内存屏障、happens-before原则及线程间的通信机制,阐释了JMM如何确保跨线程操作的有序性和可见性。同时,结合实例代码,展示了在高并发场景下如何有效利用JMM进行优化,避免常见的并发问题,如数据竞争和内存泄漏。文章还讨论了JVM的垃圾回收机制,以及它对应用程序性能的影响,提供了针对性的调优建议。最后,总结了JMM的最佳实践,旨在帮助开发人员构建更高效、稳定的Java应用。
|
11天前
|
缓存 监控 Java
Java虚拟机(JVM)性能调优实战指南
在追求软件开发卓越的征途中,Java虚拟机(JVM)性能调优是一个不可或缺的环节。本文将通过具体的数据和案例,深入探讨JVM性能调优的理论基础与实践技巧,旨在为广大Java开发者提供一套系统化的性能优化方案。文章首先剖析了JVM内存管理机制的工作原理,然后通过对比分析不同垃圾收集器的适用场景及性能表现,为读者揭示了选择合适垃圾回收策略的数据支持。接下来,结合线程管理和JIT编译优化等高级话题,文章详细阐述了如何利用现代JVM提供的丰富工具进行问题诊断和性能监控。最后,通过实际案例分析,展示了性能调优过程中可能遇到的挑战及应对策略,确保读者能够将理论运用于实践,有效提升Java应用的性能。 【
54 10
|
10天前
|
Java Scala 流计算
实时计算 Flink版产品使用问题之Docker镜像中的Java路径和容器内的Java路径不一致,是什么导致的
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
16天前
|
监控 Java 数据库连接
Java面试题:如何诊断和解决Java应用的内存泄漏问题?
Java面试题:如何诊断和解决Java应用的内存泄漏问题?
19 2
|
2天前
|
供应链 安全 Java
以典型 Java 应用为例,完整的软件供应链会包含什么
以典型 Java 应用为例,完整的软件供应链会包含什么
6 0
|
2天前
|
存储 缓存 安全
深入理解Java内存模型(JMM)及其在并发编程中的应用
本文旨在探索Java内存模型(JMM)的奥秘,并揭示其在并发编程中的关键作用。我们将通过数据支撑,案例分析,以及对比研究的方法,深入剖析JMM的核心概念、原理和机制。文章将提供丰富的实例,包括同步块、volatile关键字的使用,以及线程间的通信机制,来具体展示JMM如何管理并发环境下的数据一致性和可见性问题。我们还将讨论JMM在现代多核处理器架构下面临的挑战,以及如何在编写高效且线程安全的代码时避免常见的并发陷阱。最后,文章将提出一些最佳实践,帮助开发者充分利用JMM的特性,以提升应用程序的性能和可靠性。
|
7天前
|
存储 安全 Java
深入理解Java内存模型(JMM)及其在并发编程中的应用
Java内存模型(JMM)是Java虚拟机规范中定义的一套规则,它指导着线程如何通过内存交互。JMM不仅关乎数据一致性与可见性问题,还直接影响到并发程序的正确性和性能。本文将探讨JMM的核心概念、工作原理及其在高效并发编程中的实践应用,旨在为读者提供一套完整的理论框架和实战技巧,以应对复杂并发环境下的挑战。
|
应用服务中间件 API 容器
Tomcat多层容器的设计
Tomcat的容器用来装载Servlet。那Tomcat的Servlet容器是如何设计的呢?
143 0
Tomcat多层容器的设计
|
2月前
|
安全 网络协议 应用服务中间件
tomcat 状态页 及常见配置
tomcat 状态页 及常见配置