ImageVerifierCode 换一换
格式:DOCX , 页数:13 ,大小:19.33KB ,
资源ID:9640233      下载积分:8 金币
验证码下载
登录下载
邮箱/手机:
图形码:
验证码: 获取验证码
温馨提示:
支付成功后,系统会自动生成账号(用户名为邮箱或者手机号,密码是验证码),方便下次登录下载和查询订单;
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/9640233.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请。


权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4009-655-100;投诉/维权电话:18658249818。

注意事项

本文(性能测试脚本SocketUDP协议.docx)为本站上传会员【w****g】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

性能测试脚本SocketUDP协议.docx

1、一. UDP和Socket通信环节 1.UDP Server程序 1、编写UDP Server程序的环节 (1)使用socket()来建立一个UDP socket,第二个参数为SOCK_DGRAM。 (2)初始化sockaddr_in结构的变量,并赋值。sockaddr_in结构定义: struct sockaddr_in { uint8_t sin_len; sa_family_t sin_family; in_port_t sin_port; struct in_addr sin_addr; char sin_zero[8]; }; 这里使用“08”作为服务程序的端

2、口,使用“INADDR_ANY”作为绑定的IP地址即任何主机上的地址。 (3)使用bind()把上面的socket和定义的IP地址和端口绑定。这里检查bind()是否执行成功,假如有错误就退出。这样可以防止服务程序反复运营的问题。 (4)进入无限循环程序,使用recvfrom()进入等待状态,直到接受到客户程序发送的数据,就解决收到的数据,并向客户程序发送反馈。这里是直接把收到的数据发回给客户程序。 2、udpserv.c程序内容: #include #include #include #incl

3、ude #include #include #define MAXLINE 80 #define SERV_PORT 8888 void do_echo(int sockfd, struct sockaddr *pcliaddr, socklen_t clilen) { int n; socklen_t len; char mesg[MAXLINE]; for(;;) { len = clilen; /* waiting for receive data */ n = recvfro

4、m(sockfd, mesg, MAXLINE, 0, pcliaddr, &len); /* sent data back to client */ sendto(sockfd, mesg, n, 0, pcliaddr, len); } } int main(void) { int sockfd; struct sockaddr_in servaddr, cliaddr; sockfd = socket(AF_INET, SOCK_DGRAM, 0); /* create a socket */ /* init servaddr */ bzero(&ser

5、vaddr, sizeof(servaddr)); servaddr.sin_family = AF_INET; servaddr.sin_addr.s_addr = htonl(INADDR_ANY); servaddr.sin_port = htons(SERV_PORT); /* bind address and port to socket */ if(bind(sockfd, (struct sockaddr *)&servaddr, sizeof(servaddr)) == -1) { perror("bind error"); exit(1); } d

6、o_echo(sockfd, (struct sockaddr *)&cliaddr, sizeof(cliaddr)); return 0; } 2.UDP Client程序 1、编写UDP Client程序的环节 (1)初始化sockaddr_in结构的变量,并赋值。这里使用“8888”作为连接的服务程序的端口,从命令行参数读取IP地址,并且判断IP地址是否符合规定。 (2)使用socket()来建立一个UDP socket,第二个参数为SOCK_DGRAM。 (3)使用connect()来建立与服务程序的连接。与TCP协议不同,UDP的connect()并没有与

7、服务程序三次握手。上面我们说了UDP是非连接的,事实上也可以是连接的。使用连接的UDP,kernel可以直接返回错误信息给用户程序,从而避免由于没有接受到数据而导致调用recvfrom()一直等待下去,看上去仿佛客户程序没有反映同样。 (4)向服务程序发送数据,由于使用连接的UDP,所以使用write()来替代sendto()。这里的数据直接从标准输入读取用户输入。 (5)接受服务程序发回的数据,同样使用read()来替代recvfrom()。 (6)解决接受到的数据,这里是直接输出到标准输出上。 2、udpclient.c程序内容: #include

8、 #include #include #include #include #include #include #include #define MAXLINE 80 #define SERV_PORT 8888 void do_cli(FILE *fp, int sockfd, struct sockaddr *pservaddr, socklen_t servlen) { int n;

9、char sendline[MAXLINE], recvline[MAXLINE + 1]; /* connect to server */ if(connect(sockfd, (struct sockaddr *)pservaddr, servlen) == -1) { perror("connect error"); exit(1); } while(fgets(sendline, MAXLINE, fp) != NULL) { /* read a line and send to server */ write(sockfd, sendline, strle

10、n(sendline)); /* receive data from server */ n = read(sockfd, recvline, MAXLINE); if(n == -1) { perror("read error"); exit(1); } recvline[n] = 0; /* terminate string */ fputs(recvline, stdout); } } int main(int argc, char **argv) { int sockfd; struct sockaddr_in srvaddr; /* check

11、 args */ if(argc != 2) { printf("usage: udpclient \n"); exit(1); } /* init servaddr */ bzero(&servaddr, sizeof(servaddr)); servaddr.sin_family = AF_INET; servaddr.sin_port = htons(SERV_PORT); if(inet_pton(AF_INET, argv[1], &servaddr.sin_addr) <= 0) { printf("[%s] is not a va

12、lid IPaddress\n", argv[1]); exit(1); } sockfd = socket(AF_INET, SOCK_DGRAM, 0); do_cli(stdin, sockfd, (struct sockaddr *)&servaddr, sizeof(servaddr)); return 0; } 运营例子程序 1、编译例子程序 使用如下命令来编译例子程序: gcc -Wall -o udpserv udpserv.c gcc -Wall -o udpclient udpclient.c 编译完毕生成了udpserv和udp

13、client两个可执行程序。 2、运营UDP Server程序 执行./udpserv &命令来启动服务程序。我们可以使用netstat -ln命令来观测服务程序绑定的IP地址和端口,部分输出信息如下: Active Internet connections (only servers) Proto Recv-Q Send-Q Local Address Foreign Address State tcp 0 0 0.0.0.0:32768 0.0.0.0:* LISTEN tcp 0 0 0.0.0.0:111 0.0.0.0:* LISTEN tcp 0 0 0.0.0.

14、0:6000 0.0.0.0:* LISTEN tcp 0 0 127.0.0.1:631 0.0.0.0:* LISTEN udp 0 0 0.0.0.0:32768 0.0.0.0:* udp 0 0 0.0.0.0:8888 0.0.0.0:* udp 0 0 0.0.0.0:111 0.0.0.0:* udp 0 0 0.0.0.0:882 0.0.0.0:* 可以看到udp处有“0.0.0.0:8888”的内容,说明服务程序已经正常运营,可以接受主机上任何IP地址且端口为8888的数据。 假如这时再执行./udpserv &命令,就会看到如下信息: bind erro

15、r: Address already in use 说明已有一个服务程序在运营了。 3、运营UDP Client程序 执行./udpclient 127.0.0.1命令来启动客户程序,使用127.0.0.1来连接服务程序,执行效果如下: Hello, World! Hello, World! this is a test this is a test ^d 输入的数据都对的从服务程序返回了,按ctrl+d可以结束输入,退出程序。 假如服务程序没有启动,而执行客户程序,就会看到如下信息: $ ./udpclient 127.0.0.1 test read error

16、 Connection refused 说明指定的IP地址和端口没有服务程序绑定,客户程序就退出了。这就是使用connect()的好处,注意,这里错误信息是在向服务程序发送数据后收到的,而不是在调用connect()时。假如你使用tcpdump程序来抓包,会发现收到的是ICMP的错误信息。 二. TCP协议与UDP协议特点的比较 1.TCP协议与UDP协议特点的比较 一方面,TCP是一种面向连接的协议,而UDP是无连接的。这其中的区别在于:第一,TCP协议是以连接作为协议数据的最终目的的。UDP协议则是以目的端口作为协议数据的最终目的。因此,TCP的协议端口是可以复用的,UDP协议的

17、端口在批准时间只能为一个应用程序所用。第二,一个连接是由两个端点构成的。要使用TCP进行通信必须先在通信双方之间建立连接,连接的两端必须就连接的一些问题进行协商(如最大数据段长度、窗口大小、初始序列号等),并为该连接分派一定的资源(缓冲区)。UDP协议则不需要这个过程,可以直接发送和接受数据。 另一方面,TCP提供的是可靠的传输服务,而UDP协议提供的是不可靠的服务。使用不可靠的服务进行传输时,数据也许会丢失、失序、反复等。而可靠的服务能保证发送方发送的数据能原样到达接受方。 最后,TCP提供的是面向字节流的服务。应用程序只需将要传输的数据以字节流的形式提交给TCP协议,在连接的另一段,数

18、据以同样的字节流顺序出现在接受程序中。而UDP协议的传输单位是数据块,一个数据块只能封装在一个UDP数据包中。 2.TCP协议与UDP协议应用的比较 由于TCP协议要先建立之后才干进行通信,而连接的建立过程需要一定的时间。所以假如应用程序只有少量数据需要传输则不合用使用TCP协议,由于连接建立的开销大于其方便性的优点。但对于虽然数据量少但需要时间较长且可靠性规定高的应用TCP也是比较适合的。Telnet就是这种应用的例子。 实时应用不管数据量大小,不管对可靠性规定高低都不适合使用TCP协议,由于TCP协议对数据的传输是有先后顺序的,只有前面的传输成功才会开始后面的数据传送。这显然是不符合

19、实时应用的规定的。 此外,由于TCP协议时面向连接的,一个连接必须且只能有两个端点,所以对于多个实体间的多播式应用无法使用TCP进行通信,由于对于n个实体间的通信需要n*(n+1)/2个连接。n很大时连接数太多。 对于不适合使用TCP协议的应用就只能使用UDP协议了。但使用UDP协议进行通信时应用程序必须自己解决下列问题。 (1)应用程序必须自己提供机制来保证可靠性。应用程序必须有自己的超时重发机制、数据失序的解决、流量控制等。当然对于一些可靠性规定不高的应用可以不用这些机制,但通常都需要区分数据的先后关系。 (2)应用程序必须解决大块数据的分割,以让其能封装在一个UDP数据包中。在接

20、受方还必须再将分割的数据进行重组。 TCP协议和UDP协议各有所长、各有所短,合用于不同规定的通信环境。TCP协议和UDP协议之间的比较如下表3所示。 表3 TCP与UDP的比较表 比较项目 TCP UDP 建立的连接与关闭 有 无 数据传输效率 低 高 对数据的确认 有 无 流量控制 有(滑动窗口) 无 丢失分阻的重发 有 无(由高层应用程序负责) 协议复杂性 复杂 简朴 发送端缓冲 有 无 分组排序 有 无 对反复分组的检测 有 无 校验和 有 有(且算发相同)

21、 在低层被分片的情况 也许性小(由于在连接建立时,双方告知各自的MSS,每个TCP报文段的长度不超过MSS) 也许性大(由于应用程序每次输出都产生一个UDP报文,当一次有大量数据要输出时,常在低层被分片) 广播与多播 不支持(由于要建立一对一连接) 支持 适合场合 可靠性规定高,有大量数据要连续传输,该协议在互联网中应用较多 对可靠性规定一般,但规定高效传输数据,或应用于数据传输量小的场合 三.UDP传输协议的实现 为了进一步了解UDP的工作原理,实现数据传输,运用C++语言编一个简朴的聊天的程序,并实现UDP数据传输的功能。其程序如附录。 无连接的数据报传输服务通信

22、时,客户端与服务器端工作流程如下: ●使用WSAStartup()函数检查系统协议栈的安装情况 ●使用socket()函数创建套接口,以拟定协议类型 ●调用bind()函数将创建的套接口与本地地址绑定,拟定本地地址和本地端标语 ●使用sendto()函数发送数据,或者使用recvfrom()函数接受数据 ●使用closesocket()函数关闭套接口 ●调用WSACleanup()函数,结束Windows Sockets API 并且在运营过程中应当注意一下方面: ●通信的一方可以不用bind()绑定地址和端口,由系统分派 ●不绑定IP地址和端标语的一方必须一方面向绑定地址的一方发送数据 ●无连接的应用程序也可以调用connect()函数,但是它并不向对方发出建立连接

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4009-655-100  投诉/维权电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服