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并把每个客户连接传递给池中某个可用线程,这就像有个所有项目组的总管,他负责接项目,来了项目以后,他去把这个项目分配给可以开发的项目组。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,921评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,635评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,393评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,836评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,833评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,685评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,043评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,694评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,671评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,670评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,779评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,424评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,027评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,984评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,214评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,108评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,517评论 2 343

推荐阅读更多精彩内容

  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,084评论 1 32
  • 一. 操作系统概念 操作系统位于底层硬件与应用软件之间的一层.工作方式: 向下管理硬件,向上提供接口.操作系统进行...
    月亮是我踢弯得阅读 5,950评论 3 28
  • 第一章 引言和网络编程基础知识 1.1 分别简述OSI参考模型和TCP/IP模型,并阐述他们之间的对应关系 1.2...
    V0W阅读 5,294评论 0 9
  • 一、简历准备 1、个人技能 (1)自定义控件、UI设计、常用动画特效 自定义控件 ①为什么要自定义控件? Andr...
    lucas777阅读 5,186评论 2 54
  • ORA-00001: 违反唯一约束条件 (.) 错误说明:当在唯一索引所对应的列上键入重复值时,会触发此异常。 O...
    我想起个好名字阅读 5,169评论 0 9