生产环境中tomcat的配置

生产环境中要以daemon方式运行tomcat

通常在开发环境中,我们使用$CATALINA_HOME/bin/startup.sh来启动tomcat, 使用$CATALINA_HOME/bin/shutdown.sh来关闭tomcat。 而在生产环境中,我们要配置tomcat使其以daemon方式运行,这是因为:

  • 以daemon运行不受终端影响,不会因为退出终端而停止运行
  • 可以让tomcat以普通用户身份运行,可以让tomcat随linux启动而启动

如何将tomcat配置成守护进程

将tomcat配置成守护进程需要借助apache-commons-daemon项目的jsvc工具, 该工具通常包含在tomcat包中(bin/commons-daemon-native.tar.gz)

1. 配置JAVA_HOME, CATALINA_HOME两个环境变量

export JAVA_HOME=/opt/jdk
export CATALINA_HOME=/opt/tomcat

2. 编译安装jsvc

cd $CATALINA_HOME/bin
tar -xvf commons-daemon-native.tar.gz
cd commons-daemon-1.0.x-native-src/unix
./configure
make
cp jsvc ../..

3. 创建运行tomcat的普通用户tomcat

useradd -s /sbin/nologin tomcat

4. 修改$CATALINA_HOME的所属用户户和用户组,使tomcat可以用tomcat这个普通用户运行

chown -R $CATALINA_HOME tomcat
chgrp -R $CATALINA_HOME tomcat

5. 修改制作tomcat启动脚本

$CATALINA_HOME/bin/daemon.sh是tomcat官方为我们提供的启动脚本,我们只需要修改即可。

将该脚本复制到/etc/init.d中

cp $CATALINA_HOME/bin/daemon.sh  /etc/init.d/tomcat

有注释位置加入chkconfig配置,使得该脚本可以被chkconfig识别,从而配置成开机启动

#chkconfig: 2345 85 15

由于service命令会去除系统环境变量,因此在脚本开始位置加入以下内容:

JAVA_HOME=/opt/jdk
CATALINA_HOME=/opt/tomcat
TOMCAT_USER=tomcat

6. 设置tomcat开机启动

chkconfig tomcat on

经过上面的配置,tomcat就能够以守护进程方式运行了,而且会随开机启动而启动。

7. 使用service方式启动关闭tomcat

service tomcat start
service tomcat stop

tomcat安全配置

1. 版本安全

升级当前tomcat版本为最新稳定版本。

在升级版本中,需要注意两点:

尽量避免跨大版本的升级

将当前老版本的server.xml , catalina.sh, web.xml和tomcat-users.xml进行备份,然后部署完新的tomcat后,将这些配置文件覆盖过去。

2. 隐藏版本信息

当tomcat出现404或其它错误时,就会显示当前版本信息,为避免针对某一版本的攻击,我们应该将其隐藏或伪装

版本信息的显示是由一个jar包控制的,该jar包存放在tomcat安装目录下的lib目录下,名称为catalina.jar.

通过jar xf命令解压这个jar包会得到两个目录META-INF和org, 通过修改org/apache/catalina/util/ServerInfo.properties文件中的serverinfo字段来实现更改tomcat版本信息:

[[email protected] ~]# cat org/apache/catalina/util/SererInfo.properties | grep -v ‘^$|#‘
server.info=Apache Tomcat/7.0.53
server.number=7.0.53.0
serer.built=Mar 25 2014 06:20:16

当然还有另外一种方法来隐藏或伪装版本信息,这两种方法本质是一样的:

[[email protected] ~]# cd /usr/local/apache-tomcat-7.0.53/lib
[[email protected] lib]# mkdir -p org/apache/catalina/util
[[email protected] lib]# cd org/apache/catalina/util
[[email protected] util]# vim ServerInfo.properties
server.info=nolinux        # 如果想修改成其它版本号,把这个地方的值改成其它值就行了

修改完成之后,重启tomcat即可看到效果!

tomcat的配置优化

1. 优化web.xml

servlet与其它适用于整个Web应用程序设置的配置文件,必须符合servlet规范的标准格式。通过它可以配置你web应用的相关选项,tomcat在启动的时候会读取这个文件,完成你开发的系统的一些初始化操作。

它可以做如下事情:

  • 提供基于servlet的相关配置
  • 增加监听器,监控session或在tomcat启动时,加载一些你希望加载的资源。比如创建数据库连接池等
  • 设置session过期时间,tomcat默认是30分钟
  • 更改应用的默认页面,通常为index.html/index.jsp等
  • 增加过滤器, 做一些你希望的过滤操作,比如敏感词汇的过滤
  • 增加一些jstl(标准标签库)的定义,方便在jsp中直接include进来
  • struts, spring或hibernate的一些配置等

由于在生产环境中,tomcat不会直接对公网提供服务,前端肯定有apache或nginx,因此,默认主页或自定义错误页,我们都在前端的apache或nginx中完成;另外也有可能是由程序员在项目内的WEB-INF/web.xml中去做定义。

在tomcat新版本中,默认已经禁止列目录功能。

下面是几种觉的功能,在web.xml中的表现形式:

站点默认主页:

自定义错误页:

定义会话超时时间:

禁止列目录:

2. tomcat-user.xml的优化

该文件中包含用户名,角色及密码。 负责提供webapps下manager项目的登录认证管理。

在生产环境中,我们需要将该文件全部注释。

3. 优化server.xml

maxThreads连接数限制:

maxThreads是tomcat所能接受的最大连接数。 一般设置不要超过8000, 如果你的网站访问量非常大可使用多个tomcat实例的方法,即在一个服务器上启动多个tomcat,然后做负载均衡。

tomcat和php不同,php可以按照cpu和内存的情况去配置连接数,所以上万很正常。 但java还需要注意jvm的参数配置。如果不注意就会因为jvm参数过小而崩溃。

多个虚拟主机:

强烈建议不要使用tomcat的虚拟主机功能,推荐一个tomcat实例启动一个站点。即,可以启动多个tomcat,而不是一个tomcat里包含多个虚拟主机。 因为tomcat是多线程,共享内存,任何一个虚拟主机中的应用崩溃,都会影响到所有的应用程序。

压缩传输:

tomcat也支持gzip压缩功能。 可以在server.xml配置文件中的Connector节点中配置如下参数,来实现对指定资源类型进行压缩。

compression="on"             # 打开压缩功能
compressionMinSize="50"      # 启用压缩的输出内容大小,默认为2KB
noCompressionUserAgents="gozilla, traviata"      # 对于以下的浏览器,不启用压缩
compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain" # 哪些资源类型需要压缩

要注意的是,对于文本信息比如txt, html, css,javascript进行压缩,效果非常好。而对文件,图片,视频不要压缩。

4. 管理AJP端口:

AJP是为tomcat与HTTP服务器之间通信而定制的协议,能提供较高的通信速度和效率。如果前端是apache的话,会使用到AJP这个连接器,如果是nginx,就用不上了,因此需要注销掉:

<!--
    <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
-->

5. 更改关闭tomcat实例的指令

server.xml中定义了可以直接关闭tomcat实例的管理端口。 我们通过 telnet连接上该端口之后,输入shutdown即可关闭。值得注意的是,虽然实例关闭了,但是进程还是存在的。由于默认的端口和指令都很简单,默认端口是8005, 指令为SHUTDOWN. 因此我们要改得复杂一点(当然,新版本的tomcat管理端口监听在127.0.0.1):

<Server port="8005" shutdown="9SDKJ29jksjf23sjf0LSDF92JKS9DKkjsd">

6. 更改tomcat服务监听端口:

<Connector port="8080" address="172.16.100.1" />

7.关闭war自动部署:

<Host name="localhost"  appBase=""
      unpackWARs="false" autoDeploy="false">

8. 禁用tomcat管理页面:

删除webapps目录下的所有文件,还涉及到管理页面的2个配置文件host-manager.xml和manager.xml也要删除,这两个文件在tomcat安装 目录下的conf/Catalina/localhost目录下。

9. 使用普通用户启动tomcat

在启动之前需要将tomcat安装目录下所有文件的属主和属组都设置为指定的用户。

tomcat生产服务器性能优化

1. tomcat内存优化

tomcat内存优化主要是对tomcat启动参数优化,我们可以在tomcat启动脚本catalina.sh中设置JAVA——OPTS参数。

JAVA_OPTS=‘-Xms1024m -Xmx2048m -XX:PermSize=256M -XX:MaxNewSize=256m -XX:MaxPermSize=256m‘

参数说明:

-server  启用jdk 的 server 版;
-Xms    java虚拟机初始化时的最小内存;
-Xmx   java虚拟机可使用的最大内存;
-XX:PermSize    内存永久保留区域
-XX:MaxPermSize   内存最大永久保留区域

-Xmx 默认为物理内存的1/4, 实际建议不大于4GB;一般建议设置-Xms = -Xmx

-server   一定要作为第一个参数,在多个cpu时性能 佳

-Xms    初始heap大小,使用的最小内存,cpu性能 高时可以设置的大一些

时间: 2024-10-11 17:52:45

生产环境中tomcat的配置的相关文章

生产环境中使用脚本实现tomcat start|status|stop|restart

一.在实际生产环境中tomcat启动是在bin目录下采用自带脚本startup.sh启动:使用shutdown.sh关闭.如下图: 再如果对于新手来讲在不知道路径情况下重启是一件头痛的事情(注意没有reload,所以重启只能shutdown.sh在startup.sh):而且这里还有一个坑等着: 什么坑呢?   如图: tomcat服务是启动成功了的.那么我想停止服务用shutdown.sh,会出现什么呢? 进程还在而且成为了僵尸进程,万恶啊?居然关不了,终极方法kill -9 进程号.试试?

生产环境中jenkins主机ansible配置如下

生产环境中jenkins主机ansible配置如下: [defaults] hostfile = ./hosts library = /usr/share/ansible remote_tmp = $HOME/.ansible/tmp pattern = * transport = smart remote_port = 22 log_path = /home/jenkins/ansible/ansible.log pipelining = True module_lang = C gather

生产环境中的PHP WEB 简单架构

使用三台虚拟机器, Ubuntu1(nginx) 192.168.226.128 Ubuntu2(php-fpm+memcached)192.168.226.132 CentOS(MySQL)192.169.226.130 PHP 框架使用CakePHP,这个是很常用的MVC 框架,基于事件的分发模型 当然需要注意的是框架代码要部署在php-fpm机器上,需要在nginx 中配置的配置如下 余下的内容: 1. CakePHP 框架代码 2. PHP 内核 3. Nginx内核 4. 数据库设计模

[virtualenv]生产环境中使用virtualenv

virtualenv 对于python开发和部署都是好工具,可以隔离多个python版本和第三方库的版本,这里作者总结了几个常用python服务怎么样结合virtual部署 原文链接 Python 中我最喜欢的东西之一就是可以使用 virtualenv 去创建隔离的环境.非常简单的就可以在不同的项目中部署不同的python类库. 有一个比较棘手的问题就是在生产环境中使用virtualenv 部署几个不同的服务有一些配置上的不同. 于是我就从我的项目中收集了几种不同的服务的不同配置方式. 可以肯定

生产环境中CentOS7部署NET Core应用程序

NET Core应用程序部署至生产环境中(CentOS7) 阅读目录 环境说明 准备你的ASP.NET Core应用程序 安装CentOS7 安装.NET Core SDK for CentOS7. 部署ASP.NET Core应用程序 配置Nginx 配置守护服务(Supervisor) 这段时间在使用Rabbit RPC重构公司的一套系统(微信相关),而最近相关检验(逻辑测试.压力测试)已经完成,接近部署至线上生产环境从而捣鼓了ASP.NET Core应用程序在CentOS上的部署方案,今天

理解Docker(6):若干企业生产环境中的容器网络方案

本系列文章将介绍 Docker的相关知识: (1)Docker 安装及基本用法 (2)Docker 镜像 (3)Docker 容器的隔离性 - 使用 Linux namespace 隔离容器的运行环境 (4)Docker 容器的隔离性 - 使用 cgroups 限制容器使用的资源 (5)Docker 网络 (6)若干企业生产环境中的容器网络方案 Docker 在早期只有单机上的网络解决方案,在 1.19 版本引入了原生的 overlay 网络解决方案,但是它的性能损耗较大,可能无法适应一些生产环

LINUX环境中tomcat启动错误:The servlets named X and Y are both mapped to the url-pattern [/Z] which is not permitted

最近有一个问题困扰了我3天,我在windows部署项目无误后,准备将项目发布到阿里云linux服务器上,发现启动报错了:LINUX环境中tomcat启动错误:The servlets named X and Y are both mapped to the url-pattern [/Z] which is not permitted,首先想到的是肯定部署代码或者项目配置文件的事,怀疑有可能是jar包出错了,果不其然,在项目的WebContent\WEB-INF\lib发现了servlet-ap

Confluence 6 从生产环境中恢复一个测试实例

请参考 Restoring a Test Instance from Production 页面中的内容获得更多完整的说明. 很多 Confluence 的管理员将会使用生产实例运行完整数据和服务的 Confluence 服务器,同时还会设置一个测试实例来测试升级等.在这种情况下,你的 Confluence 可以回运行 2 个不同的版本,而且也是非常常见的.这个文档将会知道你如何拷贝生产环境中的数据到一个测试实例中,同时测试环境的版本和生产环境中的版本还有可能是不同的. 在开始这个操作指南之前,

明白生产环境中的jvm参数

明白生产环境中的jvm参数 写代码的时候,程序写完了,发到线上去运行,跑一段时间后,程序变慢了,cpu负载高了--一堆问题出来了,所以了解一下生产环境的机器上的jvm配置是有必要的.比如说: JDK版本是多少?采用何种垃圾回收器? 程序启动的时候默认分配堆内存空间是多少?随着程序的运行,程序最多能使用多大的内存空间? 程序中使用了多少个线程?目前的java进程又处于何种状态? 了解了这些,会对程序的运行有一个更好的了解.本文结合生产实践,记录一下我常用的一些操作. 注意:如果没有特殊说明,下面所