Linux下Web服务器工作模型及Nginx工作原理详解
文章目录
- 1. 工作模型概述
- 1.1 阻塞、非阻塞、同步、异步浅析
- 1.2 Web服务器处理并发请求的方式
- 2. Linux下的I/O模型
- 2.1 常用I/O模型
- 2.2 对比以上模型
- 3. Nginx工作原理
- 3.1 Nginx基本架构
- 3.2 Nginx代码结构
- 3.3 Nginx工作流程
- 3.4 Nginx缓存机制
- 3.5 Nginx缓存工具:Memcached
- 结语
在Linux环境下,Web服务器处理并发连接请求的工作模型主要有阻塞、非阻塞、同步、异步等方式。以下是对各种工作模型的浅析:
1. 工作模型概述
1.1 阻塞、非阻塞、同步、异步浅析
- 同步阻塞 I/O: 类比于在餐厅等饭,需要在取餐处等待,期间不能进行其他事情。
- 同步非阻塞 I/O: 类比于在餐厅等饭,可以进行其他事情,但需要不断询问饭是否准备好。
- 异步 I/O: 类比于在餐厅等饭,只需坐着等人送饭。
1.2 Web服务器处理并发请求的方式
- 单线程Web服务器: 一次只处理一个请求,其他请求被忽略,可能导致性能问题。
- 多进程/多线程Web服务器: 生成多个进程或线程并行处理多个用户请求,但可能消耗大量系统资源。
- I/O多路复用Web服务器: 使用多路复用架构,支持更多并发用户请求,提供高效工作模式。
- 多路复用多线程Web服务器: 结合多进程和多路复用功能,避免一个进程服务于过多请求。
2. Linux下的I/O模型
2.1 常用I/O模型
- 阻塞I/O
- 非阻塞I/O
- I/O复用(select和poll)
- 信号驱动I/O(SIGIO)
- 异步I/O(Posix.1的aio_系列函数)
2.2 对比以上模型
- 阻塞I/O: 应用程序调用I/O函数,等待数据准备好。
- 非阻塞I/O: I/O操作无法完成时返回错误,需要不断测试数据是否准备好。
- I/O复用: 使用select或poll函数,可以同时阻塞多个I/O操作,直到数据准备好。
- 信号驱动I/O: 允许套接口进行信号驱动I/O,进程不阻塞,收到SIGIO信号时处理数据。
- 异步I/O: 异步过程调用发出后,调用者不能立即得到结果,通过状态、通知和回调来通知调用者。
3. Nginx工作原理
3.1 Nginx基本架构
- 进程模型: 主进程(master)和工作进程(worker),可以同时运行多个工作进程。
- 工作进程任务: 处理客户端连接、反向代理、提供其他功能。
3.2 Nginx代码结构
- 模块化结构: 核心和多个模块组成,包括事件模块、阶段性处理器、输出过滤器、变量处理器、协议、upstream等。
- 进程间通信: 使用共享内存进行模块间通信。
3.3 Nginx工作流程
-
主进程:
- 读取并验证配置信息。
- 创建、绑定及关闭套接字。
- 启动、终止及维护工作进程个数。
- 重新打开日志文件。
- 控制程序升级、回滚等。
-
工作进程:
- 接收、传入并处理来自客户端的连接。
- 提供反向代理及过滤功能。
- 并行处理数千个并发连接及请求。
3.4 Nginx缓存机制
- 核心功能: 提供基本的Web Server功能以及Web和Mail反向代理。
- 缓存: 使用共享内存缓存,如Memcached,加速web应用程序。
3.5 Nginx缓存工具:Memcached
- 用途: 高性能、分布式内存对象缓存系统,用于降低对数据库的访问。
- 设计思想: 简单key/value存储,功能实现由客户端和服务器端共同完成。
- 命令: set, add, replace, append, prepend, get, delete, incr/decr等。
结语
综上所述,Linux下Web服务器工作模型和Nginx的工作原理是复杂而高效的,选择适当的工作模型和缓存机制对提高Web服务器性能至关重要。Nginx通过其独特的架构和模块化设计,在高并发环境下表现卓越,成为广泛应用的Web服务器和反向代理工具。
相关文章:
Linux下Web服务器工作模型及Nginx工作原理详解
文章目录 1. 工作模型概述1.1 阻塞、非阻塞、同步、异步浅析1.2 Web服务器处理并发请求的方式 2. Linux下的I/O模型2.1 常用I/O模型2.2 对比以上模型 3. Nginx工作原理3.1 Nginx基本架构3.2 Nginx代码结构3.3 Nginx工作流程3.4 Nginx缓存机制3.5 Nginx缓存工具:Memc…...
AJAX: 整理2:学习原生的AJAX,这边借助express框架
1. npm install express 终端直接安装 2. 测试案例:Hello World! 新建一个express.js的文件,写入下方的内容 // 1. 引入express const express require(express)// 2. 创建服务器 const app express()// 3.创建路由规则 // request 是对请…...
二、计算机软件及其使用-文字处理软件 Word 2016
Word 2016 的功能;Word 2016 的启动方法和工作窗口 Word 2016 的功能 编辑功能、排版功能、表格处理功能、图形与公式处理功能、文档管理功能 Word 2016 的启动方法 桌面有就单击、任务栏有就单击、开始菜单中单击 Word 2016 的工作窗口 标题栏、功能区、工作区、状…...
Linux LVM逻辑卷
一、LVM的定义 LVM 是 Logical Volume Manager 的简称,译为中文就是逻辑卷管理。它是 Linux 下对硬盘分区的一种管理机制。LVM 适合于管理大存储设备,并允许用户动态调整文件系统的大小。此外,LVM 的快照功能可以帮助我们快速备份数据。LVM 为…...
Hive生产调优介绍
1.Fetch抓取 Fetch抓取是指,Hive中对某些情况的查询可以不必使用MapReduce计算。例如:SELECT * FROM employees;在这种情况下,Hive可以简单地读取employee对应的存储目录下的文件,然后输出查询结果到控制台。 在hive-default.xml…...
如何理解鼠标点击事件在程序中的处理
在计算机用户界面中,鼠标点击是一个常见的交互动作。那么,当你按下鼠标时,程序是如何知道这个点击是否针对它自己的按钮的呢?本文将探讨鼠标点击事件在操作系统和应用程序之间的传递过程。 鼠标点击事件的捕获 当你按下鼠标按钮…...
基于JWT的用户token验证
1. 基于session的用户验证 2. 基于token的用户身份验证 3. jwt jwt代码实现方式 1. 导包 <dependency><groupId>com.auth0</groupId><artifactId>java-jwt</artifactId><version>3.18.2</version> </dependency> 2. 在登录…...
通过 conda 安装 的 detectron2
从 detectron2官网 发现预编译的版本最高支持 pytorch1.10、cuda11.3。(2023-12-26) 1、安装 conda 环境。 conda create --name detectron2 python3.8 2、安装 pytorch1.10 和 cuda11.3。 pip3 install torch1.10.0cu113 torchvision0.11.1cu113 torc…...
嵌入式开发——SPI OLED屏幕案例
学习目标 掌握移植方法掌握调试方式学习内容 需求 官方测试示例 选择对应的平台 测试示例中,找到芯片对应平台,我们选择的是STM32F407 修改例程 已知错误修改:...
ibm上电时序(视频内容)
...
如何在Vue.js中使用$emit进行组件通信
Vue.js是一个渐进式JavaScript框架,它以其简洁的数据绑定和组件系统而闻名。在构建具有多个组件层次的Vue应用时,组件间的通信成为一个关键的话题。Vue提供了一种名为$emit的方法,允许子组件向父组件发送消息。本文将详细介绍如何在Vue中使用…...
SPSS相关统计学知识精要回顾-大家都来做做
很多学生问我,学SPSS如果想深入学,那么统计学原理应该掌握到什么样的水准,我想说的是,如果真的想融会贯通,而不是短暂过关,那么应该具备一定的统计学基础,但是统计学知识也不是面面俱到都要去学…...
React Native 从类组件到函数组件
1. 发展趋势 React Native社区中的趋势是朝向使用函数组件(Functional Components)和Hooks的方向发展,而不是使用类组件(Class Components)。 React Native自推出Hooks API以来,函数组件和Hooks的使用变得…...
Redis 快速搭建与使用
文章目录 1. Redis 特性1.1 多种数据类型支持1.2 功能完善1.3 高性能1.4 广泛的编程语言支持1.5 使用简单1.6 活跃性高/版本迭代快1.7 I/O 多路复用模型 2. Redis发展历程3. Redis 安装3.1 源码安装3.1.1 下载源码包3.1.2 解压安装包3.1.3 切换到 Redis 目录3.1.4 编译安装 3.2…...
SpringBoot集成etcd,实现实时监听,实现配置中心
etcd 是一个分布式键值对存储,设计用来可靠而快速的保存关键数据并提供访问。通过分布式锁,leader选举和写屏障(write barriers)来实现可靠的分布式协作。etcd集群是为高可用,持久性数据存储和检索而准备。 以下代码实现的主要业务是…...
JavaScript元素根据父级元素宽高缩放
/*** 等比缩放* param wrap 外部容器* param container 待缩放的容器* returns {{width: number, height: number}}* 返回值:width:宽度, height:高度*/aspectRatio(wrap: any, container: any) {// w h / ratio, h w * ratioconst wrapW wrap.width;const wrapH…...
易趋产品升级(EasyTrack 11_V1.3) | 集成飞书、WPS、个性化设置,增强团队协作和用户体验
企业在项目管理过程中,经常会遇到项目信息同步不及时、沟通障碍以及管理软件使用不便捷等难题,导致团队协作效率低下。这种情况下,如果使用了多个办公软件(如:钉钉、企业微信、项目管理软件等),…...
帆软FineBi V6版本经验总结
帆软FineBi V6版本经验总结 BI分析出现背景 现在是一个大数据的时代,每时每刻都有海量的明细数据出现。这时大数据时代用户思维是:1、数据的爆炸式增长,人们比起明细数据,更在意样本的整体特征、相互关系。2、基于明细的“小…...
03.MySQL的体系架构
MySQL的体系架构 一、MySQL简介二、MySQL的体系架构三、MySQL的内存结构四、MySQL的文件结构 一、MySQL简介 MySQL是一个开源的关系型数据库管理系统(RDBMS),由瑞典MySQL AB公司开发,后被Sun公司收购,Sun公司被Oracle…...
随笔笔记-2023
随笔 computed 是基于他们的依赖进行缓存的,。如果要随时计算 new Date().now(因为不是响应式的),那么需要用 computed。 如果不希望用缓存那么就用 methods 字符与字节 1 字节8 位1B8 bit;1KB 1024B,1MB1024KB1024*1024B 编码:…...
3分钟掌握RPG Maker资源解密:纯前端工具轻松破解加密文件
3分钟掌握RPG Maker资源解密:纯前端工具轻松破解加密文件 【免费下载链接】RPG-Maker-MV-Decrypter You can decrypt RPG-Maker-MV Resource Files with this project ~ If you dont wanna download it, you can use the Script on my HP: 项目地址: https://gitc…...
微信聊天记录终极备份指南:5步将珍贵对话永久保存到电脑
微信聊天记录终极备份指南:5步将珍贵对话永久保存到电脑 【免费下载链接】WeChatExporter 一个可以快速导出、查看你的微信聊天记录的工具 项目地址: https://gitcode.com/gh_mirrors/wec/WeChatExporter 你是否曾因手机丢失、系统崩溃或更换设备而永远失去了…...
从人工到有机:数字健康AI的范式转变与工程实践
1. 从“人工”到“有机”:一次关于智能本质的范式转变在数字健康领域,我们每天都在与“人工智能”打交道。从辅助医生阅片的影像分析系统,到预测患者风险的算法模型,AI似乎已经成为推动医疗革新的核心引擎。然而,当我们…...
如何快速解析SWF文件:JPEXS免费Flash反编译器的完整指南
如何快速解析SWF文件:JPEXS免费Flash反编译器的完整指南 【免费下载链接】jpexs-decompiler JPEXS Free Flash Decompiler 项目地址: https://gitcode.com/gh_mirrors/jp/jpexs-decompiler JPEXS Free Flash Decompiler是一款功能强大的开源Flash逆向工程工具…...
VMware Unlocker:免费解锁VMware的macOS虚拟机支持终极指南
VMware Unlocker:免费解锁VMware的macOS虚拟机支持终极指南 【免费下载链接】unlocker VMware Workstation macOS 项目地址: https://gitcode.com/gh_mirrors/unloc/unlocker 想在Windows或Linux电脑上运行macOS虚拟机,却发现VMware根本不提供苹…...
观测Taotoken在每日大赛期间API调用的延迟与稳定性表现
🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 观测Taotoken在每日大赛期间API调用的延迟与稳定性表现 在技术社区组织的每日编程挑战赛期间,开发者们通常会集中、高频…...
员工管理(新增员工)、事务管理和文件上传(阿里云OSS)
员工管理(新增员工) 思路就是就是新增的员工基本信息和批量保存员工的工作经历信息,也就是后端对应了两条sql语句, 1.保存员工基本信息 Emp实体类中新添一个字段用于保存员工工作经历 //封装工作经历 private List<EmpExpr> exprList; (1)Cont…...
Nexus Machine架构:边缘计算中稀疏矩阵处理的革新
1. 项目概述:Nexus Machine架构的创新价值在边缘计算和AI推理领域,稀疏矩阵计算(如SpMSpM、SpMV)和图形处理(如BFS、PageRank)等不规则工作负载正面临严峻的性能瓶颈。传统CGRA(Coarse-Grained …...
Book118文档下载器:3步免费获取完整PDF文档的终极指南
Book118文档下载器:3步免费获取完整PDF文档的终极指南 【免费下载链接】book118-downloader 基于java的book118文档下载器 项目地址: https://gitcode.com/gh_mirrors/bo/book118-downloader 你是否曾在Book118网站上找到急需的学习资料,却发现需…...
2026浏览器插件指纹溯源机制与插件环境安全优化实战指南
一、前言:插件特征成为批量虚拟环境识别的新型突破口在矩阵运营行业精细化风控对抗背景下,UA 修改、IP 切换、基础指纹伪装已经成为行业标配操作,平台逐渐放弃基础参数检测,转向高隐蔽、高区分度、极易被忽略的插件指纹进行设备识…...
