计算机科学与技术系
实验(项目)报告
一、基本信息
二、目的与要求
目的:
通过实验掌握并发服务器与客户端进行通信的功能。
要求:
1.Linux 下项目开发工具;
2. 命令行参数;
3. 客户端文件名字定为为当前时间;
4. 对关键函数或系统调用要进行必要的错误判断处理;
5. 进程、线程;
6. 客户端将接收到的数据写入文件;
7. 进程间通信
三、完成实验(项目)过程和效果
内容:
1. 程序结构设计;
2. 程序数据设计;
3. 程序基本流程。
4. 编码、测试
图1.1 程序调试
步骤:
1. 程序结构设计
1) 采用流式套接字,即TCP 套接字。保证数据的可靠性。
图1.2 TCP套接字传输过程
2) 采用多进程或多线程方式处理客户端问题。(服务器可能要处理多个客户请求)
2. 程序数据设计
1) 服务器端:
根据套接字编程过程,需定义以下数据:
监听套接字描述符、连接套接字描述符
int listenfd , connfd;
服务器端地址结构
struct sockaddr_in server;
struct sockaddr_in client;
客户端地址结构:
进程/线程ID :pid_t pid;
接收数据缓冲区/发送数据缓冲区等
char recvbuf[MAXDATASIZE],//接收数据缓冲区
sendbuf[MAXDATASIZE],//发送数据缓冲区
cli_name[MAXDATASIZE];//保存客户端的名字
2) 客户端:
套接字描述符:int sockfd;
服务器端地址结构
struct sockaddr_in server; char sendline[MAXDATASIZE],//sendline是接收数据缓冲区 recvline[MAXDATASIZE],//recvline是接收数据缓冲区 char cname[30];//保存用户输入的名字 char wtext[100];//保存需要写入文件的数据 time_t t1;//保存当前时间 struct tm *t2;//当前时间的结构体形式
int fd;//文件描述符
2. 程序结构基本流程。 接收数据/发送数据缓冲区 保存日志信息的数据。
图1.3 服务器端程序流程图
图1.4 客户端程序流程图
四、知识应用
1. 实现两个客户端通过服务器进行通信的功能。
(1)如果只是两个客户端和一个服务器,可通过服务器转发即可,两个客户端连接到服务器,服务器把从A 接收到的发给B ,把从B 接收到的发给A 即可;
(2)如果要做成多个客户端的,则要给各个客户端分配ID ,服务端好根据各个客户端和消息要转发送给客户端的ID 来确定消息发送对象。服务端给各个客户端分配一个独立不重复的ID ,在客户端登陆时根据认证参数来查找ID 。客户端发送消息时要指定客户端的一个独立身份信息,可以是ID ,也可以是其他,服务端可以通过查询来获取ID 以及客户端当前是否连接上等来对客户端发送的消息进行响应或者存储等客户端上线后再转发。
五、总结
本门课大概就是这个框架,总的来说,对于最后几章的内容很有兴趣,特别是最后几个实验,通过自己摸摸索索,自己慢慢折腾,好像找到了一点感觉,linux 可以实现的功能很强大,我发现,还是得自己去折腾,才能学到属于自己的,可以实践,运用的东西,希望自己的学习道路越来越长吧!
计算机科学与技术系
实验(项目)报告
一、基本信息
二、目的与要求
目的:
通过实验掌握并发服务器与客户端进行通信的功能。
要求:
1.Linux 下项目开发工具;
2. 命令行参数;
3. 客户端文件名字定为为当前时间;
4. 对关键函数或系统调用要进行必要的错误判断处理;
5. 进程、线程;
6. 客户端将接收到的数据写入文件;
7. 进程间通信
三、完成实验(项目)过程和效果
内容:
1. 程序结构设计;
2. 程序数据设计;
3. 程序基本流程。
4. 编码、测试
图1.1 程序调试
步骤:
1. 程序结构设计
1) 采用流式套接字,即TCP 套接字。保证数据的可靠性。
图1.2 TCP套接字传输过程
2) 采用多进程或多线程方式处理客户端问题。(服务器可能要处理多个客户请求)
2. 程序数据设计
1) 服务器端:
根据套接字编程过程,需定义以下数据:
监听套接字描述符、连接套接字描述符
int listenfd , connfd;
服务器端地址结构
struct sockaddr_in server;
struct sockaddr_in client;
客户端地址结构:
进程/线程ID :pid_t pid;
接收数据缓冲区/发送数据缓冲区等
char recvbuf[MAXDATASIZE],//接收数据缓冲区
sendbuf[MAXDATASIZE],//发送数据缓冲区
cli_name[MAXDATASIZE];//保存客户端的名字
2) 客户端:
套接字描述符:int sockfd;
服务器端地址结构
struct sockaddr_in server; char sendline[MAXDATASIZE],//sendline是接收数据缓冲区 recvline[MAXDATASIZE],//recvline是接收数据缓冲区 char cname[30];//保存用户输入的名字 char wtext[100];//保存需要写入文件的数据 time_t t1;//保存当前时间 struct tm *t2;//当前时间的结构体形式
int fd;//文件描述符
2. 程序结构基本流程。 接收数据/发送数据缓冲区 保存日志信息的数据。
图1.3 服务器端程序流程图
图1.4 客户端程序流程图
四、知识应用
1. 实现两个客户端通过服务器进行通信的功能。
(1)如果只是两个客户端和一个服务器,可通过服务器转发即可,两个客户端连接到服务器,服务器把从A 接收到的发给B ,把从B 接收到的发给A 即可;
(2)如果要做成多个客户端的,则要给各个客户端分配ID ,服务端好根据各个客户端和消息要转发送给客户端的ID 来确定消息发送对象。服务端给各个客户端分配一个独立不重复的ID ,在客户端登陆时根据认证参数来查找ID 。客户端发送消息时要指定客户端的一个独立身份信息,可以是ID ,也可以是其他,服务端可以通过查询来获取ID 以及客户端当前是否连接上等来对客户端发送的消息进行响应或者存储等客户端上线后再转发。
五、总结
本门课大概就是这个框架,总的来说,对于最后几章的内容很有兴趣,特别是最后几个实验,通过自己摸摸索索,自己慢慢折腾,好像找到了一点感觉,linux 可以实现的功能很强大,我发现,还是得自己去折腾,才能学到属于自己的,可以实践,运用的东西,希望自己的学习道路越来越长吧!