- 1、本文档共11页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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)并发无连接的服务器的工作原理及应用范围
不同于顺序服务器,并发服务器就要能在一个时间为多个客户端提供服务。 例如,一个聊天服务器可能服务一个特定的客户端数小时 ──在停止为这个客户端服务
您可能关注的文档
最近下载
- 2025年湖北省襄阳市襄阳四中学初三下学期四月调考化学试题含解析.doc VIP
- GBT 42706.1-2023 电子元器件 半导体器件长期贮存 第1部分:总则.doc
- 2018人教版七年级数学下册练习:期末达标检测卷.docx VIP
- AC-25厂拌热再生沥青混凝土试验段施工方案.doc
- 行业联盟与竞争格局演变-深度研究.pptx
- 2024-2025学年北京西城区九年级初三(上)期末道德与法治试卷(含答案).pdf
- 2025年山东省枣庄市滕州市高三二模物理试卷及答案.docx
- 第九章 压强和浮力(知识清单)【教师版】.docx VIP
- 2025保安员理论考试100题(附答案) .pdf VIP
- 2022年三级教育测试题.docx
文档评论(0)