CN106790480A - 一种用于链路聚合链接条件下的文件传输方法 - Google Patents
一种用于链路聚合链接条件下的文件传输方法 Download PDFInfo
- Publication number
- CN106790480A CN106790480A CN201611142300.9A CN201611142300A CN106790480A CN 106790480 A CN106790480 A CN 106790480A CN 201611142300 A CN201611142300 A CN 201611142300A CN 106790480 A CN106790480 A CN 106790480A
- Authority
- CN
- China
- Prior art keywords
- client
- ack
- data block
- port
- data
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/06—Protocols specially adapted for file transfer, e.g. file transfer protocol [FTP]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L1/00—Arrangements for detecting or preventing errors in the information received
- H04L1/12—Arrangements for detecting or preventing errors in the information received by using return channel
- H04L1/16—Arrangements for detecting or preventing errors in the information received by using return channel in which the return channel carries supervisory signals, e.g. repetition request signals
- H04L1/1607—Details of the supervisory signal
- H04L1/1657—Implicit acknowledgement of correct or incorrect reception, e.g. with a moving window
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L47/00—Traffic control in data switching networks
- H04L47/10—Flow control; Congestion control
- H04L47/12—Avoiding congestion; Recovering from congestion
- H04L47/125—Avoiding congestion; Recovering from congestion by balancing the load, e.g. traffic engineering
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
- Information Transfer Between Computers (AREA)
Abstract
本发明属于通信领域,提出一种用于链路聚合链接条件下的文件传输方法,其中,数据上传方法包括:步骤1、客户端从n个端口中随机选择一端口向客户端发送写请求,请求参数中附带客户端所有n个传输端口信息;步骤2、服务端返回ACK给客户端,ACK编号为0;步骤3、客户端n个端口,同时随机发送滑动窗口内的数据块;步骤4、服务端收到数据块后,根据数据缓存内容,生成返回的ACK的编号m并返回ACK;步骤5、客户端接到编号为m的ACK之后,将窗口向前滑动到m+1,n个端口继续并行发送窗口中的数据;步骤6、重复上述发送步骤,直到ACK编号到达最后一个数据块位置,完成传输。
Description
技术领域
本发明属于通信领域,具体涉及数字化信息系统中基于对象管理组织(ObjectManagement Group,OMG)组织提出的数据分发服务(Date Distribution Service,DDS)标准实现的“请求-响应”式数据通信方式。
背景技术
TFTP(Trivial File Transfer Protocol,RFC1350)是一个传输文件的简单协议,通常使用UDP协议而实现。其单端口传输,对每一数据块一ACK的传输方式能够确保数据有序到达。而在链路聚合链接条件下,其协议不能有效使用所有链路的带宽,限制了传输效率。
发明内容
本发明的发明目的是:
为了解决背景中所存在的技术问题,本发明提出了一种用于链路聚合链接条件下的文件传输方法。在TFTP的基础上,通过对客户端使用多个端口并设立发送窗口,达到多链路的有效使用,提高了链路聚合链接条件下的传输效率。
本发明的技术解决方案是:
一种用于链路聚合链接条件下的文件传输方法,包括:
数据上传方法和数据下载方法;
其中,数据上传方法包括:
步骤1、客户端从n个端口中随机选择一端口向客户端发送写请求,请求参数中附带客户端所有n个传输端口信息;
步骤2、服务端返回ACK给客户端,ACK编号为0;
步骤3、客户端n个端口,同时随机发送滑动窗口内的数据块,所述滑动窗口大小为z;
步骤4、服务端收到数据块后,根据数据缓存内容,生成返回的ACK的编号m并返回ACK,所述m表示m及其之前的数据块已全部接收成功;
步骤5、客户端接到编号为m的ACK之后,将窗口向前滑动到m+1,n个端口继续并行发送窗口中的数据,此时发送的数据块为m+1到m+z;
步骤6、重复上述发送步骤,直到ACK编号到达最后一个数据块位置,所述最后一个数据块为不满TFTP块大小的数据块,完成传输;
数据下载方法包括:
步骤7、客户端从n个端口中随机选择一端口向客户端发送读请求,请求参数中附带客户端所有n个传输端口信息;
步骤8、服务端向客户端n个端口,分别随机发送滑动窗口内的数据块,所述滑动窗口大小为z;
步骤9、客户端收到数据块后,根据数据缓存内容,生成返回的ACK的编号m并返回ACK,所述m表示m及其之前的数据块已全部接收成功;
步骤10、服务端接到编号为m的ACK之后,将窗口向前滑动到m+1,继续向客户端n个端口随机发送窗口中的数据,此时发送的数据块为m+1到m+z;
步骤11、重复上述发送步骤,直到ACK编号到达最后一个数据块位置,所述最后一个数据块为不满TFTP块大小的数据块,完成传输。
本发明具有的优点效果:
本发明在TFTP文件传输协议的基础上,根据链路聚合链接条件下的特点,使用多端口发送及发送窗口,达到了多链路的充分利用,提高了链路聚合链接条件下的传输效率;并且当某一路断开时,可以自动将负载分配到其他正常链路上,实现了动态负载均衡。
附图说明
图1是本发明发送窗口的示意图:n,n+1及以前块数据已发送完毕且已收到ACK;n+2,n+3,n+4块数据在发送窗口中正在发送,等待收到ACK后滑动窗口;n+5,n+6,n+7,n+8及以后数据块还未发送;
图2是本发明多端口接收/发送数据链路图,客户端多端口分配到不同的链路上,从而实现多链路的充分利用。
具体实施方式
如图1、2所示,一种用于链路聚合链接条件下的文件传输方法,包括:
数据上传方法和数据下载方法;
其中,数据上传方法包括:
步骤1、客户端从n个端口中随机选择一端口向客户端发送写请求,请求参数中附带客户端所有n个传输端口信息;
步骤2、服务端返回ACK给客户端,ACK编号为0;
步骤3、客户端n个端口,同时随机发送滑动窗口内的数据块,所述滑动窗口大小为z;
步骤4、服务端收到数据块后,根据数据缓存内容,生成返回的ACK的编号m并返回ACK,所述m表示m及其之前的数据块已全部接收成功;
步骤5、客户端接到编号为m的ACK之后,将窗口向前滑动到m+1,n个端口继续并行发送窗口中的数据,此时发送的数据块为m+1到m+z;
步骤6、重复上述发送步骤,直到ACK编号到达最后一个数据块位置,所述最后一个数据块为不满TFTP块大小的数据块,完成传输;
数据下载方法包括:
步骤7、客户端从n个端口中随机选择一端口向客户端发送读请求,请求参数中附带客户端所有n个传输端口信息;
步骤8、服务端向客户端n个端口,分别随机发送滑动窗口内的数据块,所述滑动窗口大小为z;
步骤9、客户端收到数据块后,根据数据缓存内容,生成返回的ACK的编号m并返回ACK,所述m表示m及其之前的数据块已全部接收成功;
步骤10、服务端接到编号为m的ACK之后,将窗口向前滑动到m+1,继续向客户端n个端口随机发送窗口中的数据,此时发送的数据块为m+1到m+z;
步骤11、重复上述发送步骤,直到ACK编号到达最后一个数据块位置,所述最后一个数据块为不满TFTP块大小的数据块,完成传输。
Claims (1)
1.一种用于链路聚合链接条件下的文件传输方法,其特征在于,包括:
数据上传方法和数据下载方法;
其中,数据上传方法包括:
步骤1、客户端从n个端口中随机选择一端口向客户端发送写请求,请求参数中附带客户端所有n个传输端口信息;
步骤2、服务端返回ACK给客户端,ACK编号为0;
步骤3、客户端n个端口,同时随机发送滑动窗口内的数据块,所述滑动窗口大小为z;
步骤4、服务端收到数据块后,根据数据缓存内容,生成返回的ACK的编号m并返回ACK,所述m表示m及其之前的数据块已全部接收成功;
步骤5、客户端接到编号为m的ACK之后,将窗口向前滑动到m+1,n个端口继续并行发送窗口中的数据,此时发送的数据块为m+1到m+z;
步骤6、重复上述发送步骤,直到ACK编号到达最后一个数据块位置,所述最后一个数据块为不满TFTP块大小的数据块,完成传输;
数据下载方法包括:
步骤7、客户端从n个端口中随机选择一端口向客户端发送读请求,请求参数中附带客户端所有n个传输端口信息;
步骤8、服务端向客户端n个端口,分别随机发送滑动窗口内的数据块,所述滑动窗口大小为z;
步骤9、客户端收到数据块后,根据数据缓存内容,生成返回的ACK的编号m并返回ACK,所述m表示m及其之前的数据块已全部接收成功;
步骤10、服务端接到编号为m的ACK之后,将窗口向前滑动到m+1,继续向客户端n个端口随机发送窗口中的数据,此时发送的数据块为m+1到m+z;
步骤11、重复上述发送步骤,直到ACK编号到达最后一个数据块位置,所述最后一个数据块为不满TFTP块大小的数据块,完成传输。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201611142300.9A CN106790480B (zh) | 2016-12-12 | 2016-12-12 | 一种用于链路聚合链接条件下的文件传输方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201611142300.9A CN106790480B (zh) | 2016-12-12 | 2016-12-12 | 一种用于链路聚合链接条件下的文件传输方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN106790480A true CN106790480A (zh) | 2017-05-31 |
CN106790480B CN106790480B (zh) | 2020-08-11 |
Family
ID=58876011
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201611142300.9A Active CN106790480B (zh) | 2016-12-12 | 2016-12-12 | 一种用于链路聚合链接条件下的文件传输方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN106790480B (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111683094A (zh) * | 2020-06-09 | 2020-09-18 | 中国银行股份有限公司 | Tcp通讯时客户端选择端口的方法及装置 |
CN112068997A (zh) * | 2020-09-09 | 2020-12-11 | 恒生电子股份有限公司 | 数据备份方法、装置、设备及存储介质 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8189476B1 (en) * | 2007-08-20 | 2012-05-29 | F5 Networks, Inc. | Dynamic trunk distribution on egress |
CN102577277A (zh) * | 2009-10-13 | 2012-07-11 | 摩托罗拉移动公司 | 提供合并多点链路的逻辑聚合点对点数据链路 |
CN102656863A (zh) * | 2009-12-18 | 2012-09-05 | 高通股份有限公司 | Http 优化、多归属、移动性和优先级 |
CN102656862A (zh) * | 2009-12-18 | 2012-09-05 | 高通股份有限公司 | 在应用层绑定/聚合多个接口 |
-
2016
- 2016-12-12 CN CN201611142300.9A patent/CN106790480B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8189476B1 (en) * | 2007-08-20 | 2012-05-29 | F5 Networks, Inc. | Dynamic trunk distribution on egress |
CN102577277A (zh) * | 2009-10-13 | 2012-07-11 | 摩托罗拉移动公司 | 提供合并多点链路的逻辑聚合点对点数据链路 |
CN102656863A (zh) * | 2009-12-18 | 2012-09-05 | 高通股份有限公司 | Http 优化、多归属、移动性和优先级 |
CN102656862A (zh) * | 2009-12-18 | 2012-09-05 | 高通股份有限公司 | 在应用层绑定/聚合多个接口 |
Non-Patent Citations (1)
Title |
---|
赵兴涛: "《数据通信与网络技术》", 30 September 2015 * |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111683094A (zh) * | 2020-06-09 | 2020-09-18 | 中国银行股份有限公司 | Tcp通讯时客户端选择端口的方法及装置 |
CN111683094B (zh) * | 2020-06-09 | 2022-06-17 | 中国银行股份有限公司 | Tcp通讯时客户端选择端口的方法、装置、计算机设备和存储介质 |
CN112068997A (zh) * | 2020-09-09 | 2020-12-11 | 恒生电子股份有限公司 | 数据备份方法、装置、设备及存储介质 |
CN112068997B (zh) * | 2020-09-09 | 2023-12-19 | 恒生电子股份有限公司 | 数据备份方法、装置、设备及存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN106790480B (zh) | 2020-08-11 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP7154399B2 (ja) | データ伝送方法、装置、コンピュータ読み取り可能な媒体および電子デバイス | |
WO2019019906A1 (zh) | 一种通信方法、设备及存储介质 | |
CN102316516B (zh) | 一种lte上行数据传输结构构建方法 | |
CN101409675A (zh) | 网络分组净荷压缩 | |
WO2016191990A1 (zh) | 一种报文转换方法及装置 | |
PH12019502798A1 (en) | Data transmission method, terminal device, and network device | |
CN102355694A (zh) | 无线异构网络中数据分流方法、设备和无线网络控制器 | |
CN109714267A (zh) | 管理反向队列的传输控制方法及系统 | |
US9075926B2 (en) | Distributed interconnect bus apparatus | |
CN101707590B (zh) | 基于零拷贝方式的tcp/ip协议报文发送方法和装置 | |
CN104618007B (zh) | 一种同步卫星tcp协议分段连接优化方法 | |
CN106790480A (zh) | 一种用于链路聚合链接条件下的文件传输方法 | |
CN111277988A (zh) | 一种提高微信小程序蓝牙传输速度的方法 | |
JP2007266775A5 (zh) | ||
CN112969169A (zh) | 一种低功耗蓝牙通信流控方法、系统、存储介质及设备 | |
US20130250760A1 (en) | Communication link with intra-packet flow control | |
CN104168273B (zh) | 一种瘦ap模式下实现tcp代理的方法及系统 | |
CN103236880A (zh) | 一种卫星数字发行系统和方法 | |
EP3930233B1 (en) | Method for data transmission by mapping and related product | |
CN102802200A (zh) | 一种数据报文的发送方法和设备 | |
CN117376339A (zh) | 基于ota的车辆ecu升级方法、装置、设备及介质 | |
WO2018137218A1 (zh) | 一种数据传输方法、数据接收设备及数据发送设备 | |
CN103546386A (zh) | 路由器中数据报文发送的流控方法及系统 | |
CN203225755U (zh) | 一种卫星数字发行系统 | |
CN104767590A (zh) | 一种串行通信的可靠数据传输和控制方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |