- 1、本文档共6页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
福州大学网络程序设计考试随堂习题答案
socket()、bind()、connect()、listen()、accept()、close()在套接口编程中的作用各是什么?
socket():执行网络通信,进程调用socket函数,指定期望的通信协议
bind():将一个本地协议地址赋予一个套接口
connect():TCP客户端与服务器建立连接用connect函数
connect的三种出错返回
[1] 若TCP客户没有收到SYN分节的响应(ACK)——返回ETIMEOUT错误
[2] 若对客户的SYN响应是RST,则表示该服务器主机在指定端口上没有进程在等 待与之连接
[3]称为硬错(hard error),客户收到RST立即返回
ECONNREFUSED错误
listen():监听端口:
未连接的套接口 -- 被动套接口
内核应该接收指向该套接口的连接请求
套接口状态:CLOSED -- LISTEN
服务端在socket和bind后,accept前调用
accept(): TCP服务器调用
从已完成连接队列头返回下一个已完成连接
已完成队列为空,则进程睡眠
close():用来关闭套接口,终止TCP连接
Ping程序、Traceroute程序和ICMP消息守护程序的工作原理。
ping程序的工作原理是:向网络上的另一个主机系统发送ICMP报文,如果指定系统得到了报文,它将把报文一模一样地传回给发送者.
Traceroute程序工作原理
1、向目的地发送一个TTL为1的UDP数据报2、该数据报导致第一跳路由返送一个ICMP错误3、每递增TTL一次发送一个UDP数据报,逐步确定下一跳路由器
4、当UDP数据报(TTL增加到一定大小后)到达最终目的地时,目标主机返送一个ICMP错误ICMP消息守护程序工作原理
1、UDP应用程序使用Unix域套接口的描述字传递机制,通过Unix域连接把自身的UDP套接口传递给icmpd共享
2、icmpd得到该套接口的拷贝后通过getsockname获取绑定在此套接口上的端口号,随即关闭该套接口的本地拷贝
3、icmpd一旦收到了由UDP应用进程通过绑定在它的UDP套接口上的端口发送的UDP数据报所引发的任何ICMP错误,就可以通过Unix域连接向该应用进程发送一个消息
4、UDP应用进程需要使用多路复用方式等待其UDP套接口和Unix域套接口中任何一个有数据到达而变为可读
CS模式下,循环服务器和并发服务器分别是什么,它们的特点和异同是什么?分别描述TCP协议和UDP协议下两种服务器的流程,可绘制流程图。
1、重复服务器(iterative server),也称循环服务器
在同一个时刻只可以响应一个客户端的请求。这种服务器上的进程能够预知在短时间内可以处理完请求,便亲自处理它。例如,典型的服务是通报时间。
并发服务器(concurrent server)
在同一个时刻可以响应多个客户端的请求。这种服务器上的进程事先不能预知完成服务请求需要花多长时间,便以并发的方式处理它。
并发服务器通过激活别的进程来完成服务请求,而本身转入睡眠状态以等待另一个请求的到来。典型的服务是处理文件信息,例如对文件的访问和打印文件。
UDP循环服务器: TCP并发服务器
基本流程:
创建侦听套接口,等待客户机的请求
接受到一个客户机请求时,创建一个子进程
子进程进行数据处理
父进程继续等待新的客户机请求
什么是信号驱动IO?其特点是什么?基本流程是如何的?
信号驱动I/O模型:内核在描述字就绪时,发送SIGIO信号通知进程
特点:等待数据报期间,进程不被阻塞
信号驱动I/O模型的步骤:
1、设置信号捕获函数
2、调用函数fcntl,设置套接口属主(F_SETOWN选项)
3、启动信号驱动I/O方式
调用函数ioctl的FIOASYNC选项
或调用函数fcntl,用命令F_SETFL命令打开O_ASYNC标志
什么是守护进程?inetd守护进程的工作原理。
守护进程的特征:
1、所有守护进程都以超级用户优先权运行。
2
文档评论(0)