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

本文涉及的产品
容器镜像服务 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,如需转载请自行联系原作者

相关文章
|
1天前
|
安全 Java 程序员
【Java多线程】面试常考——锁策略、synchronized的锁升级优化过程以及CAS(Compare and swap)
【Java多线程】面试常考——锁策略、synchronized的锁升级优化过程以及CAS(Compare and swap)
5 0
|
2天前
|
缓存 Java 数据库
Java并发编程中的锁优化策略
【5月更文挑战第9天】 在高负载的多线程应用中,Java并发编程的高效性至关重要。本文将探讨几种常见的锁优化技术,旨在提高Java应用程序在并发环境下的性能。我们将从基本的synchronized关键字开始,逐步深入到更高效的Lock接口实现,以及Java 6引入的java.util.concurrent包中的高级工具类。文中还会介绍读写锁(ReadWriteLock)的概念和实现原理,并通过对比分析各自的优势和适用场景,为开发者提供实用的锁优化策略。
3 0
|
2天前
|
算法 安全 Java
深入探索Java中的并发编程:CAS机制的原理与应用
总之,CAS机制是一种用于并发编程的原子操作,它通过比较内存中的值和预期值来实现多线程下的数据同步和互斥,从而提供了高效的并发控制。它在Java中被广泛应用于实现线程安全的数据结构和算法。
16 0
|
2天前
|
传感器 机器人 Java
使用Java构建机器人应用
使用Java构建机器人应用
5 0
|
2天前
|
分布式计算 负载均衡 Java
构建高可用性Java应用:介绍分布式系统设计与开发
构建高可用性Java应用:介绍分布式系统设计与开发
7 0
|
2天前
|
设计模式 算法 Java
设计模式在Java开发中的应用
设计模式在Java开发中的应用
14 0
|
18小时前
|
NoSQL Redis Docker
Mac上轻松几步搞定Docker与Redis安装:从下载安装到容器运行实测全程指南
Mac上轻松几步搞定Docker与Redis安装:从下载安装到容器运行实测全程指南
7 0
|
2天前
|
监控 Kubernetes Docker
【Docker 专栏】Docker 容器内应用的健康检查与自动恢复
【5月更文挑战第9天】本文探讨了Docker容器中应用的健康检查与自动恢复,强调其对应用稳定性和系统性能的重要性。健康检查包括进程、端口和应用特定检查,而自动恢复则涉及重启容器和重新部署。Docker原生及第三方工具(如Kubernetes)提供了相关功能。配置检查需考虑检查频率、应用特性和监控告警。案例分析展示了实际操作,未来发展趋势将趋向更智能和高效的检查恢复机制。
【Docker 专栏】Docker 容器内应用的健康检查与自动恢复
|
2天前
|
存储 安全 数据库
【Docker 专栏】Docker 容器内应用的状态持久化
【5月更文挑战第9天】本文探讨了Docker容器中应用状态持久化的重要性,包括数据保护、应用可用性和历史记录保存。主要持久化方法有数据卷、绑定挂载和外部存储服务。数据卷是推荐手段,可通过`docker volume create`命令创建并挂载。绑定挂载需注意权限和路径一致性。利用外部存储如数据库和云服务可应对复杂需求。最佳实践包括规划存储策略、定期备份和测试验证。随着技术发展,未来将有更智能的持久化解决方案。
【Docker 专栏】Docker 容器内应用的状态持久化
|
2天前
|
机器学习/深度学习 监控 Kubernetes
【Docker 专栏】Docker 容器内服务的自动扩展与缩容
【5月更文挑战第9天】本文探讨了Docker容器服务的自动扩展与缩容原理及实践,强调其在动态业务环境中的重要性。通过选择监控指标(如CPU使用率)、设定触发条件和制定扩展策略,实现资源的动态调整。方法包括云平台集成和使用Kubernetes等框架。实践中,电商平台和实时数据处理系统受益于此技术。注意点涉及监控数据准确性、扩展速度和资源分配。未来,智能算法将提升扩展缩容的效率和准确性,成为关键技术支持。
【Docker 专栏】Docker 容器内服务的自动扩展与缩容