网站大量收购独家精品文档,联系QQ:2885784924

循环和并发服务比较及应用.docVIP

  1. 1、本文档共11页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
循环和并发服务比较及应用

循环和并发服务比较及应用   摘要:该文比较详细地介绍了循环和并发服务器的概念、工作原理及循环和并发服务器的算法,从工作原理、工作流程等方面进行阐述两者的区别,并分别用一个循环服务器程序和并发服务器程序实例代码加以说明。   关键词:循环服务器;并发服务器;算法;应用   中图分类号:TP311 文献标识码:A 文章编号:1009-3044(2012)32-7706-04   1 循环和并发服务器的概念   网络服务器有循环服务器和并发服务器两种。循环服务器:循环服务器在同一个时刻只可以响应一个客户端的请求;并发服务器:并发服务器在同一个时刻可以响应多个客户端的请求 。   网络服务器有循环服务器和并发服务器两种。连接性问题是传输协议的中心,而客户使用这个传输协议访问某个服务器。TCP/IP协议族给用提供了两种传输协议,可以使用面向连接的传输(TCP)或无连接的传输(UDP)。因??,可以将服务器划分为四种一般的类型:循环无连接、循环面向连接、并发无连接、并发面向连接。   2 循环和并发服务的工作原理   2.1循环服务器的工作原理及及流程   1)循环无连接(UDP)的服务器的工作原理及应用范围   循环无连接的服务器的算法   ① 创建套接字并将其绑定到所提供服务的熟知端口上。   ② 重复地读取来自客户的请求,构造响应,按照应用协议向客户发回响应。   UDP循环服务器的实现非常简单:UDP服务器每次从套接字上读取一个客户端的请求,处理, 然后将结果返回给客户机.   可以用下面的算法来实现.   socket(...);   bind(...);   while(1)   {   recvfrom(...);   process(...);   sendto(...);   }   因为UDP是非面向连接的,没有一个客户端可以老是占住服务端. 只要处理过程不是死循环, 服务器对于每一个客户机的请求总是能够满足.   2)循环面向连接(TCP)的服务器的工作原理及应用范围   循环面向连接的服务器的算法   ① 创建套接字并将其绑定到它所提供服务的熟知端口上。   ② 将该端口设置为被动模式,使其准备为服务器所用。   ③ 从该套接字上接受下一个连接请求,获得该连接的新的套接字。   ④ 重复地读取来自客户的请求,构造响应,按照应用协议向客户发回响应。   ⑤ 当与某个特定客户完成交互时,关闭连接,并返回步骤3以接受新的连接。   TCP循环服务器的实现也不难:TCP服务器接受一个客户端的连接,然后处理,完成了这个客户的所有请求后,断开连接。   算法如下:   socket(...);   bind(...);   listen(...);   while(1)   {   accept(...);   while(1)   {   read(...);   process(...);   write(...);   }   close(...);   }   TCP循环服务器一次只能处理一个客户端的请求.只有在这个客户的所有请求都满足后, 服务器才可以继续后面的请求.这样如果有一个客户端占住服务器不放时,其它的客户机都不能工作了.因此,TCP服务器一般很少用循环服务器模型的.   2.2并发服务器的工作原理及应用范围   1)并发面向连接(TCP)的服务器的工作原理及应用范围   并发服务器:TCP服务器   为了弥补循环TCP服务器的缺陷,人们又想出了并发服务器的模型. 并发服务器的思想是每一个客户机的请求并不由服务器直接处理,而是服务器创建一个 子进程来处理.   算法如下:   socket(...);   bind(...);   listen(...);   while(1)   {   accept(...);   if(fork(..)==0)   {   while(1)   {   read(...);   process(...);   write(...);   }   close(...);   exit(...);   }   close(...);   }   TCP并发服务器可以解决TCP循环服务器客户机独占服务器的情况. 不过也同时带来了一个不小的问题.为了响应客户机的请求,服务器要创建子进程来处理. 而创建子进程是一种非常消耗资源的操作.   2)并发无连接的服务器的工作原理及应用范围   不同于顺序服务器,并发服务器就要能在一个时间为多个客户端提供服务。 例如,一个聊天服务器可能服务一个特定的客户端数小时 ──在停止为这个客户端服务

文档评论(0)

317960162 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档