基于多播的以太网文件传送协议的设计与实现

文件传输  时间:2021-01-12  阅读:()

张昆朋1,吕延庆1,谢华成2洛阳师范学院信息技术学院,河南洛阳471022信阳师范学院网络信息与计算中心,河南信阳464000通讯作者邮箱keyban@163.
com摘要:将文件数据从一台主机复制到多台主机的特定情况下,基于单播的FTP、HTTP等协议及软件来传送,会造成网络流量的浪费,为此设计了一种D类多播地址传送法,可减少网络流量,提高传输效率.
设计并用Java实现了基于多播的以太网文件传送协议,服务端程序用来实现多播数据的发送,而客户端程序用来接收多播数据.
传输层采用UDP协议,参考了TFTP协议的设计思路,并对其做了一些修改,对PDU超时重传的情况进行了处理.
经实验测试,该程序在各种情况下都具有较好的效率和可靠性,在以太网多播环境下优于已有的传统的FTP协议.
该设计为局域网内大量文件的传送提供了新的思路,具有一定的推广价值.

关键词:多播;D类地址;Java;文件传送中图分类号:TP311文献标志码:ADesignandImplementationofMulticast-basedEthernetFileTransferProtocolZhangkun-peng1,Lvyan-qing1,XieHua-cheng2AcademyofInformationTechnology,LuoyangNormalUniversity,LuoyangHenan471022,ChinaInformationofNetworkandComputerCenter,XinyangNormalUniversity,Xinyang464000,ChinaAbstract:Whenfilesdataarecopiedfromahosttoseveralhosts,ifFTPorHTTPprotocoletcwhichbasedonunicastisselected,amountsofnetworkflowwillbewasted.
SoafiletransfermethodusingD-classIPaddressisproposed,anditcanreducenetworkflowandimprovetransferefficiency.
DesignanEthernetfiletransferprotocolandimplementitusingJavalanguage.
Theserverprogramimplementsthetransmissionofmulticastdata,andtheclientprogramimplementsthereceivingofmulticastdata.
ThetransportlayeradoptstheUDPprotocol.
ItconsultsandimprovedonthedesigningmethodofTFTPprotocol,anddealswiththeovertimeretransferofPDU.
AccordingtoExperimentresults,theprogramhasperfectgoodspeedandreliabilityinmostconditions.
UnderEthernetmulticastingcircumstance,theprogramisbetterthanconventionalFTPprotocol.
Thedesignprovidesanewwayofamountsoffiles'transferinLAN,andhassomepromotionalvalue.
Keywords:Multicast;D-classaddress;Java;FileTransfer0引言在局域网中经常会遇到把相同的数据复制到多台主机上的情况,如果使用基于单播的FTP、HTTP等协议及软件来传送文件,会造成很多网络流量的浪费.
在将文件数据从一台主机复制到多台主机的特定情况下,使用D类多播地址可以有效的避免以上问题,从而减少网络流量,提高传输效率.

图1以太网上数据帧的单播和多播(左图为单播,右图为多播)以太局域网本身发送数据时就是以广播的方式发送的,只是不需要该数据的客户端根据MAC帧包含的目的地址来舍弃该数据.
在使用FTP或HTTP等协议传输时,由于目的地址采用单播地址,丢弃了本不应丢弃的数据,降低了传输效率;如果目的地址为多播地址,则该数据仍能正常被接收端主机接收和处理(见图1).
目前网络克隆的程序就是基于上述的多播原理完成工作的,但这些程序大多是基于磁盘或分区的.
例如Ghost软件带有的GhostCast程序,可以通过网络对客户机的整个硬盘或分区进行克隆,一般都需要预先在多台需要复制文件的客户机的磁盘上专门划分出分区,破坏了原有的磁盘结构且设置较为繁琐.

下面设计和实现一个基于单个文件或整个目录的多播文件传送程序,能够较好地解决以上问题.

1多播文件传送协议的设计1.
1多播IP地址分析多播通信中使用的D类IP地址范围在224.
0.
0.
1~239.
255.
255.
255之间,采用多播进行通信需要使用能够进行多播通信的网络接口,如果是通常的以太网接口,自然的就可以进行多播通信.
多播通信与以太网中的广播网不同,属于OSI第三层的网络层协议,可以跨越支持多播协议的路由器进行通信.
其中D类IP地址224.
0.
0.
1表示在本子网上的所有参加多播的主机和路由器,当使用这个IP地址时,不能跨越路由器,只能在以太网的相同网段内使用多播,但这是能够满足本文针对的网络实验室的要求的.
因此本程序在实现时采用了224.
0.
0.
1这个固定的地址,实际使用时需要跨越多播路由器通信也可以根据需要来调整多播IP地址.

1.
2传输层协议分析首先,在传输层上具有可靠性保证的TCP不支持多播,因此传输层采用UDP协议,而数据的可靠传输由协议本身的设计来保证;其次,由于涉及到文件传送,多播文件传送协议参考了同样基于UDP的TFTP协议(RFC1350)的设计思路,但考虑到TFTP没有列目录的功能,因此针对其适用情况做了一些修改.
多播文件传送协议在传输层使用的UDP数据报一共定义了六种协议数据单元(PDU),每种PDU的第一个字段是操作码标志字段(FLAG),根据该标志字段的不同PDU的格式和作用各不相同(见表1).
表1多播文件传送协议定义的6种协议数据单元PDU类型及作用方向PDU格式全部传送结束PDU服务器(客户机|标志位|文件名PDU服务器(客户机|标志位|目录名长度|文件名|文件名确认PDU客户机(服务器|标志位|IP地址|文件名响应|客户端发现PDU客户机(服务器|标志位|IP地址|文件数据PDU服务器(客户机|标志位|序列号|结束标志|文件数据|文件数据确认PDU客户机(服务器|标志位|序列号|IP地址|客户端使用"客户端发现PDU"通知服务端,包含IP地址来标识不同的客户端.
这样在文件传送未开始之前,服务器收集所有客户机IP地址,开始文件传送后可以监测并保证传送的文件数据被每个客户端正确接收.
文件传送是切分成文件数据块进行的,每个"文件数据PDU"携带1K字节的文件数据(最后一个数据块可能不足1K字节),这些文件数据块使用了序号来保证顺序,从而消除了UDP可能无序接收的问题.

1.
3对PDU超时重传的处理考虑到了网络的质量问题,UDP可能出现丢包,因此对于"文件名PDU"、"文件名确认PDU"、"文件数据PDU"、"文件数据确认PDU"都作了超时重传的处理.

需要做超时重传处理的场合包括:(1)在客户端接收"文件数据PDU"超时的情况:①如果该"文件数据PDU"是文件的第一个数据块,重传该文件的"文件名确认PDU";②如果该"文件数据PDU"不是文件的第一个数据报,重传上一个文件数据块的"文件数据确认PDU".

(2)在服务端接收"文件名确认PDU"超时的情况,重传该文件的"文件名PDU".

(3)在服务端接收"文件数据确认PDU"超时的情况,重传该文件数据块的"文件数据PDU".

对于"客户端发现PDU",由于可以在服务端看到是否所有客户端都连接上,并控制发送开始的时间,所以不用重传.
发现有"客户端发现PDU"丢失,即服务端无法发现客户端的情况,只需要重新启动客户端程序就可以,或者检查客户端程序的IP设置是否是与服务端程序在同一以太网段内.

对于"全部传送结束PDU",因为服务端程序运行到发送该PDU时已经能够保证所有文件数据已经被正确发送到所有多播客户端,因此直接把该PDU数据重传多次,使得客户端程序能够接收到该PDU能够退出运行即可.
如果出现该PDU无法被有些多播客户端接收的情况,客户端强行退出即可.

2本多播程序实现概述Java平台对多播协议提供了支持,本程序使用Java语言来开发.
本多播程序分为服务端程序和客户端程序两部分.
其中,服务端程序用来实现多播数据的发送,而客户端程序用来接收多播数据.
典型的情况是在同一以太网段内运行一个服务端程序和多个客户端程序.
程序流程框图如图2、3所示.

图2服务器端多播文件传送流程图3客户端接收数据流程3测试为了测试该多播程序的有效性,测试分三步进行.
在安装了WindowsServer2003的计算机上使用1个多播服务端程序,而多播客户端程序分别使用1个、2个和25个,也就是安装多播客户端的计算机数量逐步增多,以测试该多播程序的传送效果.
测试结果见表2.

表2本程序与FlashFXP对比表多播客户端数量本程序速度(bps)FlashFXP速度(bps)本程序重传次数FlashFXP重传次数12251M800k500k1.
3M700k200k026004684结论在此多播文件传送协议的设计和实现中,参考了成熟的协议,从测试结果来看,达到了预想的效果,在以太网的同一网段内,保证数据可靠传输的前提下提高了传输效率,具有较好的实用性.
为了进一步提高其实用性,可在以下方面做出改进.

(1)在程序中,文件数据块的大小(默认取1K字节)、超时时间(默认取5秒)等参数都可以调整以适应网络情况,以获得最大的传输效率.
可通过在不同网络条件下,针对不同大小和个数的多次的文件传送实验获得最优的参数.

(2)在多播传送过程中,能够动态调整多播客户端的个数,以避免在传送时间比较长的情况下,某些客户端出现意外情况,服务端程序无法继续传送数据的情况.

(3)因为本多播程序在没有Java运行环境的机器上运行时,首先需要安装JRE(JavaRuntimeEnvironment),可以将本程序使用C来实现并可以加上图形界面,以利于Windows平台下的部署和使用.

ReliableSite怎么样,月付$95美国洛杉矶独立服务器

ReliableSite怎么样?ReliableSite好不好。ReliableSite是一家成立于2006年的老牌美国商家,主要经营美国独立服务器租赁,数据中心位于:洛杉矶、迈阿密、纽约,带宽1Gbps起步,花19美元/月即可升级到10Gbps带宽,月流量150T足够各种业务场景使用,且免费提供20Gbps DDoS防护。当前商家有几款大硬盘美国独服,地点位于美国洛杉矶或纽约机房,机器配置很具有...

提速啦(24元/月)河南BGP云服务器活动 买一年送一年4核 4G 5M

提速啦的来历提速啦是 网站 本着“良心 便宜 稳定”的初衷 为小白用户避免被坑 由赣州王成璟网络科技有限公司旗下赣州提速啦网络科技有限公司运营 投资1000万人民币 在美国Cera 香港CTG 香港Cera 国内 杭州 宿迁 浙江 赣州 南昌 大连 辽宁 扬州 等地区建立数据中心 正规持有IDC ISP CDN 云牌照 公司。公司购买产品支持3天内退款 超过3天步退款政策。提速啦的市场定位提速啦主...

RAKsmart 黑色星期五云服务器七折优惠 站群服务器首月半价

一年一度的黑色星期五和网络星期一活动陆续到来,看到各大服务商都有发布促销活动。同时RAKsmart商家我们也是比较熟悉的,这次是继双十一活动之后的促销活动。在活动产品中基本上沿袭双11的活动策略,比如有提供云服务器七折优惠,站群服务器首月半价、还有新人赠送红包等活动。如果我们有需要RAKsmart商家VPS、云服务器、独立服务器等产品的可以看看他们家的活动。这次活动截止到11月30日。第一、限时限...

文件传输为你推荐
虚拟空间购买购买虚拟空间要数据库和不要有什么区别?主机租赁电脑出租怎么收费的?美国虚拟空间请问租用美国虚拟空间,需不需要遵守美国的法律?租服务器我想租服务器,请问会提供哪些服务?美国vps主机美国VPS好?还是香港VPS好?免费网站域名申请怎么免费上传我的网站呀和免费申请域名便宜的虚拟主机哪儿有便宜的虚拟主机?国外主机空间2个国外主机空间,都放了BLOG,看看哪个更快?域名备案域名需要备案吗?免费网站空间申请申请免费空间的网站
西安服务器 seovip 地址大全 卡巴斯基永久免费版 本网站在美国维护 微信收钱 怎么测试下载速度 可外链相册 新睿云 双12 广州虚拟主机 脚本大全 塔式服务器 空间排行榜 windowsserver2008r2 cdn加速技术 最新优惠 alexa搜 大硬盘补丁 主机响 更多