Linux安装版Tomcat内存优化指南 (linux安装版tomcat内存设置)

当我们在使用Tomcat时,经常会出现内存耗尽的情况,导致应用程序崩溃甚至服务器崩溃。因此,内存优化是非常重要的一项工作。接下来,我们将为您介绍如何在Linux安装版Tomcat上进行内存优化指南。

之一步: 调整JVM内存参数

JVM是Tomcat的虚拟机。因此,调整JVM的内存参数是优化Tomcat内存的之一步。

方法如下:

1.编辑$TOMCAT_HOME/bin/catalina.sh文件,找到JAVA_OPTS参数:

JAVA_OPTS=”-server -Xms1024m -Xmx1024m -XX:PermSize=64m -XX:MaxPermSize=128m”

2.增加-XX:+UseG1GC参数

JAVA_OPTS=” -server -Xms1024m -Xmx1024m -XX:PermSize=64m -XX:MaxPermSize=128m -XX:+UseG1GC”

3.测试JVM参数

在catalina.sh文件中写入以下命令:

echo $JAVA_OPTS

然后更改Tomcat的JAVA_OPTS变量,您将看到结果如下:

-server -Xms1024m -Xmx1024m -XX:PermSize=64m -XX:MaxPermSize=128m -XX:+UseG1GC

第二步: 减少应用程序和Tomcat的内存使用

在以下情况下,Tomcat内存的使用不是100%由JVM内存控制。还需要优化应用程序代码和Tomcat容器本身。

1. 减小P的BUFFER大小

打开$TOMCAT_HOME/conf/web.xml 文件

找到标签内的javax.servlet.jsp.jstl.fmt.localizationContext

修改为以下内容:

  javax.servlet.jsp.jstl.fmt.localizationContext

  messages

  buffer

  8192

  isELIgnored

  false

增加标签中的buffer和8192,从而减小P的BUFFER大小。

2. 增加压缩静态资源压缩

默认情况下,Tomcat不支持压缩静态资源,可能会浪费大量的内存。为了将内存使用减少到更低限度,您可以使用下面的方法开启压缩。

打开$TOMCAT_HOME/conf/server.xml 文件。

找到以下内容:

connectionTimeout=”20230″

redirectPort=”8443″ />

你需要将其修改为如下所示:

               connectionTimeout=”20230″

               redirectPort=”8443″

               compression=”on”

               compressionMinSize=”2023″

               noCompressionUserAgents=”gozilla, traviata”

               compressableMimeType=”text/html,text/xml,text/javascript,text/css”/>

3. 在应用程序中减少对象的大小

在写应用程序的时候,我们尽量让对象都变得更小。

例如:

String str = “Hello World”;

List list = new ArrayList();

这里,我们可以使用:

String str = “Hello World”;

List list = new ArrayList(5);

减少内存使用量。这样,我们能够节省应用程序和Tomcat的内存使用。

相关问题拓展阅读:

Tomcat配置实践

要部署使用tomcat,则必须了解tomcat的目录结构以及各目录的作用。这里以tomcat7为例,进入tomcat安装目录下:

前端请求被tomcat直接接收或者由前端的代理,通过HTTP,或者AJP代理给Tomcat,此时请求被tomcat中的connector接收,不同的connector和Engine被service组件关联起来,在一个Engine中定义了许多的虚拟主机,由Host容器定义,每一个Host容器代表一个主机,在各自的Host中,又可以定义多个Context,用此来定义一个虚拟主机中的多个独立的应用程序。

Tomcat Server的结构图如下:

看上去很复杂。其实,大部分都是注释。下面是一个简图说明了各组件之间的关系!

上面列出的比较常用的组件元素,server.xml文件中可定义的元素非常多,包括Server, Service, Connector, Engine, Cluster, Host, Alias, Context, Realm, Valve, Manager, Listener, Resources, Resource, ResourceEnvRef, ResourceLink, WatchedResource, GlobalNameingResources, Store, Transaction, Channel, Membership, Transport, Member, ClusterListener等等。

由以上配置不难看出存在的一个问题。如果我们想要对其中一个应用程序的配置做一些修改,那么就必须重新启动tomcat,那样势必就会影响到另外两个应用程序的正常服务。因此以上配置是不适合线上使用的,

因此需要将其配置为多实例,每个实例只跑一个独立的应用程序,那样我们应用程序之间就不会在互相受到影响。

但是我们将面临这样一竖雹个问题,80端口只能被一个HTTP/1.1 Connector监听,而三个tomcat实例则至少需要3个HTTP/1.1 Connector,这样我们就

需要一个前端代理做分发处理,接收HTTP 80端口的请求,按域名通过每个tomcat实例的AJP/1.3 Connector传递请求

。而前端的代理选择apache,基于这样的思路,我们还可以做到tomcat的负载均衡,而且

apache会将接收的HTTP超文本传输报文重新封装成二进制格式通过AJP/1.3 协议传递给后端的tomcat处理

,在效率上余指帆也是有明显的提升。

这会让Tomcat启动一个server实例(即一个JVM),它监听在8005端口以接收shutdown命令。各Server的定义不能使用同一个端口,这意味着如果在同一个物理机上启动了多个Server实例,必须配置它们使用不同的端口。这个端口的定义用于为管理员提供一个关闭此实例的便捷途径,因此,管理员可以直接telnet至此端口使用SHUTDOWN命令关闭此实例。不过,基于安全角度的考虑,这通常不允许远程进行。

该元素代表整个容器,是Tomcat实例的顶层元素。由org.apache.catalina.Server接口来定义。它包含一个或多个元素。并且它不能做为任何元素的子元素。

Service主要用于关联一个引擎和与此引擎相关的连接器,每个连接器通过一个特定的端口和协议接收入站请求交将其转发至关联的引擎进行处理。因此,Service要包含一个引擎、一个或多个连接器。

该元素由org.apache.catalina.Service接口定义,它包含一个元素,以及一个或多个,这些Connector元素共享用同一个Engine元素。

Engine是Servlet处理器的一个实逗备例,即servlet引擎,默认为定义在server.xml中的Catalina。

每个Service元素只能有一个Engine元素。元素处理在同一个中所有元素接收到的客户请求。由org.apahce.catalina.Engine接口定义。

位于Engine容器中用于接收请求并进行相应处理的主机或虚拟主机。

它由Host接口定义。一个Engine元素可以包含多个元素。每个的元素定义了一个虚拟主机。它包含了一个或多个Web应用。

Context在某些意义上类似于apache中的路径别名,一个Context定义用于标识tomcat实例中的一个Web应用程序。

它由Context接口定义。是使用最频繁的元素。每个元素代表了运行在虚拟主机上的单个Web应用。一个可以包含多个元素。每个web应用有唯一的一个相对应的Context代表web应用自身。servlet容器为之一个web应用创建一个 ServletContext对象。

由Connector接口定义。元素代表与客户程序实际交互的组件,它负责接收客户请求,以及向客户返回响应结果。

进入Tomcat的请求可以根据Tomcat的工作模式分为如下两类:

Tomcat应该考虑工作情形并为相应情形下的请求分别定义好需要的连接器才能正确接收来自于客户端的请求。一个引擎可以有一个或多个连接器,以适应多种请求方式。

定义连接器可以使用多种属性,有些属性也只适用于某特定的连接器类型。一般说来,常见于server.xml中的连接器类型通常有4种:

Connector元素共用属性:

HttpConnector元素的属性:

AJP Connector的属性:

即一个service配置多个端口,项目可以通过多个端口访问。

修改tomcat-home\conf下的server.xml,在Service下配置多个即可。

在这个应用里,可以用8080端口号访问服务,也可以用8099端口号来访问服务; 服务放置的路径由host决定,上例中服务放在webapps下。

即配置多个service,每个service可以配置多个端口。修改tomcat-home\conf下的server.xml,添加多个Service即可。

注意:Service name、Engine name、appBase,端口号别忘了修改,以免重复。

以上三个service,发布的路径不同,项目分别发布在webapps、webapps1、webapps2下,访问不同的项目的方法:

在$CATALINA_HOME/conf/server.xml配置文件中的Connetctor节点,和连接数相关的参数配置和优化。

Tomcat使用线程来处理接收的每个请求。这个值表示Tomcat可创建的更大的线程数。默认值200。

可以根据机器的时期性能和内存大小调整,一般可以在

。更大可以在800左右。

指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理。默认值10。

Tomcat初始化时创建的线程数。默认值4。

一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程。默认值50。

是否反查域名,默认值为true。

为了提高处理能力,应设置为false

网络连接超时,默认值20230,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。

通常可设置为30000毫秒

保持请求数量,默认值100。

输入流缓冲大小,默认值2023 bytes。

压缩传输,取值on/off/force,默认值off。

其中和更大连接数相关的参数为maxThreads和acceptCount。

如果要加大并发连接数,应同时加大这两个参数

web server允许的更大连接数还受制于操作系统的内核参数设置

,通常Windows是2023个左右,Linux是1000个左右。

配置示例:

Tomcat默认可以使用的内存为128MB,Windows下,在文件{tomcat_home}/bin/catalina.bat,Unix下,在文件$CATALINA_HOME/bin/catalina.sh的前面,增加如下设置:

一般说来,你应该使用物理内存的 80% 作为堆大小。如果本机上有Apache服务器,可以先折算Apache需要的内存,然后修改堆大小。

建议设置为70%;建议设置等于,这样可以减少频繁分配堆而降低性能。

在$CATALINA_HOME/conf/web.xml中,把listings参数设置成false即可,如下:

参考

linux怎么配置tomcat

方法/步骤 首先是到官网下载tomcat,选游租择你需要的族野版本下载安装即可,相信能搭建服务的对安装肯定很熟了,不熟悉的同学自己百度或者google吧,网上有很多。我主要讲一神穗兆下配置过程。 tomcat安装好后首先要对它进行配置文件的修改。

关于linux安装版tomcat内存设置的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


数据运维技术 » Linux安装版Tomcat内存优化指南 (linux安装版tomcat内存设置)