CN107612831A - 一种访问源站的数据报文的传输方法及装置 - Google Patents
一种访问源站的数据报文的传输方法及装置 Download PDFInfo
- Publication number
- CN107612831A CN107612831A CN201710900504.2A CN201710900504A CN107612831A CN 107612831 A CN107612831 A CN 107612831A CN 201710900504 A CN201710900504 A CN 201710900504A CN 107612831 A CN107612831 A CN 107612831A
- Authority
- CN
- China
- Prior art keywords
- destination
- node
- source station
- data message
- routing line
- 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
- 238000000034 method Methods 0.000 title claims abstract description 66
- 230000005540 biological transmission Effects 0.000 title claims abstract description 18
- 238000004891 communication Methods 0.000 claims abstract description 61
- 238000010586 diagram Methods 0.000 description 5
- 238000004904 shortening Methods 0.000 description 4
- 238000004590 computer program Methods 0.000 description 3
- 230000003287 optical effect Effects 0.000 description 2
- 238000007796 conventional method Methods 0.000 description 1
- 230000003111 delayed effect Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000003672 processing method Methods 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
Landscapes
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
本发明的实施例公开了一种访问源站的数据报文的传输方法及装置,在访问源站的过程中,每一服务器在接收到访问源站的第一数据报文后,根据第一数据报文中的第一目的地址,建立和下一跳的第一目的节点的通信连接,再根据存储在第一数据报文中的访问源站的目标路由线路,找到下下跳的第二目的节点,将第一数据报文中第一目的地址替换为第二目的地址,得到第二数据报文,将第二数据报文发送到第一目的节点。该方法将目标路由线路存储在数据报文中,避免了通过服务器查询访问源站的路由线路的过程,从而简化了访问流程,提高了访问速度,缩短了对源站访问的延迟。
Description
技术领域
本发明实施例涉及网络安全传输技术领域,尤其是涉及一种访问源站的数据报文的传输方法及装置。
背景技术
在用户通过多个节点访问源站的过程中,本地节点接收到上一节点发送的访问源站的数据报文后,根据数据报文中携带的源站的信息,依次通过本地节点的LVS、WAF和Cache查询访问源站的下下跳节点,并按照数据报文携带的地址信息将该数据报文发送到下一节点。由此可知,在现有的访问源站的过程中,接收到数据报文的每一节点均要通过WAF和Cache查询下下跳节点,导致访问源站的过程繁琐,且对源站访问的延迟较长。
在实现本发明实施例的过程中,发明人发现现有的对源站进行访问的过程繁琐,访问的延迟较长。
发明内容
本发明所要解决的技术问题是如何解决现有的对源站进行访问的过程繁琐,访问的延迟较长的问题。
针对以上技术问题,本发明的实施例提供了一种访问源站的数据报文的传输方法,包括:
获取访问源站的第一数据报文,从所述第一数据报文中获取第一目的地址,建立本地节点与所述第一目的地址对应的第一目的节点之间的通信连接;
若所述第一目的节点不是所述源站对应的节点,则从所述第一数据报文中获取访问所述源站的目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址;
将所述第一数据报文中的所述第一目的地址替换为所述第二目的地址,得到第二数据报文,通过所述通信连接将所述第二数据报文发送至所述第一目的节点;
其中,所述目标路由线路包括由所述本地节点访问所述源站的路由线路,所述第一目的节点为从所述本地节点访问所述源站的下一跳节点,所述第二目的节点为从所述第一目的节点访问所述源站的下一跳节点。
可选地,所述若所述第一目的节点不是所述源站对应的节点,则从所述第一数据报文中获取访问所述源站的目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址,包括:
若所述第一目的节点不是所述源站对应的节点,查找所述第一数据报文的TCP报头,判断所述第一数据报文的TCP报头中的TCP option是否存储了所述目标路由线路;
若所述TCP option中未存储所述目标路由线路,则通过所述本地节点的WAF从缓存中查找由所述本地节点访问所述源站的至少一条待选路由线路,从所述待选路由线路中选取延迟最小的待选路由线路作为所述目标路由线路,将所述目标路由线路存储在所述TCP option中;
从所述TCP option中获取所述目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址。
可选地,将所述第一数据报文中的所述第一目的地址替换为所述第二目的地址,得到第二数据报文,通过所述通信连接将所述第二数据报文发送至所述第一目的节点,包括:
通过所述本地节点的LVS,将所述第一数据报文中的IP报头中的第一IP地址替换为所述第二目的地址中的第二IP地址,将所述第一数据报文中的TCP报头中的第一目的端口替换为所述第二目的地址中的第二目的端口;
将包括所述第二IP地址的IP报头作为所述第二数据报文的IP报头,将包括所述第二目的端口的TCP报头作为所述第二数据报文的TCP报头,通过所述通信连接将所述第二数据报文发送至所述第一目的节点;
其中,所述第一目的地址包括所述第一IP地址和所述第一目的端口。
可选地,所述若所述第一目的节点不是所述源站对应的节点,则从所述第一数据报文中获取访问所述源站的目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址,还包括:
若所述第一目的节点是所述源站对应的节点,通过所述通信连接将所述第一数据报文发送至所述第一目的节点。
所述获取访问源站的第一数据报文,包括:
接收到访问所述源站的数据报文后,获取所述第一原始数据报文作为所述第一数据报文;
或者,
生成访问所述源站的访问数据,查找访问所述源站的路由线路作为所述目标路由线路,根据所述目标路由线路获取所述第一目的地址,将所述访问数据、所述第一目的地址和所述目标路由线路封装为数据报文,作为所述第一数据报文。
第二方面,本发明的实施例提供了一种访问源站的数据报文的传输装置,包括:
连接模块,用于获取访问源站的第一数据报文,从所述第一数据报文中获取第一目的地址,建立本地节点与所述第一目的地址对应的第一目的节点之间的通信连接;
获取模块,用于若所述第一目的节点不是所述源站对应的节点,则从所述第一数据报文中获取访问所述源站的目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址;
替换模块,用于将所述第一数据报文中的所述第一目的地址替换为所述第二目的地址,得到第二数据报文,通过所述通信连接将所述第二数据报文发送至所述第一目的节点;
其中,所述目标路由线路包括由所述本地节点访问所述源站的路由线路,所述第一目的节点为从所述本地节点访问所述源站的下一跳节点,所述第二目的节点为从所述第一目的节点访问所述源站的下一跳节点。
可选地,所述获取模块还用于若所述第一目的节点不是所述源站对应的节点,查找所述第一数据报文的TCP报头,判断所述第一数据报文的TCP报头中的TCP option是否存储了所述目标路由线路;若所述TCP option中未存储所述目标路由线路,则通过所述本地节点的Waf从缓存中查找由所述本地节点访问所述源站的至少一条待选路由线路,从所述待选路由线路中选取延迟最小的待选路由线路作为所述目标路由线路,将所述目标路由线路存储在所述TCP option中;从所述TCP option中获取所述目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址。
可选地,所述替换模块用于通过所述本地节点的LVS,将所述第一数据报文中的IP报头中的第一IP地址替换为所述第二目的地址中的第二IP地址,将所述第一数据报文中的TCP报头中的第一目的端口替换为所述第二目的地址中的第二目的端口;将包括所述第二IP地址的IP报头作为所述第二数据报文的IP报头,将包括所述第二目的端口的TCP报头作为所述第二数据报文的TCP报头,通过所述通信连接将所述第二数据报文发送至所述第一目的节点;其中,所述第一目的地址包括所述第一IP地址和所述第一目的端口。
可选地,所述获取模块还用于若所述第一目的节点是所述源站对应的节点,通过所述通信连接将所述第一数据报文发送至所述第一目的节点。
所述连接模块还用于:
接收到访问所述源站的数据报文后,获取所述第一原始数据报文作为所述第一数据报文;
或者,
生成访问所述源站的访问数据,查找访问所述源站的路由线路作为所述目标路由线路,根据所述目标路由线路获取所述第一目的地址,将所述访问数据、所述第一目的地址和所述目标路由线路封装为数据报文,作为所述第一数据报文。
第三方面,本发明的实施例提供了一种电子设备,包括:
至少一个处理器、至少一个存储器、通信接口和总线;其中,
所述处理器、存储器、通信接口通过所述总线完成相互间的通信;
所述通信接口用于该电子设备和服务器的通信设备或者终端的通信设备之间的信息传输;
所述存储器存储有可被所述处理器执行的程序指令,所述处理器调用所述程序指令能够执行以上任一项所述的方法。
第四方面,本发明的实施例还提供了一种非暂态计算机可读存储介质,所述非暂态计算机可读存储介质存储计算机指令,所述计算机指令使所述计算机执行以上任一项所述的方法。
本发明的实施例提供了一种访问源站的数据报文的传输方法及装置,在访问源站的过程中,每一服务器在接收到访问源站的第一数据报文后,根据第一数据报文中的第一目的地址,建立和下一跳的第一目的节点的通信连接,再根据存储在第一数据报文中的访问源站的目标路由线路,找到下下跳的第二目的节点,将第一数据报文中第一目的地址替换为第二目的地址,得到第二数据报文,将第二数据报文发送到第一目的节点。由于每一服务器均根据接收到的第一数据报文建立和下一跳节点的通信连接,并根据第一数据报文中存储的目标路由线路找到下下跳节点的目的地址,将下一跳的目的地址替换为下下跳的目的地址,因此接收到第一数据报文的每一服务器均不需要通过该服务器的WAF查询访问源站的待选路由线路,而只需要通过LVS将下一跳的目的地址替换为下下跳的目的地址即可实现对源站的访问。该方法将目标路由线路存储在数据报文中,避免了通过服务器查询访问源站的待选路由线路的过程,从而简化了访问流程,提高了访问速度,缩短了对源站访问的延迟。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作一简单地介绍,显而易见地,下面描述中的附图是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本发明一个实施例提供的访问源站的数据报文的传输方法的流程示意图;
图2是本发明另一个实施例提供的访问源站的数据报文的传输方法的流程示意图;
图3是本发明另一个实施例提供的访问源站的数据报文的传输装置的结构框图;
图4是本发明另一个实施例提供的电子设备的结构框图。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
图1是本实施例提供的访问源站的数据报文的传输方法的流程示意图,参见图1,该方法包括:
101:获取访问源站的第一数据报文,从所述第一数据报文中获取第一目的地址,建立本地节点与所述第一目的地址对应的第一目的节点之间的通信连接;
102:若所述第一目的节点不是所述源站对应的节点,则从所述第一数据报文中获取访问所述源站的目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址;
103:将所述第一数据报文中的所述第一目的地址替换为所述第二目的地址,得到第二数据报文,通过所述通信连接将所述第二数据报文发送至所述第一目的节点;
其中,所述目标路由线路包括由所述本地节点访问所述源站的路由线路,所述第一目的节点为从所述本地节点访问所述源站的下一跳节点,所述第二目的节点为从所述第一目的节点访问所述源站的下一跳节点。
需要说明的是,本实施例提供的方法由服务器执行,例如,由云端服务器或代理服务器(如Nginx)执行。本实施例提供的方法适用于访问源站的过程中的每一网络节点对应的服务器。例如,某一服务器(本地节点)接收来自客户端(例如,手机、电脑或者网络电视)或者其它服务器发送的第一数据报文后,根据第一数据报文中的第一目的地址建立和下一跳的第一目的节点的通信连接,同时将第一数据报文中的第一目的地址替换为下下跳的第二目的地址,并将第一目的地址替换为第二目的地址的第二数据报文发送到下一跳的第一目的节点,以此类推,每一服务器均按照上述方法传输接收到的数据报文,避免了服务器接收到数据报文后根据要访问的源站重新查找待选路由线路,确定下下跳要访问的节点这一步骤,该方法通过将目标路由线路存储在第一数据报文中,直接根据目标路由线路对第一数据报文中的地址信息进行更改,避免了通过本地服务器查找待选路由线路的过程,提高了访问源站的效率,缩短了延迟。
第一数据报文和第二数据报文均为根据传输协议(例如,TCP协议,本实施例对传输协议的具体内容不做限制)封装的数据,均包括了传输该数据的附加信息,例如目的IP,目的端口,数据长度,所用协议等。例如,第一目的地址包括下一跳的第一目的节点的第一IP地址和第一目的端口,第一IP地址封装在第一数据报文的IP报头中,第一目的端口封装在第一数据报文的TCP报头中,将第一数据报文中的第一目的地址替换为第二目的地址的过程中,将第一数据报文的IP报头中的第一IP地址替换为第二目的地址的第二IP地址,将第一数据报文的TCP报头中的第一目的端口替换为第二目的地址的第二目的端口,得到第二数据报文。
相对于本地节点,第一目的节点为访问源站的下一跳节点,第二目的节点为访问源站的下下跳节点(也就是,相对于第一目的节点的下一跳节点)。当本地节点接收到的第一数据报文中未存储目标路由线路,则通过本地节点获取的目标路由线路即为从本地节点访问源站的路由线路(可理解的是,这种情况下,目标路由线路的起点未本地节点)。若本地节点接收到的第一数据报文中存储了目标路由线路,则该目标路由线路包括了由本地节点访问源站的路由线路(可理解的是,这种情况下,目标路由线路的起点可能是本地节点之前的某个网络节点,也可能是接收该第一数据报文的第一个网络节点,本实施例对此不做限制)。
需要说明的是,服务器接收到第一数据报文中,若第一数据报文中携带了目标路由线路,则直接根据该目标路由线路得到第二目的节点对应的第二目的地址。若第一数据报文中没有携带该目标路由线路,则通过本地节点的WAF(防护节点)访问缓存获取目标路由线路,将该目标路由线路存储在第一数据报文中,以避免下一跳节点和下一跳之后的节点在接收到根据该第一数据报文生成的数据报文后,可以直接通过接收到的数据报文获取目标路由线路。此外,本实施例如何将目标路由线路封装到第一数据报文中不做具体限制,例如,将目标路由线路封装在第一数据报文的TCP报头中的TCP option中。
本实施例提供了一种访问源站的数据报文的传输方法,在访问源站的过程中,每一服务器在接收到访问源站的第一数据报文后,根据第一数据报文中的第一目的地址,建立和下一跳的第一目的节点的通信连接,再根据存储在第一数据报文中的访问源站的目标路由线路,找到下下跳的第二目的节点,将第一数据报文中第一目的地址替换为第二目的地址,得到第二数据报文,将第二数据报文发送到第一目的节点。由于每一服务器均根据接收到的第一数据报文建立和下一跳节点的通信连接,并根据第一数据报文中存储的目标路由线路找到下下跳节点的目的地址,将下一跳的目的地址替换为下下跳的目的地址,因此接收到第一数据报文的每一服务器均不需要通过该服务器的WAF查询访问源站的待选路由线路,而只需要通过LVS将下一跳的目的地址替换为下下跳的目的地址即可实现对源站的访问。该方法将目标路由线路存储在数据报文中,避免了通过服务器查询访问源站的待选路由线路的过程,从而简化了访问流程,提高了访问速度,缩短了对源站访问的延迟。
更进一步地,在上述实施例的基础上,所述若所述第一目的节点不是所述源站对应的节点,则从所述第一数据报文中获取访问所述源站的目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址,包括:
若所述第一目的节点不是所述源站对应的节点,查找所述第一数据报文的TCP报头,判断所述第一数据报文的TCP报头中的TCP option是否存储了所述目标路由线路;
若所述TCP option中未存储所述目标路由线路,则通过所述本地节点的WAF从缓存中查找由所述本地节点访问所述源站的至少一条待选路由线路,从所述待选路由线路中选取延迟最小的待选路由线路作为所述目标路由线路,将所述目标路由线路存储在所述TCP option中;
从所述TCP option中获取所述目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址。
需要说明的是,TCP option是TCP报头的最后一个选项字段,为是可变长的可选信息。待选路由线路为本地节点的服务器查找的由本地节点访问源站的所有路由线路。若本地节点检测到第一数据报文的TCP option中未存储目标路由线路,则需要通过WAF访问本地服务器获取目标路由线路。例如,可以直接从本地节点的服务器中查找访问源站的所有待选路由线路,然后将这些待选路由线路中延迟最小的待选路由线路作为目标路由线路存储在TCP option中。本实施例对本地节点对应的服务器如何查找目标路由线路不做具体限制,例如,也可以通过本地节点的服务器和其它服务器联网查找目标路由线路。
进一步地,所述若所述第一目的节点不是所述源站对应的节点,查找所述第一数据报文的TCP报头,判断所述第一数据报文的TCP报头中的TCP option是否存储了所述目标路由线路之后,还包括:
若所述TCP option中存储了所述目标路由线路,则从所述TCP option中获取所述目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址。
本实施例提供了一种访问源站的数据报文的传输方法,该方法基于TCP传输协议,将目标路由线路存储在TCP报头的TCP option中,便于读取目标路由线路,同时对第一数据报文中的其它数据不产生影响,保证了传输过程的正常进行。当服务器检测到第一数据报文的TCP option中不存在该目标路由线路后,及时通过本地节点获取目标路由线路,并将目标路由线路存储在第一数据报文的TCP option中,为下一跳节点和下一跳之后的节点快速获取第二目的地址提供了便利,缩短了访问源站的延迟。
更进一步地,在上述各实施例的基础上,所述将所述第一数据报文中的所述第一目的地址替换为所述第二目的地址,得到第二数据报文,通过所述通信连接将所述第二数据报文发送至所述第一目的节点,包括:
通过所述本地节点的LVS,将所述第一数据报文中的IP报头中的第一IP地址替换为所述第二目的地址中的第二IP地址,将所述第一数据报文中的TCP报头中的第一目的端口替换为所述第二目的地址中的第二目的端口;
将包括所述第二IP地址的IP报头作为所述第二数据报文的IP报头,将包括所述第二目的端口的TCP报头作为所述第二数据报文的TCP报头,通过所述通信连接将所述第二数据报文发送至所述第一目的节点;
其中,所述第一目的地址包括所述第一IP地址和所述第一目的端口。
需要说明的是,LVS(Linux Virtual Server,虚拟服务器)是一个虚拟的服务器集群系统。在传统的方法中,服务器接收到数据报文后,通过该服务器的LVS对该数据报文进行流量清洗,通过WAF访问该服务器的缓存(Cache)得到下下跳节点的地址。而本实施例提供的方法中,当第一数据报文中存储了该目标路由线路后,直接通过LVS即可将下下跳节点的第二目的地址存储在数据报文中,服务器只需根据数据报文中的下一跳的目的地址建立和下一跳节点的通信连接,将数据报文发送到下一站即可,以此类推,实现对源站的访问。
本实施例提供了一种访问源站的数据报文的传输方法,该方法中每一服务器接收到第一数据报文后,通过LVS将下下跳的第二IP地址和第二目的端口进行存储,得到第二数据报文,实现了对第一数据报文中的第一目的地址的更改,保证了下下跳以及下下跳之后的节点均能通过该方法对第一目的地址进行更改,避免了通过访问服务器得到目标路由线路进而获取第二目的地址的步骤,缩短了访问源站的延迟。
更进一步地,在上述各实施例的基础上,所述若所述第一目的节点不是所述源站对应的节点,则从所述第一数据报文中获取访问所述源站的目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址,还包括:
若所述第一目的节点是所述源站对应的节点,通过所述通信连接将所述第一数据报文发送至所述第一目的节点。
本实施例提供了一种访问源站的数据报文的传输方法,该方法中接收到第一数据报文的本地节点的服务器在判断第一目的节点是源站对应的节点后,则不需要再查询访问源站的待选路由线路,也不需要对第一数据报文中的第一目的地址进行更改,而是直接将该第一数据报文发送至第一目的节点,即实现了对源站的访问。
更进一步地,在上述各实施例的基础上,所述获取访问源站的第一数据报文,包括:
接收到访问所述源站的数据报文后,获取所述第一原始数据报文作为所述第一数据报文;
或者,
生成访问所述源站的访问数据,查找访问所述源站的路由线路作为所述目标路由线路,根据所述目标路由线路获取所述第一目的地址,将所述访问数据、所述第一目的地址和所述目标路由线路封装为数据报文,作为所述第一数据报文。
需要说明的是,服务器获取的第一数据报文可以是其它服务器或者终端发送的数据报文,也可以是自身生成的数据报文。当服务器生成了访问源站的访问数据(例如,访问请求信息)后,需要将该访问数据封装为数据报文。
具体地,服务器查找目标路由线路,根据目标路由线路得到第一目的地址(即下一跳节点对应的地址),将该第一目的地址中的第一IP地址存储到数据报文的IP报头中,将第一目的地址中的第一目的端口存储到数据报文的TCP报头中,将目标路由线路存储到TCP报头的TCP option中,将访问数据存储到数据报文的报身中,得到第一数据报文。
本实施例提供了一种访问源站的数据报文的传输方法,该方法提供了服务器在接收到访问源站的数据报文或者生成访问源站的访问数据的两种情况下的处理方法。该方法针对自身生成的访问数据,对第一目的地址、目标路由线路和访问数据进行封装得到第一数据报文,为通过本发明的实施例提供的访问源站的数据报文的传输方法传输该数据报文奠定了基础。
作为一种更为具体的实施例,本实施例提供了一种访问源站的数据报文的传输方法的流程示意图,参见图2,该方法包括:
201:本地节点(本地的服务器)接收到服务器或者终端发送的第一数据报文。
202:根据第一数据报文中的第一目的节点的第一目的地址,通过三次握手协议,建立本地节点和第一目的节点的通信连接。
203:判断第一数据报文中是否有访问源站的目标路由线路,若是,则执行步骤204,否则,执行步骤205。
204:获取该目标路由线路。
205:通过本地节点的WAF访问本地的缓存,得到目标路由线路,将该目标路由线路存储在第一数据报文的TCP option中,获取该目标路由线路。
206:根据目标路由线路获取下下跳的第二目的节点的第二目的地址,通过本地节点的LVS将第一目的地址替换为第二目的地址,得到第二数据报文。
207:将第二数据报文发送到第一目的节点,通过四次握手协议终止本地节点和第一目的节点的通信连接。
本实施例提供了一种访问源站的数据报文的传输方法,该方法将目标路由线路存储在数据报文中,避免了通过服务器查询访问源站的待选路由线路的过程,从而简化了访问流程,提高了访问速度,缩短了对源站访问的延迟。
图3示出了本发明的实施例提供的一种访问源站的数据报文的传输装置的结构框图,参见图3,本实施例提供的访问源站的数据报文的传输装置,包括连接模块301、获取模块302和替换模块303,其中,
连接模块301,用于获取访问源站的第一数据报文,从所述第一数据报文中获取第一目的地址,建立本地节点与所述第一目的地址对应的第一目的节点之间的通信连接;
获取模块302,用于若所述第一目的节点不是所述源站对应的节点,则从所述第一数据报文中获取访问所述源站的目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址;
替换模块303,用于将所述第一数据报文中的所述第一目的地址替换为所述第二目的地址,得到第二数据报文,通过所述通信连接将所述第二数据报文发送至所述第一目的节点;
其中,所述目标路由线路包括由所述本地节点访问所述源站的路由线路,所述第一目的节点为从所述本地节点访问所述源站的下一跳节点,所述第二目的节点为从所述第一目的节点访问所述源站的下一跳节点。
本实施例提供的访问源站的数据报文的传输装置适用于上述实施例中提供的访问源站的数据报文的传输方法,在此不再赘述。
本发明的实施例提供了一种访问源站的数据报文的传输装置,在访问源站的过程中,每一服务器在接收到访问源站的第一数据报文后,根据第一数据报文中的第一目的地址,建立和下一跳的第一目的节点的通信连接,再根据存储在第一数据报文中的访问源站的目标路由线路,找到下下跳的第二目的节点,将第一数据报文中第一目的地址替换为第二目的地址,得到第二数据报文,将第二数据报文发送到第一目的节点。由于每一服务器均根据接收到的第一数据报文建立和下一跳节点的通信连接,并根据第一数据报文中存储的目标路由线路找到下下跳节点的目的地址,将下一跳的目的地址替换为下下跳的目的地址,因此接收到第一数据报文的每一服务器均不需要通过该服务器的WAF查询访问源站的待选路由线路,而只需要通过LVS将下一跳的目的地址替换为下下跳的目的地址即可实现对源站的访问。该装置将目标路由线路存储在数据报文中,避免了通过服务器查询访问源站的待选路由线路的过程,从而简化了访问流程,提高了访问速度,缩短了对源站访问的延迟。
第三方面,图4是示出本实施例提供的电子设备的结构框图。
参照图4,所述电子设备包括:处理器(processor)401、存储器(memory)402、通信接口(Communications Interface)403和总线404;
其中,
所述处理器401、存储器402、通信接口403通过所述总线404完成相互间的通信;
所述通信接口403用于该电子设备和服务器的通信设备或者终端的通信设备之间的信息传输;
所述处理器401用于调用所述存储器402中的程序指令,以执行上述各方法实施例所提供的方法,例如包括:获取访问源站的第一数据报文,从所述第一数据报文中获取第一目的地址,建立本地节点与所述第一目的地址对应的第一目的节点之间的通信连接;若所述第一目的节点不是所述源站对应的节点,则从所述第一数据报文中获取访问所述源站的目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址;将所述第一数据报文中的所述第一目的地址替换为所述第二目的地址,得到第二数据报文,通过所述通信连接将所述第二数据报文发送至所述第一目的节点;其中,所述目标路由线路包括由所述本地节点访问所述源站的路由线路,所述第一目的节点为从所述本地节点访问所述源站的下一跳节点,所述第二目的节点为从所述第一目的节点访问所述源站的下一跳节点。
第四方面,本实施例提供一种非暂态计算机可读存储介质,所述非暂态计算机可读存储介质存储计算机指令,所述计算机指令使所述计算机执行上述各方法实施例所提供的方法,例如包括:获取访问源站的第一数据报文,从所述第一数据报文中获取第一目的地址,建立本地节点与所述第一目的地址对应的第一目的节点之间的通信连接;若所述第一目的节点不是所述源站对应的节点,则从所述第一数据报文中获取访问所述源站的目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址;将所述第一数据报文中的所述第一目的地址替换为所述第二目的地址,得到第二数据报文,通过所述通信连接将所述第二数据报文发送至所述第一目的节点;其中,所述目标路由线路包括由所述本地节点访问所述源站的路由线路,所述第一目的节点为从所述本地节点访问所述源站的下一跳节点,所述第二目的节点为从所述第一目的节点访问所述源站的下一跳节点。
本实施例公开一种计算机程序产品,所述计算机程序产品包括存储在非暂态计算机可读存储介质上的计算机程序,所述计算机程序包括程序指令,当所述程序指令被计算机执行时,计算机能够执行上述各方法实施例所提供的方法,例如,包括:获取访问源站的第一数据报文,从所述第一数据报文中获取第一目的地址,建立本地节点与所述第一目的地址对应的第一目的节点之间的通信连接;若所述第一目的节点不是所述源站对应的节点,则从所述第一数据报文中获取访问所述源站的目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址;将所述第一数据报文中的所述第一目的地址替换为所述第二目的地址,得到第二数据报文,通过所述通信连接将所述第二数据报文发送至所述第一目的节点;其中,所述目标路由线路包括由所述本地节点访问所述源站的路由线路,所述第一目的节点为从所述本地节点访问所述源站的下一跳节点,所述第二目的节点为从所述第一目的节点访问所述源站的下一跳节点。
本领域普通技术人员可以理解:实现上述方法实施例的全部或部分步骤可以通过程序指令相关的硬件来完成,前述的程序可以存储于一计算机可读取存储介质中,该程序在执行时,执行包括上述方法实施例的步骤;而前述的存储介质包括:ROM、RAM、磁碟或者光盘等各种可以存储程序代码的介质。
以上所描述的电子设备等实施例仅仅是示意性的,其中所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部模块来实现本实施例方案的目的。本领域普通技术人员在不付出创造性的劳动的情况下,即可以理解并实施。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到各实施方式可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件。基于这样的理解,上述技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品可以存储在计算机可读存储介质中,如ROM/RAM、磁碟、光盘等,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行各个实施例或者实施例的某些部分所述的方法。
最后应说明的是:以上各实施例仅用以说明本发明的实施例的技术方案,而非对其限制;尽管参照前述各实施例对本发明的实施例进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分或者全部技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明的实施例各实施例技术方案的范围。
Claims (12)
1.一种访问源站的数据报文的传输方法,其特征在于,包括:
获取访问源站的第一数据报文,从所述第一数据报文中获取第一目的地址,建立本地节点与所述第一目的地址对应的第一目的节点之间的通信连接;
若所述第一目的节点不是所述源站对应的节点,则从所述第一数据报文中获取访问所述源站的目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址;
将所述第一数据报文中的所述第一目的地址替换为所述第二目的地址,得到第二数据报文,通过所述通信连接将所述第二数据报文发送至所述第一目的节点;
其中,所述目标路由线路包括由所述本地节点访问所述源站的路由线路,所述第一目的节点为从所述本地节点访问所述源站的下一跳节点,所述第二目的节点为从所述第一目的节点访问所述源站的下一跳节点。
2.根据权利要求1所述的方法,其特征在于,所述若所述第一目的节点不是所述源站对应的节点,则从所述第一数据报文中获取访问所述源站的目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址,包括:
若所述第一目的节点不是所述源站对应的节点,查找所述第一数据报文的TCP报头,判断所述第一数据报文的TCP报头中的TCP option是否存储了所述目标路由线路;
若所述TCP option中未存储所述目标路由线路,则通过所述本地节点的WAF从缓存中查找由所述本地节点访问所述源站的至少一条待选路由线路,从所述待选路由线路中选取延迟最小的待选路由线路作为所述目标路由线路,将所述目标路由线路存储在所述TCPoption中;
从所述TCP option中获取所述目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址。
3.根据权利要求2所述的方法,其特征在于,所述将所述第一数据报文中的所述第一目的地址替换为所述第二目的地址,得到第二数据报文,通过所述通信连接将所述第二数据报文发送至所述第一目的节点,包括:
通过所述本地节点的LVS,将所述第一数据报文中的IP报头中的第一IP地址替换为所述第二目的地址中的第二IP地址,将所述第一数据报文中的TCP报头中的第一目的端口替换为所述第二目的地址中的第二目的端口;
将包括所述第二IP地址的IP报头作为所述第二数据报文的IP报头,将包括所述第二目的端口的TCP报头作为所述第二数据报文的TCP报头,通过所述通信连接将所述第二数据报文发送至所述第一目的节点;
其中,所述第一目的地址包括所述第一IP地址和所述第一目的端口。
4.根据权利要求1所述的方法,其特征在于,所述若所述第一目的节点不是所述源站对应的节点,则从所述第一数据报文中获取访问所述源站的目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址,还包括:
若所述第一目的节点是所述源站对应的节点,通过所述通信连接将所述第一数据报文发送至所述第一目的节点。
5.根据权利要求1所述的方法,其特征在于,所述获取访问源站的第一数据报文,包括:
接收到访问所述源站的数据报文后,获取所述第一原始数据报文作为所述第一数据报文;
或者,
生成访问所述源站的访问数据,查找访问所述源站的路由线路作为所述目标路由线路,根据所述目标路由线路获取所述第一目的地址,将所述访问数据、所述第一目的地址和所述目标路由线路封装为数据报文,作为所述第一数据报文。
6.一种访问源站的数据报文的传输装置,其特征在于,包括:
连接模块,用于获取访问源站的第一数据报文,从所述第一数据报文中获取第一目的地址,建立本地节点与所述第一目的地址对应的第一目的节点之间的通信连接;
获取模块,用于若所述第一目的节点不是所述源站对应的节点,则从所述第一数据报文中获取访问所述源站的目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址;
替换模块,用于将所述第一数据报文中的所述第一目的地址替换为所述第二目的地址,得到第二数据报文,通过所述通信连接将所述第二数据报文发送至所述第一目的节点;
其中,所述目标路由线路包括由所述本地节点访问所述源站的路由线路,所述第一目的节点为从所述本地节点访问所述源站的下一跳节点,所述第二目的节点为从所述第一目的节点访问所述源站的下一跳节点。
7.根据权利要求6所述的装置,其特征在于,所述获取模块还用于若所述第一目的节点不是所述源站对应的节点,查找所述第一数据报文的TCP报头,判断所述第一数据报文的TCP报头中的TCP option是否存储了所述目标路由线路;若所述TCP option中未存储所述目标路由线路,则通过所述本地节点的Waf从缓存中查找由所述本地节点访问所述源站的至少一条待选路由线路,从所述待选路由线路中选取延迟最小的待选路由线路作为所述目标路由线路,将所述目标路由线路存储在所述TCP option中;从所述TCP option中获取所述目标路由线路,根据所述目标路由线路获取第二目的节点对应的第二目的地址。
8.根据权利要求7所述的装置,其特征在于,所述替换模块用于通过所述本地节点的LVS,将所述第一数据报文中的IP报头中的第一IP地址替换为所述第二目的地址中的第二IP地址,将所述第一数据报文中的TCP报头中的第一目的端口替换为所述第二目的地址中的第二目的端口;将包括所述第二IP地址的IP报头作为所述第二数据报文的IP报头,将包括所述第二目的端口的TCP报头作为所述第二数据报文的TCP报头,通过所述通信连接将所述第二数据报文发送至所述第一目的节点;其中,所述第一目的地址包括所述第一IP地址和所述第一目的端口。
9.根据权利要求6所述的装置,其特征在于,所述获取模块还用于若所述第一目的节点是所述源站对应的节点,通过所述通信连接将所述第一数据报文发送至所述第一目的节点。
10.根据权利要求6所述的装置,其特征在于,所述连接模块还用于:
接收到访问所述源站的数据报文后,获取所述第一原始数据报文作为所述第一数据报文;
或者,
生成访问所述源站的访问数据,查找访问所述源站的路由线路作为所述目标路由线路,根据所述目标路由线路获取所述第一目的地址,将所述访问数据、所述第一目的地址和所述目标路由线路封装为数据报文,作为所述第一数据报文。
11.一种电子设备,其特征在于,包括:
至少一个处理器、至少一个存储器、通信接口和总线;其中,
所述处理器、存储器、通信接口通过所述总线完成相互间的通信;
所述通信接口用于该电子设备和服务器的通信设备或者终端的通信设备之间的信息传输;
所述存储器存储有可被所述处理器执行的程序指令,所述处理器调用所述程序指令能够执行如权利要求1至5中任一项所述的方法。
12.一种非暂态计算机可读存储介质,其特征在于,所述非暂态计算机可读存储介质存储计算机指令,所述计算机指令使所述计算机执行权利要求1至5中任一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710900504.2A CN107612831B (zh) | 2017-09-28 | 2017-09-28 | 一种访问源站的数据报文的传输方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710900504.2A CN107612831B (zh) | 2017-09-28 | 2017-09-28 | 一种访问源站的数据报文的传输方法及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN107612831A true CN107612831A (zh) | 2018-01-19 |
CN107612831B CN107612831B (zh) | 2020-07-14 |
Family
ID=61059240
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201710900504.2A Active CN107612831B (zh) | 2017-09-28 | 2017-09-28 | 一种访问源站的数据报文的传输方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN107612831B (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111510487A (zh) * | 2020-04-10 | 2020-08-07 | 杭州云缔盟科技有限公司 | 一种实现智能路由的方法 |
CN112954045A (zh) * | 2021-02-07 | 2021-06-11 | 游密科技(深圳)有限公司 | 节点中的数据传输方法、装置、介质及电子设备 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104135438A (zh) * | 2014-07-08 | 2014-11-05 | 清华大学 | 报文携带路由信息的可扩展路由方法 |
WO2016141846A1 (zh) * | 2015-03-09 | 2016-09-15 | 华为技术有限公司 | 数据报文传输方法及边缘路由网桥设备 |
CN106506367A (zh) * | 2016-11-30 | 2017-03-15 | 杭州华三通信技术有限公司 | 一种下一跳确定方法及装置 |
CN106656781A (zh) * | 2015-11-02 | 2017-05-10 | 中兴通讯股份有限公司 | 一种报文传输的方法、装置和系统 |
-
2017
- 2017-09-28 CN CN201710900504.2A patent/CN107612831B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104135438A (zh) * | 2014-07-08 | 2014-11-05 | 清华大学 | 报文携带路由信息的可扩展路由方法 |
WO2016141846A1 (zh) * | 2015-03-09 | 2016-09-15 | 华为技术有限公司 | 数据报文传输方法及边缘路由网桥设备 |
CN106656781A (zh) * | 2015-11-02 | 2017-05-10 | 中兴通讯股份有限公司 | 一种报文传输的方法、装置和系统 |
CN106506367A (zh) * | 2016-11-30 | 2017-03-15 | 杭州华三通信技术有限公司 | 一种下一跳确定方法及装置 |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111510487A (zh) * | 2020-04-10 | 2020-08-07 | 杭州云缔盟科技有限公司 | 一种实现智能路由的方法 |
CN112954045A (zh) * | 2021-02-07 | 2021-06-11 | 游密科技(深圳)有限公司 | 节点中的数据传输方法、装置、介质及电子设备 |
CN112954045B (zh) * | 2021-02-07 | 2022-04-26 | 游密科技(深圳)有限公司 | 节点中的数据传输方法、装置、介质及电子设备 |
Also Published As
Publication number | Publication date |
---|---|
CN107612831B (zh) | 2020-07-14 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN104202360B (zh) | 访问网页的方法、装置及路由器 | |
US9392081B2 (en) | Method and device for sending requests | |
US20160088074A1 (en) | System and Method to Balance Servers Based on Server Load Status | |
CN107332908B (zh) | 一种数据传输方法及其系统 | |
US10306007B2 (en) | Cache content hit method and communications system | |
WO2019062593A1 (zh) | 报文传输方法及装置、计算机可读存储介质 | |
CN108494755B (zh) | 一种传输应用程序编程接口api请求的方法及装置 | |
CN111510476B (zh) | 通信方法、装置、计算机设备和计算机可读存储介质 | |
US11064390B2 (en) | Traffic control method and device, terminal, system, and storage medium | |
US10693785B2 (en) | Method and system for forwarding data, virtual load balancer, and readable storage medium | |
RU2642833C2 (ru) | Способ и устройство для обеспечения медиаресурса | |
CN111193773A (zh) | 负载均衡方法、装置、设备及存储介质 | |
CN105991793B (zh) | 报文转发的方法和装置 | |
CN106507414B (zh) | 报文转发方法及装置 | |
CN105959188B (zh) | 一种控制用户终端上线的方法和装置 | |
US9350606B2 (en) | System and method for assigning server to terminal and efficiently delivering messages to the terminal | |
CN107612831B (zh) | 一种访问源站的数据报文的传输方法及装置 | |
CN111953806A (zh) | 一种链路选择方法、装置、计算机设备及计算机存储介质 | |
CN105656978A (zh) | 一种资源共享方法及装置 | |
CN109788050B (zh) | 一种获取源站ip地址方法、系统、电子设备和介质 | |
TW201611549A (zh) | 網路設備及其進行路由轉發的方法 | |
CN109471713B (zh) | 用于查询信息的方法和装置 | |
CN110933121A (zh) | 连接建立方法、通信处理方法、装置及通信设备 | |
CN110324436B (zh) | 一种传输层代理的代理方法及装置 | |
CN107682271B (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 | ||
CB02 | Change of applicant information | ||
CB02 | Change of applicant information |
Address after: 100088 Building 3 332, 102, 28 Xinjiekouwai Street, Xicheng District, Beijing Applicant after: QAX Technology Group Inc. Address before: 100015 Jiuxianqiao Chaoyang District Beijing Road No. 10, building 15, floor 17, layer 1701-26, 3 Applicant before: BEIJING QIANXIN TECHNOLOGY Co.,Ltd. |
|
GR01 | Patent grant | ||
GR01 | Patent grant |