Tomcat components illustrate the architectural evolution of a web server

Tomcat components illustrate the architectural evolution of a web server

1. Who is tomcat?

2. What can tomcat do?

Tomcat is a web container. Web applications can be deployed to Tomcat, which provides web services. Multiple web applications can be deployed in one web container. These web applications can be services of the same domain name or multiple domain names.

3. What are the components of tomcat

4. How to quickly understand these components?

We can assume that we are designing a web container, what should we design?

The first generation: receiving requests, processing requests, and returning results to the entire web container, as shown in the following figure:

Second generation: Separate connection management and processing logic

During use, I found that it was annoying to open the socket connection, call the processing logic, and then close the socket connection every time. I simply let the Connector handle the closing of the socket connection, and let the Container handle the business logic of the request. That's it.

Third generation: Support multiple network protocols

The original goal was to design a web server or container. If you want to support more protocols, you need to create different Connectors and Containers. At this time, it becomes like this, where service wraps Connectors and Containers.

Fourth generation: support for multiple web applications

Since it is a container, it must support multiple applications. Each application has a Context and is isolated from each other. The architecture that supports multiple Contexts is as follows:

Fifth generation: support for multiple domain names

Contexts require not only physical isolation, but also logical isolation, such as app1.example.com accessing context1 and app1.test.com accessing context2.

The architecture at this point should be like this: the host can support multiple contexts.

5. Summary:

  • The components of the web server are server-->satisfy the function
  • server+connector+Container-->Separation of responsibilities
  • server+service+connector+Container-->Support multiple protocols
  • server+service+connector+Container+context-->support multiple applications
  • server+service+connector+Container+host+context -->Support multiple applications with multiple domain names

In fact, it is a process of division of labor and refinement of components, similar to the refinement of social division of labor. Note that Container is also called engine in Tomcat.

The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM.

You may also be interested in:
  • Looking at Tomcat's thread model from the connector component - BIO mode (recommended)
  • Detailed explanation of Tomcat core components and application architecture

<<:  A simple explanation of MySQL parallel replication

>>:  How to deeply understand React's ref attribute

Recommend

MySQL 8.0.25 installation and configuration method graphic tutorial

The latest download and installation tutorial of ...

Method for comparing the size of varchar type numbers in MySQL database

Create a test table -- --------------------------...

How to implement Docker volume mounting

The creation of the simplest hello world output i...

Native JS encapsulation vue Tab switching effect

This article example shares the specific code of ...

Detailed installation process of MySQL 8.0 Windows zip package version

The installation process of MySQL 8.0 Windows zip...

MySQL 5.5.56 installation-free version configuration method

The configuration method of MySQL 5.5.56 free ins...

Vue gets token to implement token login sample code

The idea of ​​using token for login verification ...

Detailed steps to upgrade mysql8.0.11 to mysql8.0.17 under win2008

Upgrade background: In order to solve the vulnera...

Implementing a simple timer in JavaScript

This article example shares the specific code of ...

How to modify the default storage engine in MySQL

mysql storage engine: The MySQL server adopts a m...

How to build SFTP server and image server on Linux cloud server

First of all, you can understand the difference b...

CSS3 radar scan map sample code

Use CSS3 to achieve cool radar scanning pictures:...