当前位置: 首页 > article >正文

Web框架 --- Web服务器和Web应用服务器

Web框架 --- Web服务器和Web应用服务器

  • 什么是HTTP Web服务器
  • Web框架与Web服务器的关系 --- 以SpringBoot 和 Tomcat为例
  • Simple Web Server Example

在日常开发的时候不管是用什么样的Web框架,比如Srpingboot或者ASP.Net, 我们只要在IDE里点击Run,项目就运行起来并且可以接收解析HTTP请求了. 但是Web框架是怎么做到接收解析HTTP请求的呢.

其实所有的Web框架都内置了一个HTTP Web服务器来接收解析HTTP请求

什么是HTTP Web服务器

HTTP Web 服务器是用于托管网站、处理 HTTP/HTTPS 请求的软件. 其中又分为Web服务器Web应用服务器

  • Web服务器(也称为HTTP服务器)是负责处理客户端(如浏览器)的HTTP请求,并返回静态内容(如HTML、图片、CSS、JavaScript文件等)的软件。它主要关注静态资源的快速响应和基础的请求处理。
  • Web应用服务器(简称应用服务器)是用于处理动态内容和复杂业务逻辑的服务器。它通常与编程语言或框架(如Java、ASP.NET、Python的WSGI)结合,执行后端代码生成动态响应,并提供企业级服务(如事务管理、安全、数据库连接池等)。

Web服务器(Web Server)

核心职责

  • 静态内容托管:直接返回预存的静态文件(如HTML、CSS、JS、图片)。
  • 高性能处理:优化静态资源的传输效率,支持高并发。
  • 基础功能:
    HTTP请求解析
    URL路由
    缓存控制(如CDN配合)
    反向代理/负载均衡

典型工作流程

用户请求 --> Web服务器 --> 返回静态文件(如index.html)

主流Web服务器

  • Nginx:高性能、低内存占用,常用于反向代理。
  • Apache HTTP Server:模块化设计,支持.htaccess配置。
  • Caddy:自动HTTPS,配置简单
 目前最常用的Web服务器是Nginx, 常用于反向代理和负载均衡

Web应用服务器(Web Application Server)

核心职责

  • 接收解析HTTP请求,URL路由
  • 运行动态程序:执行服务器端代码(如Java Servlet、Python Flask、Node.js)。
  • 和Web框架搭配(如SpringBoot , ASP.Net)负责业务逻辑处理:连接数据库、处理表单、生成动态内容。

典型工作流程

用户请求 --> Web应用服务器 --> 执行业务逻辑(如查询数据库) --> 生成动态HTML --> 返回响应

代表软件

  • Tomcat/Jetty:轻量级Servlet容器(支持Java Web应用)。
  • IIS / Kestrel:微软系,支持ASP.NET。

常见协作模式(Java为例)

用户请求 --> Nginx(反向代理/负载均衡) --> Tomcat(SpringBoot)(动态请求) --> 数据库

Web框架与Web服务器的关系 — 以SpringBoot 和 Tomcat为例

  • Spring Boot 是一个基于 Spring 框架的开发工具,它的目标是简化 Spring 应用的开发。Spring Boot 提供了许多开箱即用的配置,消除了繁琐的XML配置,并通过自动化配置简化了开发过程。它还提供了许多特性,例如内嵌服务器支持、生产级别的监控、Spring Boot Actuator等。
  • Spring Boot 的核心特性之一是其能够嵌入 Web 服务器。它支持多个 Web 服务器,如 Tomcat、Jetty 和 Undertow。我们可以选择其中一个内嵌服务器,这样应用就可以作为一个独立的 Java 应用运行,而不需要部署到外部服务器上
  • 虽然 Spring Boot 默认使用内嵌 Tomcat,但它仍然支持传统的 Web 应用部署方式。开发者可以选择将 Spring Boot 应用部署到外部的 Tomcat 服务器上
  • Spring Boot 主要关注简化 Spring 应用的开发过程,提供内嵌的 Web 服务器,并简化应用的配置与部署。
  • Tomcat 主要是一个 Web 服务器,它处理 HTTP 请求、Servlet 请求和响应,但它并不直接涉及应用程序的业务逻辑开发。
  • Spring Boot 通过自动配置、内嵌服务器支持和快速启动特性,使得开发者可以将应用打包成一个 JAR 文件或 WAR 文件,并通过 java -jar 或部署到外部服务器的方式运行应用。
  • Tomcat 则是独立的 Web 服务器,通常需要手动安装和配置,并将 WAR 文件部署到 Tomcat 中。
    配置的灵活性:
  • 在 Spring Boot 中,Tomcat 被内嵌并自动配置,开发者不需要手动配置 Tomcat 的细节(例如端口、线程池等),除非有特别的需求。Spring Boot 提供了 application.properties 或 application.yml 文件来轻松配置 Tomcat。
  • 在传统的 Tomcat 环境中,所有配置(如端口、内存、线程池等)通常都需要通过 server.xml 等配置文件手动设置。

Simple Web Server Example

  • 以下是一个使用Java实现的基础HTTP Web服务器的示例代码,支持静态文件传输和基础HTTP协议处理:
import java.io.*;
import java.net.*;
import java.nio.file.Files;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;public class SimpleWebServer {private static final int PORT = 8080;private static final String ROOT_DIR = "www"; // 静态文件根目录private static final ExecutorService threadPool = Executors.newFixedThreadPool(10);public static void main(String[] args) throws IOException {try (ServerSocket serverSocket = new ServerSocket(PORT)) {System.out.println("Server started on port " + PORT);while (true) {Socket clientSocket = serverSocket.accept();threadPool.execute(() -> handleRequest(clientSocket));}}}private static void handleRequest(Socket clientSocket) {try (BufferedReader in = new BufferedReader(new InputStreamReader(clientSocket.getInputStream()));OutputStream out = clientSocket.getOutputStream()) {// 解析HTTP请求String requestLine = in.readLine();if (requestLine == null || !requestLine.startsWith("GET")) {sendErrorResponse(out, 400, "Bad Request");return;}// 提取请求路径String path = requestLine.split(" ")[1];path = path.equals("/") ? "/index.html" : path;File file = new File(ROOT_DIR + path);// 处理文件请求if (file.exists() && !file.isDirectory()) {sendFileResponse(out, file);} else {sendErrorResponse(out, 404, "Not Found");}} catch (IOException e) {e.printStackTrace();} finally {try {clientSocket.close();} catch (IOException e) {e.printStackTrace();}}}private static void sendFileResponse(OutputStream out, File file) throws IOException {String contentType = Files.probeContentType(file.toPath());byte[] fileContent = Files.readAllBytes(file.toPath());String header = "HTTP/1.1 200 OK\r\n" +"Content-Type: " + contentType + "\r\n" +"Content-Length: " + fileContent.length + "\r\n" +"Connection: close\r\n\r\n";out.write(header.getBytes());out.write(fileContent);out.flush();}private static void sendErrorResponse(OutputStream out, int statusCode, String statusText) throws IOException {String response = "HTTP/1.1 " + statusCode + " " + statusText + "\r\n" +"Content-Type: text/html\r\n" +"Connection: close\r\n\r\n" +"<h1>" + statusCode + " - " + statusText + "</h1>";out.write(response.getBytes());out.flush();}
}

实现说明:

  1. 启动服务器

    • 使用ServerSocket监听8080端口
    • 线程池处理并发请求(最多10个并发)
  2. 请求处理流程

    • 解析HTTP请求首行(仅支持GET方法)
    • 映射请求路径到本地文件系统
    • 默认请求/返回index.html
  3. 文件响应

    • 自动检测MIME类型
    • 发送正确的HTTP头+文件内容
    • 支持常见静态文件类型(HTML/CSS/JS/图片等)
  4. 错误处理

    • 400 Bad Request(非法请求)
    • 404 Not Found(文件不存在)
    • 500错误会被Java异常机制捕获

这个实现虽然简单(约100行代码),但完整演示了Web服务器的核心工作原理

相关文章:

Web框架 --- Web服务器和Web应用服务器

Web框架 --- Web服务器和Web应用服务器 什么是HTTP Web服务器Web框架与Web服务器的关系 --- 以SpringBoot 和 Tomcat为例Simple Web Server Example 在日常开发的时候不管是用什么样的Web框架&#xff0c;比如Srpingboot或者ASP.Net, 我们只要在IDE里点击Run&#xff0c;项目就…...

【SpringBoot】98、SpringBoot中整合springdoc-openapi-ui接口文档

1、引入依赖 引入依赖<dependency><groupId>org.springdoc</groupId><artifactId>springdoc-openapi-ui...

多线程(进阶)(内涵面试题)

目录 一、常见的锁策略 1. 悲观锁 vs 乐观锁 2. 重量级锁 vs 轻量级锁 3. 挂起等待锁 vs 自旋锁 4. 普通互斥锁 vs 读写锁 5. 可重入锁 vs 不可重入锁 6. 公平锁 vs 非公平锁 7. 面试题 二、synchronized的原理 1. 基本特点 2. 加锁工作过程 1&#xff09;偏向锁&am…...

蓝桥杯补题

方法技巧&#xff1a; 1.进行循环暴力骗分&#xff0c;然后每一层的初始进行判断&#xff0c;如果已经不满足题意了&#xff0c;那么久直接continue&#xff0c;后面的循环就不用浪费时间了。我们可以把题目所给的等式&#xff0c;比如说有四个未知量&#xff0c;那么我们可以用…...

【MySQL篇】mysqlpump和mysqldump参数区别总汇

&#x1f4ab;《博主主页》&#xff1a;奈斯DB-CSDN博客 &#x1f525;《擅长领域》&#xff1a;擅长阿里云AnalyticDB for MySQL(分布式数据仓库)、Oracle、MySQL、Linux、prometheus监控&#xff1b;并对SQLserver、NoSQL(MongoDB)有了解 &#x1f496;如果觉得文章对你有所帮…...

C++17模板编程与if constexpr深度解析

一、原理深化 1.1 模板编程 1.1.1 编译器如何处理模板&#xff08;补充&#xff09; 模板的实例化机制存在两种模式&#xff1a; 隐式实例化&#xff1a;编译器在遇到模板具体使用时自动生成代码&#xff0c;可能导致多翻译单元重复实例化&#xff0c;增加编译时间。显式实…...

SQL:DDL(数据定义语言)和DML(数据操作语言)

目录 什么是SQL&#xff1f; 1. DDL&#xff08;Data Definition Language&#xff0c;数据定义语言&#xff09; 2. DML&#xff08;Data Manipulation Language&#xff0c;数据操作语言&#xff09; DDL和DML的区别 什么是SQL&#xff1f; SQL&#xff08;Structured …...

神舟平板电脑怎么样?平板电脑能当电脑用吗?

在如今的数码产品市场上&#xff0c;神舟平板电脑会拥有独特的优势&#xff0c;其中比较受到大家关注的就是神舟PCpad为例&#xff0c;无论是设计还是规格也会有很多的亮点&#xff0c;那么是不是可以直接当成电脑一起来使用呢&#xff1f; 这款平板电脑就会配备10.1英寸显示屏…...

【力扣hot100题】(075)数据流的中位数

一开始只建立了一个优先队列&#xff0c;每次查询中位数时都要遍历一遍于是喜提时间超限&#xff0c;看了答案才恍然大悟原来还有这么聪明的办法。 方法是建立两个优先队列&#xff0c;一个大根堆一个小根堆&#xff0c;大根堆记录较小的数&#xff0c;小根堆记录较大的数。 …...

AI大模型从0到1记录学习 day15

14.3.5 互斥锁 1&#xff09;线程安全问题 线程之间共享数据会存在线程安全的问题。 比如下面这段代码&#xff0c;3个线程&#xff0c;每个线程都将g_num 1 十次&#xff1a; import time import threading def func(): global g_num for _ in range(10): tmp g_num 1 # ti…...

43. Java switch 语句 null 选择器变量

文章目录 43. Java switch 语句 null 选择器变量null 选择器变量示例&#xff1a;处理 null 选择器变量程序输出&#xff1a;解释 &#x1f4d6; 为什么需要这样做&#xff1f; &#x1f914;更进一步&#xff1a;使用 Optional 避免 null 检查示例&#xff1a;使用 Optional 包…...

linux下MMC_TEST的使用

一:打开如下配置,将相关文件编译到内核里: CONFIG_MMC_TEST CONFIG_MMC_DEBUG CONFIG_DEBUG_FS二:将mmc设备和mmc_test驱动进行绑定 2.1查看mmc设备编号 ls /sys/bus/mmc/drivers/mmcblk/mmc0:aaaa2.2将mmc设备与原先驱动进行解绑 echo mmc0:aaaa >...

Java——pdf增加水印

文章目录 前言方式一 itextpdf项目依赖引入编写PDF添加水印工具类测试效果展示 方式二 pdfbox依赖引入编写实现类效果展示 扩展1、将inputstream流信息添加水印并导出zip2、部署出现找不到指定字体文件 资料参考 前言 近期为了知识库文件导出&#xff0c;文件数据安全处理&…...

leetcode_19. 删除链表的倒数第 N 个结点_java

19. 删除链表的倒数第 N 个结点https://leetcode.cn/problems/remove-nth-node-from-end-of-list/ 1、题目 给你一个链表&#xff0c;删除链表的倒数第 n 个结点&#xff0c;并且返回链表的头结点。 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,4,5], n 2 输出&#…...

41、web前端开发之Vue3保姆教程(五 实战案例)

一、项目简介和需求概述 1、项目目标 1.能够基于Vue3创建项目 2.能够基本Vue3相关的技术栈进行项目开发 3.能够使用Vue的第三方组件进行项目开发 4.能够理解前后端分离的开发模式 2、项目概述 使用Vue3结合ElementPlus,ECharts工具实现后台管理系统页面,包含登录功能,…...

zsh: command not found: hdc - 鸿蒙 HarmonyOS Next

终端中执行 hdc 命令抛出如下错误; zsh: command not found: hdc 解决办法 首先,查找到 DevEco-Studio 的 toolchains 目录路径; 其次,按照类似如下的文件夹层级结果推理到 toolchains 子级路径下,其中 sdk 后一级的路径可能会存在差异,以实际本地路径结构为主,直至找到 ope…...

ffpyplayer+Qt,制作一个视频播放器

ffpyplayerQt&#xff0c;制作一个视频播放器 项目地址FFmpegMediaPlayerVideoWidget 项目地址 https://gitee.com/chiyaun/QtFFMediaPlayer FFmpegMediaPlayer 按照 QMediaPlayer的方法重写一个ffpyplayer # coding:utf-8 import logging from typing import Unionfrom PySide…...

transformer 中编码器原理和部分实现

编码器部分实现 目标 了解编码器中各个组成部分的作用掌握编码器中各个组成部分的实现过程 编码器部分 由N个编码器堆叠组成每个编码器由两个子层连接结构组成第一个子连接结构包括一个多头注意力子层和规范化层以及一个残差连接第二个子层连接结构包括一个前馈全链接子层和…...

MySQL多表查询实战指南:从SQL到XML映射的完整实现(2W+字深度解析)

MySQL多表查询实战指南:从SQL到XML映射的完整实现(2W+字深度解析) 第一章 多表查询基础与核心原理 1.1 关系型数据库设计范式 以电商系统为例的三范式实践: -- 原始数据表(违反第三范式) CREATE TABLE orders (order_id INT PRIMARY KEY,customer_name VARCHAR(50),p…...

蓝桥杯--寻找整数

题解 public static void main(String[] args) {int[] mod {0, 0, 1, 2, 1, 4, 5, 4, 1, 2, 9, 0, 5, 10, 11, 14, 9, 0, 11, 18, 9, 11, 11, 15, 17, 9, 23, 20, 25, 16, 29, 27, 25, 11, 17, 4, 29, 22, 37, 23, 9, 1, 11, 11, 33, 29, 15, 5, 41, 46};long t lcm(2, 3);lo…...

Kafka 中,为什么同一个分区只能由消费者组中的一个消费者消费?

在 Kafka 中&#xff0c;同一个分区只能由消费者组中的一个消费者消费&#xff0c;这是 Kafka 的设计决策之一&#xff0c;目的是保证消息的顺序性和避免重复消费。这背后有几个关键的原因&#xff1a; 1. 保证消息顺序性 Kafka 中的每个 分区&#xff08;Partition&#xff…...

自然语言处理入门6——RNN生成文本

一、文本生成 我们在前面的文章中介绍了LSTM&#xff0c;根据输入时序数据可以输出下一个可能性最高的数据&#xff0c;如果应用在文字上&#xff0c;就是根据输入的文字&#xff0c;可以预测下一个可能性最高的文字。利用这个特点&#xff0c;我们可以用LSTM来生成文本。输入…...

$R^n$超平面约束下的向量列

原向量&#xff1a; x → \overset{\rightarrow}{x} x→ 与 x → \overset{\rightarrow}{x} x→法向相同的法向量&#xff08;与 x → \overset{\rightarrow}{x} x→同向&#xff09; ( x → ⋅ n → ∣ n → ∣ 2 ) n → (\frac{\overset{\rightarrow}x\cdot\overset{\righta…...

FPGA_DDR错误总结

1otp 31-67 解决 端口没连接 必须赋值&#xff1b; 2.PLACE 30-58 TERM PLINITCALIBZ这里有问题 在顶层输出但是没有管脚约束报错 3.ERROR: [Place 30-675] 这是时钟不匹配IBUF不在同一个时钟域&#xff0c;时钟不在同一个时钟域里&#xff0c;推荐的不建议修改 问题 原本…...

k8s之Service类型详解

1.ClusterIP 类型 2.NodePort 类型 3.LoadBalancer 类型 4.ExternalName 类型 类型为 ExternalName 的 Service 将 Service 映射到 DNS 名称&#xff0c;而不是典型的选择算符&#xff0c; 例如 my-service 或者 cassandra。你可以使用 spec.externalName 参数指定这些服务…...

NOIP2011提高组.玛雅游戏

目录 题目算法标签: 模拟, 搜索, d f s dfs dfs, 剪枝优化思路*详细注释版代码精简注释版代码 题目 185. 玛雅游戏 算法标签: 模拟, 搜索, d f s dfs dfs, 剪枝优化 思路 可行性剪枝 如果某个颜色的格子数量少于 3 3 3一定无解因为要求字典序最小, 因此当一个格子左边有…...

网络安全应急响应之文件痕迹排查:从犯罪现场到数字狩猎的进化论

凌晨3点&#xff0c;某金融企业的服务器突然告警&#xff0c;核心数据库出现未知进程访问。安全团队紧急介入时&#xff0c;攻击者已抹去日志痕迹。在这场与黑客的时间赛跑中&#xff0c;文件痕迹排查成为破局关键。本文将带您深入数字取证的"案发现场"&#xff0c;揭…...

移动端六大语言速记:第11部分 - 内存管理

移动端六大语言速记:第11部分 - 内存管理 本文将对比Java、Kotlin、Flutter(Dart)、Python、ArkTS和Swift这六种移动端开发语言在内存管理方面的特性,帮助开发者理解和掌握各语言的内存管理机制。 11. 内存管理 11.1 垃圾回收机制对比 各语言垃圾回收机制的主要特点对比:…...

基于ssm框架的校园代购服务订单管理系统【附源码】

1、系统框架 1.1、项目所用到技术&#xff1a; javaee项目 Spring&#xff0c;springMVC&#xff0c;mybatis&#xff0c;mvc&#xff0c;vue&#xff0c;maven项目。 1.2、项目用到的环境&#xff1a; 数据库 &#xff1a;mysql5.X、mysql8.X都可以jdk1.8tomcat8 及以上开发…...

lib-zo,C语言另一个协程库,函数列表

lib-zo,C语言另一个协程库,函数列表 支持开启/禁用指定fd是否开启协程切换 /* 主动设置fd支持协程切换 */ void zcoroutine_enable_fd(int fd);/* 主动设置fd不支持协程切换 */ void zcoroutine_disable_fd(int fd);函数列表 #pragma once#ifndef ___ZC_LIB_INCLUDE_COROUTI…...