Tomcat中定制阀门
我们说管道机制给我们带来了更好的扩展性,Tomcat中在扩展性方面具体如何体现,这便是本节讨论的内容。从上节了解到基础阀门是必须执行的,假如你需要一个额外的逻辑处理阀门,可以添加一个非基础阀门。
我的需求是对每个请求访问进行IP记录,打印到日志里面,详细操作如下:
① 自定义一个阀门PrintIPValve,只要继承ValveBase并重写invoke方法即可,ValveBase是Tomcat抽象的一个基础类,它帮我们实现了生命接口及MBean接口,使我们只需专注阀门的逻辑处理即可。需要注意的地方是一定要执行调用下一个阀门操作,即执行getNext().invoke(request,response),否则运行时将出现错误,请求到这个阀门就停止往下处理。
public classPrintIPValve extends ValveBase{
@Override
publicvoid invoke(Request request, Response response) throws IOException,
ServletException{
System.out.println(request.getRemoteAddr());
getNext().invoke(request,response);
}
}
② 配置tomcat服务器配置server.xml,这里把阀门配到Engine容器下,这样作用范围即在整个引擎,你也可以根据作用范围配置Host或Context下。
<Server port="8005"shutdown="SHUTDOWN">
……
<Engine name="Catalina"defaultHost="localhost">
<ValveclassName="org.apache.catalina.valves.PrintIPValve" />
……
</Engine>
……
</Server>
③ 将PrintIPValve类编译成.class文件,可以导出一个jar包放入tomcat安装目录lib目录下,也可直接将.class文件放入tomcat官方包catalina.jar中,这里的包名为org.apache.catalina.valves。
经过上面三个步骤配置好阀门,启动tomcat后对其进行的任何请求访问的客户端的IP都将被记录到日志中。除了自定义阀门以外,tomcat的开发者也十分友好,为我们提供了很多常用的阀门,对于这些阀门我们就无需再自定编写阀门类,要做的仅仅是在server.xml中配置即可生效。
l AccessLogValve,请求访问日志阀门,通过此阀门可以记录所有客户端的访问日志,包括远程主机IP、远程主机名、请求方法、请求协议、会话id、请求时间、处理时长、数据包大小等等。它提供了任意参数化的配置,可以通过任意组合来定制你的访问日志格式。
l JDBCAccessLogValve,同样是记录访问日志的阀门,但此类帮助将访问日志通过jdbc持久化到数据库中。
l ErrorReportValve,这是一个将错误以html格式输出的阀门。
l PersistentValve,这是对每个请求的会话实现持久化的阀门。
l RemoteAddrValve,这是一个访问控制阀门,通过配置可以决定哪些ip可以访问web应用。
l RemoteHostValve,这也是一个访问控制阀门,与RemoteAddrValve不同的是它是通过主机名限制访问者。
l RemoteIPValve,这是一个针对代理或负载均衡处理的一个阀门,一般经过代理或负载均衡转发的请求都将自己的IP添加到请求头部"X-Forwarded-For"中,此时可以通过此阀门可以获取访问者真实的IP。
l SemaphoreValve,这是一个控制容器上并发访问的阀门,可以作用在不同容器上。例如放在Context则整个上下文只允许若干线程同时访问,并发数量可以自己配置。
在实际的使用过程中,如果你需要的阀门tomcat已经帮你写好,则只需要对配置文件进行配置即可生效,如果无法满足自己需求的话则可以通过自己定义一个阀门。
喜欢研究java的同学可以交个朋友,下面是本人的微信号:
Tomcat中定制阀门的更多相关文章
- CAS 在 Tomcat 中实现单点登录
单点登录(Single Sign On , 简称 SSO )是目前比较流行的服务于企业业务整合的解决方案之一, SSO 使得在多个应用系统 中,用户只需要登录一次就可以访问所有相互信任的应用系统.CA ...
- 【IBM】使用 CAS 在 Tomcat 中实现单点登录
来源: IBM Developer http://www.ibm.com/developerworks/cn/opensource/os-cn-cas/ 张 涛 (zzhangt@cn.ibm.com ...
- 使用 CAS 在 Tomcat 中实现单点登录
单点登录(Single Sign On , 简称 SSO )是目前比较流行的服务于企业业务整合的解决方案之一, SSO 使得在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统.CAS ...
- Tomcat中Listener的使用范例(转载http://cywhoyi.iteye.com/blog/2075848)
Tomcat是非常有名的开源容器,因其开源我们可以对其做定制化的改变,而且Tomcat在其配置文件方面做了很多注释说明摘要,帮助我们更好的定制化我们所需的功能点. New Tomcat Listene ...
- 在Tomcat中采用基于表单的安全验证
.概述 (1)基于表单的验证 基于From的安全认证可以通过TomcatServer对Form表单中所提供的数据进行验证,基于表单的验证使系统开发者可以自定义用户的登陆页面和报错页面.这种验证方法 ...
- tomcat中Servlet的工作机制
在研究Servlet在tomcat中的工作机制前必须先看看Servlet规范的一些重要的相关规定,规范提供了一个Servlet接口,接口中包含的重要方法是init.service.destroy等方法 ...
- Tomcat中Pipeline
Pipeline 节选部分源码.源码版本 Tomcat8.5 处理模式 Pipeline--Valve是一种责任链模式,它和普通责任链模式有两点区别: 每个Pipeline都是有特定的Valve,而且 ...
- Tomcat中日志组件
Tomcat日志组件 AccessLog接口 public interface AccessLog { public void log(Request request, Response respon ...
- (8) tomcat中管理领域、角色及用户
srverlet Container或web应用程序本身都可以提供控制web应用程序资源的安全防护 前者称为容器管理的安全防护,或者称为应用程序管理安全防护 通过内嵌机制,tomcat提供一些安全防护 ...
随机推荐
- jquery easyui datagrid 排序列
点击排序列,将获取参数有:page=1&rows=10&sort=UserName&order=desc c#后台获取sort跟order参数 string sortColum ...
- python之with的使用
python之with使用 with工作原理 紧跟with后面的语句被求值后,返回对象的__e ...
- 正确在遍历中删除List元素
最近在写代码的时候遇到了遍历时删除List元素的问题,在此写一篇博客记录一下. 一般而言,遍历List元素有以下三种方式: 使用普通for循环遍历 使用增强型for循环遍历 使用iterator遍历 ...
- angular 路由的引用
使用angular路由 遇到的坑. 使用cmd 安装好node.js 安装成功 输入node -v 能查看版本说明安装成功 搭建angular项目输入命令 npm install -g angu ...
- 02 基础设施/Gitlab - DevOps之路
基础设施/Gitlab - DevOps之路 文章Github地址,欢迎start:https://github.com/li-keli/DevOps-WiKi 源代码管理器选用Gitlab,新版(2 ...
- 转:函数signal()
from:http://blog.sina.com.cn/s/blog_4b226b92010119l5.html 当服务器close一个连接时,若client端接着发数据.根据TCP协议的规定,会收 ...
- Node.js 常用工具util
util 是一个Node.js 核心模块,提供常用函数的集合,用于弥补核心JavaScript 的功能 过于精简的不足. util.inherits util.inherits(constructor ...
- springMVC源码分析--HandlerMethodReturnValueHandlerComposite返回值解析器集合(二)
在上一篇博客springMVC源码分析--HandlerMethodReturnValueHandler返回值解析器(一)我们介绍了返回值解析器HandlerMethodReturnValueHand ...
- 到底什么是集群&分布式
对于楼主这样工作一年的菜鸟,偶尔会看到一些文章标题带有"分布式""集群"关键字,然后就懵逼了.最近对这些概念进行了一定的了解,整理了一下思路,在这里分享给各位猿 ...
- 20160218.CCPP体系详解(0028天)
程序片段(01):加法.c 内容概要:字符串计算表达式 #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <st ...