服务器模型小结(未完成)
时间:2022-06-05
本文章向大家介绍服务器模型小结(未完成),主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
1. 单进程同步IO(迭代服务器)
server每次accept一个请求,收包,完成业务处理逻辑后回包,完成整个请求的处理后,才能继续接入下一个请求。这种server模式仅适用于业务处理
2. 父进程+动态创建子进程
父进程accpet连接,有新连接到来时fork一个进程,然后继续accept,等待新的连接。业务逻辑由子进程处理,处理完后子进程exit,每个子进程只处理一个连接。由于父子进程共享accept操作返回的连接fd,因些子进程可以方便的拿到connfd并进行收发数据包的操作。
大致伪代码如下:
listenfd = socket();
bind();
listen();
while(1)
{
newsockfd = accept();
if (error) continue;
if ((childpid = fork()) == 0) {
close(listen);
process(newsockfd);
}
}
3. 预创建进程池-子进程竞争accept,有惊群效应
父进程启动后预先prefork一部分子进程,子进程都阻塞在accept,有新连接到来时,子进程竞争accept,竞争到的子进程负责这一次的业务逻辑处理,处理完成后继续阻塞在accpet上。
可以使用锁进行同步,以避免惊群效应。
4. 父进程+预创建进程池, 父进程accept,子进程负责处理,规避了惊群效应
父进程可通过管道的方式传入套接字给子进程,并且父进程需要维护子进程当前状态,根据UNP1测试,这种方式性能较差。
5. 单进程IO复用
采用select/poll/epoll等IO复用技术,只使用一个进程,当有请求可读时,读请求并处理,处理后回包,这种服务器仅适合小包请求比较多,并且业务逻辑处理不需要阻塞的服务器。
6. 单进程接入+处理子进程池
使用IO复用技术启用proxy进程负责收发包,收到的请求放到共享内存或管道中,处理子进程池中每个进程都阻塞于读管道请求上,一旦有请求到达,读请求,处理完成后写回管道中,由proxy回包给客户端。
- 通过使用hint unnest调优sql语句(r4笔记第38天)
- Spring+SpringMVC+MyBatis+easyUI整合进阶篇(十一)redis密码设置、安全设置
- 极简增强学习新手教程 返回专栏查看评论
- 经典Java面试题收集
- 百度魅族深度学习大赛初赛冠军作品(图像识别.源码)
- easyUI整合富文本编辑器KindEditor详细教程(附源码)
- 经典Java面试题收集(二)
- 使用sqlt手工创建sql_profile(r4笔记第37天)
- 使用ash分析ORA-01652问题(r4笔记第36天)
- Spring+SpringMVC+MyBatis+easyUI整合进阶篇(八)线上Mysql数据库崩溃事故的原因和处理
- 数据结构01 算法的时间复杂度和空间复杂度
- Docker+SpringBoot+Mybatis+thymeleaf的Java博客系统开源啦
- Spring【依赖注入】就是这么简单
- 数据结构02 线性表之顺序表
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- dotnet 在 UOS 国产系统上安装 MonoDevelop 开发工具
- 使用SAP Spartacus快速创建一个电商店铺网站
- 使用StackBlitz和SAP Spartacus快速创建电商店铺页面
- SAP CRM Interactive Report(交互式报表)里和服务订单相关的一些字段
- SAP S/4HANA Customer Management(CRM)模块的扩展性设计
- SAP S/4HANA Customer Management(CRM)模块的Partner模型设计
- 使用soapUI消费SAP Cloud for Customer的web service
- 视频上云网关EasyNTS智能云组网如何通过23端口穿透实现远程控制功能?
- 视频上云网关平台EasyCVR登录页开发控制台报net::ERR_CONNECTION_TIMED_OUT错误
- 视频监控系统视频上云解决方案EasyCVR集成海康EHome私有协议系列——开启存储服务
- 设计模式~责任链模式
- 大数据计算的基石——MapReduce
- SPA单页应用的优缺点
- 《JavaScript 模式》读书笔记(7)— 设计模式1
- CenterNet测试推理过程