网络通信编程实验报告.docVIP

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

网络通信编程实验报告 网络编程实验报告 网络编程 课程设计报告 题目: 姓名: 学院: 专业: 班级: 学号: 指导教师:基于Linux网络聊天室的设计陈佳悦 陈雄兰信息科学技术学院 网络工程 网络工程10219310214 薛 卫 职称:副教授 基于Linux网络聊天室的设计 摘要:本课程设计是在Linux环境下基于Socket进行开发的。系统服务器端和客户端组成。服务端程序通过共享存储区存储聊天数据,并发送给每个连接的客户端。通过多路复用的子进程实现服务端与多个客户端之间的数据发送与接收。可以在单机上开辟两个窗口分别运行客户、服务器的程序。本方案经gcc调试器调试成功,可以在机网络聊天中使用。 关键词:网络聊天;linux ;socket 1.相关概念及技术 1.1 网络套接字编程 1.1.1套接字基本概念 套接字是通信的基石,是支持TCP/IP协议的网络通信的基本操作单元。可以将套接字看作不同主机间的进程进行双向通信的端点,它构成了单个主机内及整个网络间的编程界面。套接字存在于通信域中,通信域是为了处理一般的线程通过套接字通信而引进的一种抽象概念。套接字通常和同一个域中的套接字交换数据(数据交换也可能穿越域的界限,但这时一定要执行某种解释程序)。各种进程使用这个相同的域互相之间用Internet协议簇来进行通信。 1.1.2 套接字工作原理 要通过互联网进行通信,你至少需要一对套接字,其中一个运行于客户机端,我们称之为ClientSocket,另一个运行于服务器端,我们称之为ServerSocket。根据连接启动的方式以及本地套接字要连接的目标,套接字之间的连接过程可以分为三个步骤:服务器监听,客户端请求,连接确认。 所谓服务器监听,是服务器端套接字并不定位具体的客户端套接字,而是处于等待连接的状态,实时监控网络状态。 所谓客户端请求,是指由客户端的套接字提出连接请求,要连接的目标是服务器端的套接字。为此,客户端的套接字必须首先描述它要连接的服务器的套接字,指出服务器端套接字的地址和端口号,然后就向服务器端套接字提出连接请求。 所谓连接确认,是指当服务器端套接字监听到或者说接收到客户端套接字的连接请求,它就响应客户端套接字的请求,建立一个新的线程,把服务器端套接 字的描述发给客户端,一旦客户端确认了此描述,连接就建立好了。而服务器端套接字继续处于监听状态,继续接收其他客户端套接字的连接请求。 1.1.3 linux中socket的基本应用: 服务端建立套接字的大致步骤: (1)建立socket。 (2)bindPort 绑定特定的端口。 (3)listen 监听特定的端口。 (4)accept,当有客户端连接服务器端口时,accept接收信息,并返回新的套接字描述符,提供给操作 (5)根据实际需求,write,read,send,recv等操作 (6)关闭套接字。 客户端大致步骤: 1)创建socket. 2)根据服务器地址,connect连接到特定服务器。 3)write,read等读写操作。 4)关闭套接字。 1.2 客户/服务器模型 应用程序之间为了能顺利地进行通信,一方通常需要处于守候状态,等待另一方请求的到来。在分布式计算中,一个应用程序被动地等待,而另一个应用程序通过请求启动通信的模式就是客户/服务器模式。 客户/服务器模型的典型运行过程包括五个主要步骤: (1)服务器监听相应窗口的输入。 (2)客户机发出请求。 (3)服务器接收到此请求。 (4)服务器处理此请求,并将结果返回给客户机。 (5)重复上述过程,直至完成一次会话过程任务。 运作过程如下: 1.3 多路复用技术 多路复用一般有以下几种技术: (1) 非阻塞通信技术: 将文件管道设为非阻塞通信方式, 每隔一段时间对他们实行一次轮询, 以判断是否可以进行读写操作。 (2)信号驱动的异步I/O 技术。首先, 异步I/O 是基于信号机制的, 并不可靠。其次, 单一的信号不足以提供更多的信息来源。还是需要辅助以其他的手段, 实现有很高的难度。 (3)select()技术。在BSD 中提供了一种可以对多路I/O 进行阻塞式查询的方法—select()。它提供同时对多个I/O 描述符进行阻塞式查询的方法。 (4) 子进程技术。应用多个子进程, 每一个对一个单工阻塞方式通信。所有子进程通过IPC 和父进程进行通信。父进程掌管所有信息。该聊天室即采用此种子进程技术。 1.4相关函数调用 (1) Socket() 作用:socket函数为客户机或服务器创建一个sokcet 格式: int socket(int family,int t

文档评论(0)

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

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

1亿VIP精品文档

相关文档