Tomcat学习

1. 运行项目

  • 将java项目打包为war或者war所对应的文件夹,放置于tomcat的webapps目录下。
  • 其实tomcat运行时会解压war到项目中并运行class文件,延伸开来,为啥不能用jar包,因为jar可能可以表示项目但也能表示依赖,tomcat无法识别。
  • 源码方式运行的时候控制台输出乱码,可以修改vm options:-Duser.language=

2. tomcat的四大容器

engine ,host虚拟主机,context应用,wrapper类型分组
结构:

engine:
	list<host>
	pipeline: 管道
		list<valve> 阀门

host:
	list<context>
	pipeline:
		list<valve>

context:
	list<wrapper>
	pipeline:
		list<valve>
	
wrapper:
	list<servlet>
	pipeline:
		list<valve>

3. 请求的流程

当请求经过时的顺序:
请求-》engine-》engine的阀门-》host-》host的阀门-》context-》context的阀门-》wrapper-》wrapper的阀门
阀门valve是容器之间的桥梁,可以传输数据
请求的doGet方法是wrapper里面的最后一个阀门在操作(standardWrapperValve),期间会生成过滤器链filterChain,最终tomcat执行service方法,httpServlet规范会根据请求类型来调用相应的doGet方法
下图为tomcat执行流程示意图:
tomcat执行流程
操作系统实现tcp传输协议,提供socket接口供外部调用,tomcat等使用网络传输就会用到socket,在java中new socket()其实是创建了一个tcp连接。
tomcat接受到socket请求获取数据,根据应用层协议(http)解析为request请求,其中上图中的Endpoint代表io模型,常用的为BIO和NIO,例如配置HTTP1.1的时候tomcat7默认使用BIO

4.Tomcat中长连接的底层源码原理实现

当客户端和服务端建立连接以后,生成一个socket连接,当客户端发送数据,数据会存在于服务端的操作系统的buffer缓冲区中,会有填满的一刻,Tomcat会不停从操作系统的缓冲区取(Tomcat自身也有一个缓冲区来读取)。
在这里插入图片描述
对于BIO,一个请求一个线程。以下为长连接的伪代码:
在这里插入图片描述
先默认http请求的keepalive为true,然后进入解析请求头请求体,赋值真实的keepalive的,封装request和response交给容器servlet,根据keepalive判断是否继续该长连接。代码里有一个比例,当长连接达到Tomcat默认的75%以后,新来的连接将不会成为长连接
有一个属性maxKeepaliveRequest:默认100,一个socket请求最多拥有100个http请求

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值