创建用户

useradd -u 501 tomcat
passwd tomcat

tomcat安装

tar zxf apache-tomcat-8.5.5.tar.gz -C /usr/local/
cd /usr/local/; ln -s apache-tomcat-8.5.5 tomcat
chown -R tomcat.tomcat *tomcat*

应用程序配置

mkdir -p /data/webapps
cd /data/
chown -R tomcat.tomcat webapps
su tomcat #将应用程序放置在/data/webapps/目录下。建立相应的目录如团购wmw_tuan,静态化wmw_static,并修改server.xml,对应好目录即可 ###server.xml###
<Host name="localhost" appBase="webapps"
unpackWARS="true" autoDeploy="true"> <Context path="" docBase="/data/webapps/wmw_static" />
...

启动tomcat

 /usr/local/tomcat/bin/startup.sh 

tomcat重启问题

/usr/local/tomcat/bin/shutdown.sh 这个命令是关闭tomcat
重启有2个问题需要注意:
  1、建议生产环境中,每次重启之前把这两个文件夹清空,不然可能会因为缓存的问题造成一些奇怪的事件
  2、有时候会发现执行shutdown.sh后,tomcat并没有完全关闭,所以我们可以做脚本kill进程

去除其他用户对tomcat启停脚本的执行权限

chmod 744 -R tomcat/bin/*

telnet端口保护

说明:
修改默认的8005管理端口为不易猜测的端口(大于1024)
修改SHUTDOWN指令为其他字符串 标准配置:
<Server port="8527" shutdown="dangerous"> 备注:
以上配置项的配置内容只是建议配置

ajp端口保护

说明:
修改默认的ajp 8009端口为不易冲突的大于1024端口
通过iptables规则限制ajp端口访问的权限仅为线上机器 标准配置:
<Connector port="8528" protocol="AJP/1.3"/> 备注:
以上配置项内容仅为建议配置,请按照实际情况进行合理配置,但要求端口在8000~8999之间
保护此端口的目的在于防止线下的测试流量被mod_jk转发至线上tomcat服务器

禁用管理端

说明:
删除默认的{tomcat安装目录}/conf/tomcat-user.xml文件,重启tomcat后将会自动生成新的文件
删除{tomcat安装目录}/webapps下默认所有的目录和文件
将tomcat应用根目录配置为tomcat安装目录以外的目录 标准配置:
<Context path="" docBase="/data/webapps/bagtree" debug="0" reloadable="false" crossContext="true" /> 备注:
对于前段web模块,tomcat管理端属于tomcat的高危安全隐患,一旦被攻破,黑客通过上传web shell的方式将会直接取
得服务器的控制权,后果极其严重

降权启动

说明:
tomcat启动用户权限必须为非root权限,尽量降低tomcat启动用户的目录访问权限
如需要直接对外使用80端口,可通过普通帐号启动后,配置iptables规则进行转发 备注:
避免一旦tomcat服务被入侵,黑客直接获取高级用户权限危害整个server的安全

文件访问列表控制

说明:
conf/web.xml文件中default部分listings的配置必须为false 标准配置:
<init-param>
<param-name>listings</param-name>
<param-value>false</param-value>
</init-param> 备注:
false为不列出目录文件,true为允许列出,默认为false

版本信息隐藏

说明:
修改conf/web.xml,重定向403、404以及500等错误到指定的错误页面
也可以通过应用程序目录下的WEB-INF/web.xml进行错误页面的重定向 标准配置:
<error-page>
<error-code>403</error-code>
<location>/forbidden.jsp</location>
</error-page> <error-page>
<error-code>404</error-code>
<location>/notfound.jsp</location>
</error-page> <error-page>
<error-code>500</error-code>
<location>/serverbusy.jsp</location>
</error-page> 备注:
在配置中对一些常见错误进行重定向,避免当出现错误时tomcat默认显示的错误页面暴露服务器和版本信息
必须确保程序跟目录下的错误页面已经存在

Server header重写

说明:
在HTTP Connector配置中加入server的配置 标准配置:
server="webserver" 备注:
当tomcat HTTP端口直接提供web服务时此配置生效,加入此配置,将会替换http响应Server header部分默认配置,默认是Apache-Coyote/1.1

访问控制

说明:
通过配置,限定访问的ip源 标准配置:
<Context path="" docBase="/home/work/tomcat" debug="0" reloadable="false" crossContext="true">
<Valve className="org.apache.catalina.valves.RemoteAddrValue" allow="61.148.18.138,61.135.165.*" deny="*.*.*.*" />
</Context> 备注:
ip的白名单,拒绝非白名单ip的访问,此配置主要是针对高保密级别的系统

起停脚本权限回收

说明:
取出其他用户对tomcat的bin目录下shutdown.sh、startup.sh、catalina.sh的可执行权限 标准配置:
chmod -R 744 tomcat/bin/* 备注:
防止其他用户有起停线上tomcat的权限

访问日志格式规范

说明:
开启tomcat默认访问日志中的Referer和User-Agent记录 标准配置:
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="localhost_access_log" suffix=".txt"
pattern="%h %l %u %t %r %s %b %{Referer}i %{User-Agent}i %D" resolveHosts="false" /> 备注:
开启Referer和User-Agent是为了一旦出现安全问题能够更好的根据日志进行问题排查

tomcat安装规范的更多相关文章

  1. Tomcat安全管理规范

    s 前言 随着公司内部使用Tomcat作为web应用服务器的规模越来越大,为保证Tomcat的配置安全,防止信息泄露,恶性攻击以及配置的安全规范,特制定此Tomcat安全配置规范. 定位:仅对tomc ...

  2. tomcat安装配置规范

    tomcat用户设置 1 2 [root@host-1 ~]# useradd -u 501 tomcat [root@host-1 ~]# passwd tomcat   安装JDK 1 2 3 4 ...

  3. Tomcat 安装与配置规范

    Tomcat 安装 演示版本:8.5.32 安装版 JDK推荐版本:jdk1.8 下载地址:https://tomcat.apache.org/download-80.cgi 安装教程 注意:tomc ...

  4. JavaWeb——tomcat安装及目录介绍

    一.web web可以说,就是一套 请求->处理->响应 的流程.客户端使用浏览器(IE.FireFox等),通过网络(Network)连接到服务器上,使用HTTP协议发起请求(Reque ...

  5. Tomcat安装、启动和配置

    Tomcat服务器介绍 Tomcat是一个免费开发源代码的web应用服务器,具有与IIS.Apache等web服务器一样处理html页面的功能,另外它还是一个Servlet和JSP容器,独立的serv ...

  6. tomcat安装与配置文件

    一 安装tomcat 1.系统必须已安装配置JDK 安装说明参考地址:http://www.cnblogs.com/Yuanbangchen/p/5945491.html   2.将apache-to ...

  7. Tomcat学习之二:tomcat安装、配置及目录文件说明

    我们看到tomcat目录/bin文件夹里有个tomcat6w.exe,顾名思义就是tomcat以window方式显示控制台.第1次点击打开它时候,可能会提示:tomcat指定的服务未安装,此时我们可以 ...

  8. Tomcat安装部署和安全加固优化以及反向代理应用

    1.Tomcat介绍 Tomcat是Apache软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache.Sun和其他一些公司及个人共同 ...

  9. Tomcat安装及配置详解

    Tomcat安装及配置详解   一,Tomcat简介 Tomcat 服务器是一个免费的开放源代码的Web 应用服务器,Tomcat是Apache 软件基金会(Apache Software Found ...

随机推荐

  1. jsp电子商务 购物车实现之一 设计篇

    购物车的功能实现. 查询的资料,找到三种方法: 1.用cookie实现购物车: 2.用session实现购物车: 3.用cookie和数据库(购物车信息持久化)实现购物车: ============= ...

  2. cookie中的path与domain属性详解

    1.domain表示的是cookie所在的域,默认为请求的地址,如网址为www.jb51.net/test/test.aspx,那么domain默认为www.jb51.net.而跨域访问,如域A为t1 ...

  3. github导入springboot maven项目

    1.在GitHub里force喜欢的项目,获取GitHub项目地址,eclipse---import---project from git---clone uri---next---finish,项目 ...

  4. c++编辑器下载地址

    https://msdn.itellyou.cn/ 输入上述地址选中下图所示的按钮:

  5. (转载)--SG函数和SG定理【详解】

    在介绍SG函数和SG定理之前我们先介绍介绍必胜点与必败点吧. 必胜点和必败点的概念:        P点:必败点,换而言之,就是谁处于此位置,则在双方操作正确的情况下必败.        N点:必胜点 ...

  6. mysql 基本操作练习

    ), sex ), age )); , '北京'); , '上海'); , '广州'); , '北京'); , '北京'); , '上海'); , '北京'); #(). 写出sql语句,查询所有年龄 ...

  7. 【bzoj4310/hdu5030-跳蚤】后缀数组

    我真的是..调了一百年.. 傻逼的人生.. 而且这题好像可以用sam做哎!我Y出了一个奇怪的办法.. 好吧sam是不能做这题的.搞错了. 说说后缀数组好了.. 搞后缀数组 然后我们要二分一个子串,判断 ...

  8. [BZOJ3698]XWW的难题解题报告|上下界网络流|有源汇最大流

    XWW是个影响力很大的人,他有很多的追随者.这些追随者都想要加入XWW教成为XWW的教徒.但是这并不容易,需要通过XWW的考核.XWW给你出了这么一个难题:XWW给你一个N*N的正实数矩阵A,满足XW ...

  9. 2017年上海金马五校程序设计竞赛:Problem B : Sailing (广搜)

    Description Handoku is sailing on a lake at the North Pole. The lake can be considered as a two-dime ...

  10. bzoj 2749 杂题

    我们可以发现,phi(x)与x相比,相当于x的每个质因子-1后再分解质因数,添加到现有的质因子中,比如质因子13相当于将13变成12,然后分解成2*2*3,再将2的质数+2,3的指数+1,除了质因子2 ...