热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Tomcat学习笔记(1)源码环境搭建

书籍《Tomcat内核设计剖析》《howtomcatworks?》文章目录1.基础知识2.环境搭建3.Servlet规范1.基础知识Java的网络通信底层是基于套接

书籍《Tomcat内核设计剖析》《how tomcat works?》


文章目录

  • 1. 基础知识
  • 2. 环境搭建
  • 3. Servlet规范


1. 基础知识

Java的网络通信底层是基于套接字的,其理论依据是应用层与TCP/IP协议族通信的中间抽象层,它是一组接口。
应用层通过调用这些接口发送和接收数据。一般这种抽象层由操作系统提供或者由JVM自己实现。使用套接字通信可以简单地实现应用程序在网络上的通信。一台机器上的应用向套接字中写入信息,另外一台相连的机器能读取到。TCP/IP协议族中有两种套接字类型,分别是流套接字和数据报套接字,分别对应TCP协议和UDP协议。一个TCP/IP套接字由一个互联网地址、一个协议及一个端口号唯一确定。即Socket

感兴趣的可以去了解下Java的Socket编程,以及它对应的延申出来的一些性能优化模型。
下面是个简单的例子:

Socket socket = new Socket("127.0.0.1", "8080"); //建立连接
OutputStream os = socket.getOutputStream(); //获取输出流
boolean autoflush = true;
PrintWriter out = new PrintWriter( socket.getOutputStream(), autoflush); //设置自动 flush
BufferedReader in = new BufferedReader( new InputStreamReader( socket.getInputstream() ));


IO模型参考链接



  • 单线程阻塞I/O模型
    在这里插入图片描述

  • 多线程阻塞I/O模型
    在这里插入图片描述

  • 单线程非阻塞I/O模型
    在调用读取或写入接口后立即返回,而不会进入阻塞状态。

  • 多线程非阻塞I/O模型
    即经典的Reactor模型。(Netty)
    在这里插入图片描述

–图片来自《Tomcat内核设计剖析》

2. 环境搭建
  1. 下载源码:地址

在这里插入图片描述

  1. 进入解压目录,并创建一个目录,命名为home , 并将conf、webapps目录移入 home 目录中。
    在这里插入图片描述
  2. 在当前目录下创建一个 pom.xml 文件,引入tomcat的依赖包


4.0.0org.apache.tomcatapache-tomcat-8.5.42-srcTomcat8.58.5Tomcat8.5javajavaorg.apache.maven.pluginsmaven-compiler-plugin2.3UTF-81.81.8junitjunit4.12testorg.easymockeasymock3.4antant1.7.0wsdl4jwsdl4j1.6.2javax.xmljaxrpc1.1org.eclipse.jdt.core.compilerecj4.5.1



  1. 在idea中, 使用MAVEN导入该工程。
    在这里插入图片描述

  2. 配置idea的启动类, 配置 MainClass , 并配置 VM 参数。
    在这里插入图片描述
    找到启动类:
    org.apache.catalina.startup.Bootstrap
    在这里插入图片描述
    注意需要和自己的源码文件夹位置对应:

-Dcatalina.home=D:/apache-tomcat/apache-tomcat-8.5.51-src/home -Dcatalina.base=D:/apache-tomcat/apache-tomcat-8.5.51-src/home -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.util.logging.config.file=D:/apache-tomcat/apache-tomcat-8.5.51-src/home/conf/logging.properties

  1. 修改一行代码,启动主方法, 运行Tomcat , 访问Tomcat 。
    这样做的目的是手动将JSP解析器初始化。
    在org.apache.catalina.startup.ContextConfig#configureStart方法下,722行添加如下代码:

context.addServletContainerInitializer(new JasperInitializer(), null);

在这里插入图片描述
启动,成功访问。
在这里插入图片描述

如果按照上面的流程来出了问题,建议多试试,实在不行看看其他博客。

3. Servlet规范

首先我们得知道:Java体系的Web服务器基本上都会遵循Servlet规范。
其次就是我们需要学习的Servlet以及其具体实现Tomcat(容器)。
在这里插入图片描述
从包名就可以看出这是jdk自身定义的规范。

Tomcat作为一款Web服务器,其最基本的通信协议是HTTP(过程如下):
1) 用户通过浏览器进行了一个操作,比如输入网址并回车,或者是点击链接,接着浏览 器获取了这个事件。
2) 浏览器向服务端发出TCP连接请求。
3) 服务程序接受浏览器的连接请求,并经过TCP三次握手建立连接。
4) 浏览器将请求数据打包成一个HTTP协议格式的数据包。
5) 浏览器将该数据包推入网络,数据包经过网络传输,最终达到端服务程序。
6) 服务端程序拿到这个数据包后,同样以HTTP协议格式解包,获取到客户端的意图。
7) 得知客户端意图后进行处理,比如提供静态文件或者调用服务端程序获得动态结果。
8) 服务器将响应结果(可能是HTML或者图片等)按照HTTP协议格式打包。
9) 服务器将响应数据包推入网络,数据包经过网络传输最终达到到浏览器。
10) 浏览器拿到数据包后,以HTTP协议的格式解包,然后解析数据,假设这里的数据是 HTML。
11) 浏览器将HTML文件展示在页面上。


那我们想要探究的Tomcat作为一个HTTP服务器,在这个过程中都做了些什么事情呢?主要是接受连接、解析请求数据、处理请求和发送响应这几个步骤。此外我们还得了解一下Tomcat启动。


推荐阅读
  • 1,启动MySQL终端输入mysql-uroot-p然后输入密码,启动成功WelcometotheMySQLmonitor.Commandsendwith;or\g.YourMyS ... [详细]
  • Linux数据链路层的包解析仅以此文作为学习笔记,初学者,如有错误欢迎批评指正,但求轻喷。一般而言,Linux系统截获数据包后,会通过协议栈,按照TCPIP层次进行解析,那我们如何 ... [详细]
  • 超赞!GitHub上百万下载量Java面试手册!颠覆你的认知
    金三面试不顺心,马上银四面试在即,自己复盘总觉得Java知识点很凌乱?没有合适的方法学习!今天分享这份GitHub上百万下载量Ja ... [详细]
  • 为什么需要有应用层缓冲区?muduo网络库使用IO复用,并且文件描述符使用非阻塞模式,如果使用阻塞模式那么read、write就会阻塞在 ... [详细]
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了在单独的JVM上执行新的JavaFX应用程序相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 服务器性能优化之网络性能优化
    hi,大家好,今天分享一篇后台服务器性能优 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • 本文介绍了Python爬虫技术基础篇面向对象高级编程(中)中的多重继承概念。通过继承,子类可以扩展父类的功能。文章以动物类层次的设计为例,讨论了按照不同分类方式设计类层次的复杂性和多重继承的优势。最后给出了哺乳动物和鸟类的设计示例,以及能跑、能飞、宠物类和非宠物类的增加对类数量的影响。 ... [详细]
  • 纠正网上的错误:自定义一个类叫java.lang.System/String的方法
    本文纠正了网上关于自定义一个类叫java.lang.System/String的错误答案,并详细解释了为什么这种方法是错误的。作者指出,虽然双亲委托机制确实可以阻止自定义的System类被加载,但通过自定义一个特殊的类加载器,可以绕过双亲委托机制,达到自定义System类的目的。作者呼吁读者对网上的内容持怀疑态度,并带着问题来阅读文章。 ... [详细]
  • 一次上线事故,30岁+的程序员踩坑经验之谈
    本文主要介绍了一位30岁+的程序员在一次上线事故中踩坑的经验之谈。文章提到了在双十一活动期间,作为一个在线医疗项目,他们进行了优惠折扣活动的升级改造。然而,在上线前的最后一天,由于大量数据请求,导致部分接口出现问题。作者通过部署两台opentsdb来解决问题,但读数据的opentsdb仍然经常假死。作者只能查询最近24小时的数据。这次事故给他带来了很多教训和经验。 ... [详细]
  • 本文介绍了网络编程的要点,包括InetAddress类获取IP地址的方法,IP地址的定义和表示方法,IPv4和IPv6的区别,以及网络通信协议中的端口和协议类型。 ... [详细]
  • 概述H.323是由ITU制定的通信控制协议,用于在分组交换网中提供多媒体业务。呼叫控制是其中的重要组成部分,它可用来建立点到点的媒体会话和多点间媒体会议 ... [详细]
  • 1、概述首先和大家一起回顾一下Java消息服务,在我之前的博客《Java消息队列-JMS概述》中,我为大家分析了:然后在另一篇博客《Java消息队列-ActiveMq实战》中 ... [详细]
  • 详解Netty Zero Copy机制
    NettyZeroCopy的巧妙设计让Netty从众多高性 ... [详细]
  • 前言最近一段时间在整公司项目里一个功能的优化,用到了多线程处理。期间也是踩了不少的坑,在这里想说下我遇到的问题和注意事项。以及怎样知道启动的那些多线程都 ... [详细]
author-avatar
Katycui
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有