计算机基础课件 第8章计算机网络应用程序设计

上传人:woxinch****an2018 文档编号:44952088 上传时间:2018-06-14 格式:PPT 页数:23 大小:181KB
返回 下载 相关 举报
计算机基础课件  第8章计算机网络应用程序设计_第1页
第1页 / 共23页
计算机基础课件  第8章计算机网络应用程序设计_第2页
第2页 / 共23页
计算机基础课件  第8章计算机网络应用程序设计_第3页
第3页 / 共23页
计算机基础课件  第8章计算机网络应用程序设计_第4页
第4页 / 共23页
计算机基础课件  第8章计算机网络应用程序设计_第5页
第5页 / 共23页
点击查看更多>>
资源描述

《计算机基础课件 第8章计算机网络应用程序设计》由会员分享,可在线阅读,更多相关《计算机基础课件 第8章计算机网络应用程序设计(23页珍藏版)》请在金锄头文库上搜索。

1、第章计算机网络应用程序设计 8.1 套接口API的有关概念 8.2 基本Socket函数 8.3 基于TCP的socket程序设计 8.4 基于UDP的socket 程序设计 8.5 输入输出多路复用 8.6 并发服务器程序设计8.1 套接口API的有关概念8.1.1 网络应用编程接口nBerkeley套接口APInWinSockn远程过程调用(RPC)8.1.2 socket编程模型及类型套接口可分如下5种类型:流式套接字、数据报套接字、 原始套接字、SOCK_SEQPACKET及SOCK_RDM。n流式套接字定义了一种可靠的面向连接的服务,实现了无差错的数据传 输。n数据报套接字定义了一种

2、无连接的服务,数据通过相互独立的报文进行 传输,是无序的,并且不保证可靠。n原始套接字允许对低层协议如IP或ICMP直接访问,主要用于新的网络协议实现的测试等。InternetInternet的的SocketSocket编程模型编程模型8.1.3 socket地址应用进程的标识Internet上两台主机种的进程间要进行通信,必须能 够互相识别。用于标识进程的信息有两个:n主机名或主机地址n主机内部标识进程的标识符这两部分合在一起,成为套接口地址(计算机通信的基础 构筑块 )8.1.4 通信进程的阻塞和非阻塞方式对于运行状态中的进程来说,当某些条件不具备, 如输入输出条件还没有准备好时,该进程可

3、以有两种处理方 式:阻塞与非阻塞。n阻塞方式 在阻塞方式下,当输入输出条件还没有准备好时,就将进程 转入阻塞状态,标记阻塞原因,并保留当前进程现场信息, 然后将控制转入进程调度程序,等阻塞原因解除后,将进程 状态由阻塞变成就绪等待处理机,或直接获得由调度程序再 次分配的处理机,恢复阻塞的现场继续执行。n非阻塞方式 在非阻塞方式下,当输入输出条件还没有准备好时,进程仍 处于运行状态,通过循环,反复进行某条件的查询。一般说 来,阻塞机制可以防止进程在循环反复的查询等待中造成资 源浪费。但是有时在应用中需要进程一直处于运行状态,不希望进程在对socket的操作中阻塞,这时就要使用非阻塞机 制。 8.

4、2 基本Socket函数8.2.1 初始化套接口服务绑定socket() 1、功能:在应用程序中使用插口API时,首先要创建一个插口-socket。为 了说明什么是socket,可以打个比方:一个电话插座,既可以接电话机打 电话,也可以接传真机发传真,还可以接计算机上网。接上什么设备, 就是绑定了什么服务。创建一个插口,就是创建一个通信,需要指定提 供什么服务,即为一个标识符绑定某个服务,并为之分配资源。这个标 识就是该插口标识。n应用程序调用socket()函数将创建一个插口。 2、原型8.2.2 本地地址绑定bind() 1、功能 调用函数bind(),可以将本地地址与插口绑定在一起。调

5、用成功时,返回0;否则,返回1,并设置全局变量errno为错误类型 2、原型参数说明 sockfd是函数socket返回的插口描述字; myaddr是特定于协议的地址结构体的指针,指向本地插口地址; addrlen是插口地址结构体的长度。 8.2.3 建立套接口连接绑定远程服务器地址connect()n功能 函数connect()可以让客户机程序建立一个与TCP服务器的连 接. n原型 参数: sockfd是函数socket返回的插口描述符; servaddr指定远程服务器的插口地址; addrlen是插口地址结构体的长度。 8.2.4 套接口被动转换listen()n函数listen()有两

6、个功能。 (1)主动插口的被动转换 socket()创建的插口都是主动插口,只可以用来(调用connect())进行主动连接(发出请求 ),不能接收连接请求。listen()函数将未连接的主动插口转换为被动插口,即倾听插口( listening socket),告诉操作系统该插口可以接收连接请求。所以listen()也称为创建倾听 插口函数。 (2)设置最大请求连接数 listen()用一个参数(backlog)指定完成队列的最大长度。如果一个客户机的SYN数据段到 达时,倾听插口的完成队列已经满了,TCP则忽略这个SYN数据段。 listen()函数执行成功,返回0,服务器的TCP状态由CL

7、OSED转变成LISTEN,成为被动模 式;执行失败,返回1。n 原型参数: sockfd为要转换的已绑定本地地址的插口描述符; backlog设置请求队列的最大长度,表示被动(倾听)插口能够接收 的最大数目的未接收连接(相当于窗口通告)。 8.2.4 套接口被动转换listen()n创建TCP服务器倾听插口的过程 (1)首先调用socket()函数创建一个主动插口; (2)调用bind()函数进行插口地址绑定; (3)调用listen()函数进行转换。 8.2.5 从被动套接口的完成队列中接受一个连 接请求accept()n功能 一个插口被创建、用bind绑定本地地址并转换成被动模式后,必须

8、接收 一个连接请求。一旦接收了连接,服务器就能使用该连接与客户机进行 通信。面向连接传输协议的服务器调用 accept从被动(倾听)插口的完 成连接队列中接收下一个连接请求。如果该完成连接队列空,则使这个 进程睡眠。n原型参数: sockfd为服务器已经创建并绑定到指定插口地址的插口描述符; addr是指向一个Internet插口地址结构体的指针; addrlen是指向一个整型数的指针。 8.2.5 从被动套接口的完成队列中接受 一个连接请求accept()naccept()工作过程TCP使用侦听插口接收客户机的连接请求。如果 调用accept()时,倾听插口的完成队列中有已经完成 3次握手的

9、TCP连接,accept()就从队列的首部读取第 一个连接,并返回该连接的描述符。如果调用 accept()时,倾听插口的完成队列为空,进程将阻塞 ,等待出现新的完成3次握手的TCP连接送到完成队 列;TCP协议为服务器创建一个新的连接插口来标 识这条新的连接,accept()返回该新连接的描述符。 8.2.6 基本套接口I/O函数列表8.2.7 关闭插口通道与撤消套接口 1、概述 建立一对插口的连接之后,就可以进行通信了。由于TCP连接是全双工 的,对每一个套接口来说,都可以看作在使用读、写两个通道进行通信 。于是,关闭一个插口通信可以有两种不同级别的方法。(1)关闭插口通道,具体有三种方式

10、: SHUT_RD关闭连接的读通道; SHUT_WR关闭连接的写通道; SHUT_RDWR关闭连接的读写通道。 (2)撤消套接口(句柄),同时关闭了连接的读写 通道。这两种方式分别用两个不同的函数shutdown()和close()实现。 2. close()原型 函数close()用于撤消一个插口,终止其TCP连接, 其原型为 #include in close (int sockfd) 3. shutdown()原型 #include int shutdown (int sockfd, int howto); 8.3 基于TCP的socket程序设计8.3.1 TCP有限状态机 1、TCP

11、有限状态机的概念 在网络通信中,一个健壮的插口应用程序必 须能够处理通信过程中可能出现的各种状态。对于 TCP来说,不同的状态将决定传输实体对一些事件 的响应。描述TCP在响应各种事件时,各个宏观状 态之间相互作用的规则称为TCP有限状态机(或称 TCP状态转换图),它由图所示的11种状态组成。TCPTCP的有限状态机的有限状态机2、状态转换分析 (1) 客户进程发起连接的状态转换过程n 一个主机的客户进程要发起连接,其TCP实体就发一个 SYN置1的分组 由CLOSED状态进入SYN_SENT状态。n 收到来自进程的SYN和ACK,TCP就发出三次握手中的 最后一个ACK 进入ESTABLI

12、SHED状态。这时就可以收发 数据了。 (2) 客户进程发起断连请求(主动关闭)的状态转换过程n 客户进程要发起断连,其TCP实体就发一个SYN置1的 分组,等待确认ACK的到达 由ESTABLISHED状态变为 FIN_WAIT_1状态。n 运行客户进程的主机收到确认ACK,一个方向的连接关 闭 进入FIN_WAIT_2状态。n 运行客户进程的主机收到运行服务器的主机发送的FIN 置1的分组后,应响应确认ACK。n 收到确认ACK,连接不是立即进入到关闭CLOSED, 而是先进入TIME_WAIT状态。n TCP在TIME_WAIT状态等待2MSL(MSL表示分组在 网络中的寿命),才删除原

13、来建立的连接记录 返回 CLOSED状态。 8.3.2 TCP的C/S模型时序图 面向连接的C/S模型的典型时序图说明:服务器必须 首先启动,直到它执行accept()调用,进入等待状态,方 可接收客户机请求。否则,客户机的connect()调用将返回出 错代码,连接宣告失败。 面向连接的C/S模型的典型时序图 面向连接服务器处理的请求C/S模型工作过程: n 服务进程首先调用socket( )创建一个字节流套接字 ,并调用bind( )将服务器地址捆扎在该套接字上,接着 调用listen( )监听连接请求,随后调用accept( )做好与客 户进程建立连接的准备,无连接请求时,服务进程被 阻

14、塞。当连接请求到来后,服务器进程被唤醒,建立 一个新的Socket,并用新套接字同客户进程的套接字建 立连接,而服务进程最早生成的套接字则继续用于监 听网络上的服务请求。n 客户进程调用socket( )创建字节流套接字,然后调 用connect( )向服务进程发出连接请求。n 服务进程和客户进程通过调用read( )/recv( )和 Write( )/send( )交换数据。 8.4 基于UDP的socket 程序设计 8.4.1 UDP编程模式 UDP提供不保证顺序的用户数据报传输服务。在比较 简单的应用中,客户机常常只用单个UDP报文来发送请求, 服务器也用单个报文回送应答。这种情况下

15、,UDP服务器和 客户机间的交互程序采用循环结构是非常有利的。图表明了 这种处理结构。 图 采用循环结构的UDP服务器与客户机间的交互 8.5 输入输出多路复用n输入输出多路复用基本工作原理:输入输出多路复用是一种特殊的阻塞式 输入输出模式,其特点:用select()调用指示内 核监视多路流事件,当一个或多个事件发生 或经过某个指定时间后,就唤醒进程,就绪 的套接口描述符可以进行相应的输入输出操 作。8.6 并发服务器程序设计n多进程并发服务器的基本工作原理:在多进程模式下,使用多个进程来处理 不同客户的请求。一开始,只运行一个服务 进程,用来侦听是否有客户的连接到来。每 当该服务进程接收接收到一个连接请求时, 就调用fork()函数生产一个子进程,让该子进 程处理到来的请求,父进程继续侦听还有无 其他客户的连接请求。谢谢 大家

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 中学教育 > 高中教育

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号