[发明专利]一种数据传输的方法以及装置有效
申请号: | 201410467037.5 | 申请日: | 2014-09-12 |
公开(公告)号: | CN104243473B | 公开(公告)日: | 2018-11-30 |
发明(设计)人: | 李广鹏;于德雷 | 申请(专利权)人: | 华为技术有限公司 |
主分类号: | H04L29/06 | 分类号: | H04L29/06;H04L12/26;H04L12/24 |
代理公司: | 暂无信息 | 代理人: | 暂无信息 |
地址: | 518129 广东*** | 国省代码: | 广东;44 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 数据传输 方法 以及 装置 | ||
本发明实施例公开了一种数据传输的方法以及装置,其中所述方法包括:在客户端与主服务器之间转发客户端发起的数据报文和主服务器发起的数据报文;当检测到所述主服务器发生故障时,与备用服务器建立传输控制协议TCP连接;根据与所述备用服务器间的TCP连接,将所述客户端与所述备用服务器之间所发起的数据报文构造成中转数据报文,并在所述客户端与所述备用服务器之间转发所述中转数据报文。采用本发明,可降低在客户端侧的设计复杂性,以降低对客户端的性能要求。
技术领域
本发明涉及通信技术领域,尤其涉及一种数据传输的方法以及装置。
背景技术
云计算和虚拟化技术日益成熟,不断刺激传统分布式的网络基础设施开始向SDN(Software Defined Network,软件定义网络)网络架构演进。借助IT(InformationTechnology,信息技术)的成熟技术来解决CT(Communication Technology,通信技术)领域的问题是SDN很重要的研究课题。在网络集中式控制问题中,借助高可靠性集群技术来构建SDN网络高可靠、可扩展的大规模网络服务能力是比较可行的做法。
然而,集中控制平台和网络设备之间的控制协议(典型地,如OpenFlow协议)需要满足持久性和可靠性特点。因此,目前通过提出多归属方案来满足这种需求,所述多归属方案是指客户端同时连接到多个服务器,并选择出主通道,当主通道的TCP(TransmissionControl Protocol,传输控制协议)连接断开后,由应用层决定将后续报文通过副通道传输给其他服务器。但是在所述多归属方案中的客户端必须同时与多个服务器连接,这必然增加了在客户端侧的设计复杂性,例如,当主通道断开TCP连接后,客户端需要对发起的数据报文的目的地进行变更,才能将数据报文成功发送到其他服务器,从而增加了在客户端侧的设计复杂性,并增加了对客户端的性能要求。
发明内容
本发明实施例所要解决的技术问题在于,提供一种数据传输的方法以及装置,可降低在客户端侧的设计复杂性,以降低对客户端的性能要求。
本发明第一方面提供一种数据传输的方法,包括:
在客户端与主服务器之间转发客户端发起的数据报文和主服务器发起的数据报文;
当检测到所述主服务器发生故障时,与备用服务器建立传输控制协议TCP连接;
根据与所述备用服务器间的TCP连接,将所述客户端与所述备用服务器之间所发起的数据报文构造成中转数据报文,并在所述客户端与所述备用服务器之间转发所述中转数据报文;
其中,由所述客户端发起的数据报文所构造成的中转数据报文是所述备用服务器所预期的数据报文,由所述备用服务器发起的数据报文所构造成的中转数据报文是所述客户端所预期的数据报文。
在第一种可能的实现方式中,在所述在客户端与主服务器之间转发客户端发起的数据报文和主服务器发起的数据报文的步骤之前,还包括:
初始化服务器优先级列表,根据所述服务器优先级列表在服务器集群中选择出所述主服务器,所述服务器优先级列表包括所述主服务器信息以及至少一个备用服务器的优先级信息;
接收客户端发送的握手请求报文,并将所述握手请求报文转发到所述主服务器,以完成所述客户端与所述主服务器的TCP连接。
结合第一方面,或第一方面的第一种可能的实现方式,在第二种可能的实现方式中,所述当检测到所述主服务器发生故障时,与备用服务器建立TCP连接,包括:
当检测到所述主服务器发生故障时,根据故障时所跟踪到的客户端发起的数据报文中的客户端TCP序列号,生成备用握手请求报文;
将所述备用握手请求报文发送到备用服务器,以与所述备用服务器建立TCP连接;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于华为技术有限公司,未经华为技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201410467037.5/2.html,转载请声明来源钻瓜专利网。