linux如何处理多连接请求?
1.TCP迭代服务器程序
这种方式就是服务器同一时间只处理一个客户端的请求,这个请求处理完以后才转向下一个客户请求。当然这样的服务器程序比较少见,这就像一个公司只能一次处理一个客户,后面的客户只能等待,这样的话肯定是不行的,效率太低 了,但是要是从进程控制角度来看这种方式是最快的,因为它没有执行进程控制,这是相对于后面讲的方式多进程而言的,啥意思呢,就是说一个公司里面当你只有一个销售员接待客户的时候,我对销售员的管理成本就没有了,当你是多个销售员对应多个客户的时候,虽然这个时候可以同时接待多个客户,但是老板对多个销售员的管理成本也要算进去,上面说的进程控制就是老板对多个销售员的管理。
2.TCP并发服务器程序,每个客户一个子进程
这种方式呢,就是多个进程处理多个连接,每来一个新的连接,就立即创建(fork)一个新的子进程来处理这个连接,这种方式的问题是为每个新连接现场fork一个子进程比较耗费cpu时间,操作系统在fork子进程时要做的事情很多的,首先需要复制父进程的相关数据结构,然后在初始化权限,调度器,文件系统,内存这一系列操作,所以创建一个子进程的开销是很大的,尤其是现在这个时代,繁忙的服务器每天的连接数可以达到数以百万计。
举例来说这种方式就像你作为老板,每接一个项目就创建一个新的子公司,这个子公司的人员,桌椅板凳,各种工具都是新的,项目完成以后该子公司解散。
3.TCP预先派生子进程服务器程序
这种方式就是在启动阶段预先创建多个子进程,当各个客户连接到来时,子进程就可以马上为他们服务,而不是说当客户来的时候在创建好子进程为他们服务,这种方式优点就是没有了父进程fork的开销,缺点就是父进程必须在服务器启动阶段猜测需要预先创建多少子进程,而且父进程还要实时监控进程池中的进程数,当这个数字高于某个阈值时,需要终止多余的进程,当这个数字低于某个阈值时,需要创建新进程。
举例来说:这就像老板预先创建了多个子公司,当来项目时,让创建好的子公司接项目就可以 了,而不是像第二种方式那样,来客户了,你再去创建子公司,但是作为老板你要全局把控,当你发现子公司的数量太多,已经远大于项目的数量,这时候你就要注销掉一部分公司,以节省开销,同样反过来,当你发现接的项目数很多,增长的速度很多,那么你就需要马上在创建几个子公司来处理项目,要不然你的项目就接不到了,就挣不了钱,无法迎娶白富美,走上人生巅峰了。
然后我们再说关于这种方式会发生的一个问题,这个问题就叫做"惊群",啥意思呢,就是说当来了一个新请求时,所有的进程都会被唤醒,但是最后只有一个进程能接到这个请求,这样就会导致性能受损。
举例来说:当没有项目来的时候,所有的子公司都处于放假状态,所有人员都休息了,然后来了一个新的项目,所有的公司都得恢复到上班状态,但是其实到最后只有一个公司能接到这个项目,这样对于其他子公司员工来说是不是有点烦,老子正在放假休息呢,然后你把我召回到了公司还没事情做,让我白跑一趟,交通费食宿费这些都属于浪费掉了,对应到操作系统来说就是性能受损。
4.TCP并发服务器程序,每个客户一个线程
这种方式就是每来一个客户请求,就创建一个线程,创建线程的开销要比创建进程的开销小多了,创建线程就是将各个结构的引用计数加一,创建栈等操作,相对比创建进程来说开销要小很多了,这其实就像公司接项目的时候不是创建子公司,而是创建多个项目组,项目组可以共用公司的各种资源。
这里说一下accept的概念,accept是套接字(socket)中的一个函数,他是用来接收服务器中已完成连接队列里面的连接,也就是服务器会有一个队列专门用来存放已经三次握手完成的tcp连接,当这个队列有数据的时候,调用这个accept函数就会从队列头部拿出一个连接给应用程序处理。
5.TCP预先创建线程服务器程序,每个线程各自accept
这种其实就是服务器启动阶段预先创建线程池,也就是多个线程以取代为每个客户连接现场创建一个线程有性能加速效果,这种做法就像来了一个新项目,只有一个项目组接这个项目,其他项目组还是做原来做的事情。
6.TCP预先创建线程服务器程序,主线程统一accept
这种方式就是在程序启动阶段创建一个线程池之后只让主线程调用accept并把每个客户连接传递给池中某个可用线程,这就像有个所有项目组的总管,他负责接项目,来了项目以后,他去把这个项目分配给可以开发的项目组。
了解更多:https://www.toutiao.com/c/user/83293539887/#mid=1633933053814798
linux如何处理多连接请求?的更多相关文章
- [IB]Integration Broker 是如何处理传入的请求(Part 2)
让我们讨论一下集成代理如何处理传入的请求.可以先阅读(理解PeopleSoft集成代理 Part1). 当PeopleSoft集成代理接收传入请求时,会发生一系列事件. 当侦听连接器(Listenin ...
- Linux系统——ssh-key连接原理
SSH是一种客户端连接,在Linux服务器下通过远程的方式将本地电脑连接到对方的电脑上. 远程连接的方式: (1)telnet命令(为明文传输,不安全) (2)(2)SSH(加密传输,安全) 操作的两 ...
- Netty是如何处理新连接接入事件的?
更多技术分享可关注我 前言 前面的分析从Netty服务端启动过程入手,一路走到了Netty的心脏——NioEventLoop,又总结了Netty的异步API和设计原理,现在回到Netty服务端本身,看 ...
- 推荐:实现RTSP/RTMP/HLS/HTTP协议的轻量级流媒体框架,支持大并发连接请求
推荐一个比较好用的流媒体服务开源代码: ZLMediaKit: 实现RTSP/RTMP/HLS/HTTP协议的轻量级流媒体框架,支持大并发连接请求 https://gitee.com/xiahcu/Z ...
- linux(centos8):firewalld对于请求会选择哪个zone处理?
一,firewalld对一个请求会适用哪个zone? 当接收到一个请求时,firewalld具体使用哪个zone? firewalld是通过三个步骤来判断的: source,即:源地址 interfa ...
- ASP.NET Core应用针对静态文件请求的处理[3]: StaticFileMiddleware中间件如何处理针对文件请求
我们通过<以Web的形式发布静态文件>和<条件请求与区间请求>中的实例演示,以及上面针对条件请求和区间请求的介绍,从提供的功能和特性的角度对这个名为StaticFileMidd ...
- Netruon 理解(11):使用 NAT 将 Linux network namespace 连接外网
学习 Neutron 系列文章: (1)Neutron 所实现的虚拟化网络 (2)Neutron OpenvSwitch + VLAN 虚拟网络 (3)Neutron OpenvSwitch + GR ...
- Netruon 理解(12):使用 Linux bridge 将 Linux network namespace 连接外网
学习 Neutron 系列文章: (1)Neutron 所实现的虚拟化网络 (2)Neutron OpenvSwitch + VLAN 虚拟网络 (3)Neutron OpenvSwitch + GR ...
- Anyconnect的VPN环境部署(2)-在Linux客户机上连接Anyconnect
由于之前已经在机房IDC安装了Anyconnect的VPN服务环境(参考:Anyconnect的VPN环境部署(1)-OpenConnect server(ocserv)服务安装)今天介绍下在linu ...
随机推荐
- Zabbix--03 邮件报警、微信报警
目录 一. 邮件报警 1.定义发件人 2.定义收件人 3.优化告警信息 二. 微信报警 1.查看配置文件里的脚本目录路径 2.将weixin.py放在zabbix特定目录 3.配置发信人 4.配置收信 ...
- IsDate(expression)函数
IsDate 函数 返回 Boolean 值指明某表达式是否可以转换为日期. IsDate(expression) expression 参数可以是任意可被识别为日期和时间的日期表达式或字符串表达式. ...
- bzoj4326: NOIP2015 运输计划(二分+LCA+树上差分)
题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=4326 题目大意:有一颗含有n个顶点的树,每两个点之间有一个边权,现在有m个运输计划,每个 ...
- 北京师范大学第十五届ACM决赛-重现赛D Disdain Chain (规律+组合数学)
链接:https://ac.nowcoder.com/acm/contest/3/D 来源:牛客网 Disdain Chain 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 2621 ...
- GUI学习之三十一—QLabel学习总结
前面所有的控件都是归于输入控件的,下面我们要总结下展示控件的用法.首先要将的就是最常用的QLabel. 一.描述 标签控件(QLabel)提供了文本或图像显示的功能,可以用来显示 普通文本 数字 富 ...
- java代码实现H5页面
public void getH5(HttpServletResponse response){ StringBuffer res=new StringBuffer(); res.append(&qu ...
- 接口测试的一些FAQ
近期在学习接口测试,总会有很多问题,故把前任给的经验做个记录下. 1,测试一条delete接口,delete请求后要检验什么内容: 原来删除有分为:物理删除,删除资源,删除关系,软删除 一般delet ...
- 【GDOI2014模拟】雨天的尾巴
题目 深绘里一直很讨厌雨天. 灼热的天气穿透了前半个夏天,后来一场大雨和随之而来的洪水,浇灭了一切. 虽然深绘里家乡的小村落对洪水有着顽固的抵抗力,但也倒了几座老房子,几棵老树被连 根拔起,以及田地里 ...
- 浙大PAT CCCC L3-015 球队“食物链” ( 搜索 && 剪枝 )
题目链接 题意 : 有 n 个球队,给出主客场胜负图,找出一个序列 1.2.3..... 使得 1 战胜过 2 .2 战胜过 3.3 战胜过 4..... n 战胜过 1 ( 这个序列是 1~n 的其 ...
- 简记特定容器list和forward_list算法
链表类型list和forward_list有独有的sort.merge.remove.reverse和unique,而通用版本的是不能用于这两个类型的,因为所要求的迭代器不同,通用版本需要迭代器支持更 ...