您当前的位置: 首页 > 

风间琉璃•

暂无认证

  • 4浏览

    0关注

    337博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

客户端/服务端软件概述

风间琉璃• 发布时间:2021-10-16 17:44:18 ,浏览量:4

文章目录
  • 前言
  • 一、客户端基本功能
    • 1.解析服务器IP地址
    • 2.解析服务器端口号
    • 3.解析协议号
  • 二、客户端实现
    • 1.TCP客户端软件流程
    • 2.UDP客户端软件流程
  • 三、服务器软件设计
    • 1.循环无连接(Iterative connectionless)服务器
    • 2.循环面向连接(Iterative connection-oriented)服务器
    • 3.并发无连接(Concurrent connectionless)服务器
    • 4.并发面向连接(Concurrent connection-oriented)服务器
  • 总结

提示:以下是本篇文章正文内容

一、客户端基本功能 1.解析服务器IP地址

客户端可能使用域名(如:study.163.com)或IP地址(如: 123.58.180.121)标识服务器,但是, IP协议需要使用32位二进制IP地址,

(1)函数inet_addr( ) 实现点分十进制IP地址到32位IP地址转换

(2)函数gethostbyname( ) 实现域名到32位IP地址转换,返回一个指向结构hostent 的指针

hostent结构体:包含32位IP地址

struct hostent 
{
	char FAR* h_name; /*official host name */
	char FAR* FAR* h_aliases; /*other aliases */
	short h_addrtype; /*address type */
	short h_lengty; /*address length */
	char FAR* FAR* h_addr_list; /*list of address */
};
#define h_addr h_addr_list[0]
2.解析服务器端口号

客户端还可能使用服务名(如HTTP)标识服务器端口,需要将服务名转换为熟知端口号

通过调用函数getservbyname( ) ,返回一个指向结构servent的指针

servent结构体:包含端口号

struct servent
{
	char FAR* s_name; /*official service name */
	char FAR* FAR* s_aliases; /*other aliases */
	short s_port; /*port for this service */
	char FAR* s_proto; /*protocol to use */
};
3.解析协议号

客户端可能使用协议名(如:TCP)指定协议,需要将协议名转换为协议号(如: 6)

通过调用函数getprotobyname ( ) 实现协议名到协议号的转换,返回一个指向结构protoent的指针

protoent结构体:包含协议号

struct protoent 
{
	char FAR* p_name; /*official protocol name*/
	char FAR* FAR* p_aliases; /*list of aliases allowed*/
	short p_proto; /*official protocol number*/
};
二、客户端实现 1.TCP客户端软件流程

1.确定服务器IP地址与端口号 2.创建套接字 3.分配本地端点地址(IP地址+端口号) 4.连接服务器(套接字) 5.遵循应用层协议进行通信 6.关闭/释放连接

2.UDP客户端软件流程

1.确定服务器IP地址与端口号 2.创建套接字 3.分配本地端点地址(IP地址+端口号) 4.指定服务器端点地址,构造UDP数据报 5.遵循应用层协议进行通信 6.关闭/释放套接字

三、服务器软件设计 1.循环无连接(Iterative connectionless)服务器

循环这里是指一次只处理一个,处理完后,接着处理下一个

软件流程:

1.创建套接字 2.绑定端点地址(INADDR_ANY+端口号) 3.反复接收来自客户端的请求 4.遵循应用层协议,构造响应报文,发送给客户

数据发送:服务器端不能使用connect()函数,无连接服务器使用sendto()函数发送数据报 在这里插入图片描述 获取客户端点地址:调用recvfrom()函数接收数据时,自动提取 在这里插入图片描述

2.循环面向连接(Iterative connection-oriented)服务器

设计流程:

1.创建(主)套接字,并绑定熟知端口号; 2.设置(主)套接字为被动监听模式,准备用于服务器; 3.调用accept()函数接收下一个连接请求(通过主套接字),创建新套接字用于与该客户建立连接; 4.遵循应用层协议,反复接收客户请求,构造并发送响应(通过新套接字); 5.完成为特定客户服务后,关闭与该客户之间的连接,返回步骤3.

3.并发无连接(Concurrent connectionless)服务器

设计流程:

主线程1: 创建套接字,并绑定熟知端口号; 主线程2: 反复调用recvfrom()函数,接收下一个客户请求,并创建新线程处理该客户响应; 子线程1: 接收一个特定请求; 子线程2: 依据应用层协议构造响应报文,并调用sendto()发送; 子线程3: 退出(一个子线程处理一个请求后即终止)。

4.并发面向连接(Concurrent connection-oriented)服务器

设计流程:

主线程1: 创建(主)套接字,并绑定熟知端口号; 主线程2: 设置(主)套接字为被动监听模式,准备用于服务器; 主线程3: 反复调用accept()函数接收下一个连接请求(通过主套接字),并创建一个新的子线程处理该客户响应; 子线程1: 接收一个客户的服务请求(通过新创建的套接字); 子线程2: 遵循应用层协议与特定客户进行交互; 子线程3: 关闭/释放连接并退出(线程终止) .

关注
打赏
1665385461
查看更多评论
立即登录/注册

微信扫码登录

0.0371s