一种通信方法和通信装置与流程

文档序号:18981158发布日期:2019-10-29 03:46阅读:155来源:国知局
本发明涉及视联网
技术领域
:,特别是涉及一种通信方法和通信装置。
背景技术
::随着视联网业务在全国范围内的普及发展,视联网高清视联交互技术在政府部门已经其它行业中发挥着举足轻重的作用。视联网采用全球最先进的visionvera实时高清视频交换技术,实现了目前互联网无法实现的全网高清视频实时传输,将高清视频会议、视频监控、远程培训、智能化监控分析、应急指挥、视频电话、现场直播、电视邮件、信息发布等数十种视频、语音、图片、文字、通讯、数据等服务全部整合在一个系统平台,通过多种终端设备实现高清品质视频通信实时互联互通。然而,上述一切服务仅限于视联网专有网络中,在上述服务实现视联网与互联网的结合应用方面,尤其在视联网数据与互联网数据互相传输的过程,目前仍然没有较为有效可行的方法。技术实现要素:鉴于上述问题,提出了本发明实施例以便提供一种克服上述问题或者至少部分地解决上述问题的一种通信方法和相应的一种通信装置。为了解决上述问题,本发明实施例公开了一种通信方法,所述方法应用于视联网中,所述视联网包括:视联网终端、视联网服务器、视联猫服务端、视联猫客户端、互联网终端,所述方法包括:所述视联网终端将待发送的数据报文,通过视联网服务器发送至所述视联猫客户端;所述视联猫客户端将所述待发送的数据报文封装成视联网报文,并通过所述视联猫客户端网关发送至对应目标地址的所述视联猫服务端;所述视联网报文包括目标地址;所述视联猫服务端接收到所述视联网报文,并将所述视联网报文重组为互联网报文;所述视联猫服务端根据所述目标地址查找对应的所述互联网终端,并将所述互联网报文发送至所述互联网终端。可选地,所述视联网终端将待发送的数据报文,通过视联网服务器发送至所述视联猫客户端的步骤,包括:所述视联网终端将待发送的数据报文,通过视联网接入控制器发送到所述视联网服务器内核协议栈;所述视联网服务器内核协议栈通过虚拟交换接口的转发实例,将所述待发送的数据报文转发至所述视联猫客户端。可选地,所述视联猫客户端将所述待发送的数据报文封装成视联网报文,并通过所述视联猫客户端网关发送至对应目标地址的所述视联猫服务端的步骤,包括:所述视联猫客户端将所述待发送的数据报文,按照视联网报文封装成视联网报文;所述视联猫客户端调用点对点发送函数,将所述视联网报文通过虚拟交换接口,发送至对应目标地址的所述视联猫服务端网关。可选地,所述视联猫服务端接收到所述视联网报文,并将所述视联网报文重组为互联网报文的步骤,包括:所述视联猫服务端网关通过ip协议调用接收函数,接收所述视联网报文;所述视联猫服务端判断所述视联网报文中的ip数据包有没有丢失或者乱序;如果存在丢失或者乱序,则丢弃相应分片;如果不存在丢失或者乱序,则将所述ip数据包添加ip头,重组成完整的互联网报文。可选地,在所述视联猫服务端根据所述目标地址查找对应的所述互联网终端,并将所述互联网报文发送至所述互联网终端的步骤之后,还包括:所述视联猫服务端网关通过ip协议调用接收函数,接收所述互联网终端返回的响应数据包;所述响应数据包包含响应目的地址;所述视联猫服务端将所述响应数据包重组为视联网报文;所述视联猫服务端将所述视联网报文发送至对应所述响应地址的所述视联猫客户端;所述视联猫客户端解析出所述视联网报文中的视联网数据包,发送至对应至所述响应目的地址的所述视联网终端。本发明实施例还公开了一种通信装置,所述装置应用于视联网中,所述视联网包括:视联网终端、视联网服务器、视联猫服务端、视联猫客户端、互联网终端,所述装置包括:报文转发装置,用于所述视联网终端将待发送的数据报文,通过视联网服务器发送至所述视联猫客户端;封装模块,用于所述视联猫客户端将所述待发送的数据报文封装成视联网报文,并通过所述视联猫客户端网关发送至对应目标地址的所述视联猫服务端;所述视联网报文包括目标地址;重组模块,用于所述视联猫服务端接收到所述视联网报文,并将所述视联网报文重组为互联网报文;发送模块,用于所述视联猫服务端根据所述目标地址查找对应的所述互联网终端,并将所述互联网报文发送至所述互联网终端。可选地,所述报文转发装置,包括:内核转发子模块,用于所述视联网终端将待发送的数据报文,通过视联网接入控制器发送到所述视联网服务器内核协议栈;转发子模块,用于所述视联网服务器内核协议栈通过虚拟交换接口的转发实例,将所述待发送的数据报文转发至所述视联猫客户端。可选地,所述封装模块,包括:封装子模块,用于所述视联猫客户端将所述待发送的数据报文,按照视联网报文封装成视联网报文;发送子模块,用于所述视联猫客户端调用点对点发送函数,将所述视联网报文通过虚拟交换接口,发送至对应目标地址的所述视联猫服务端网关。可选地,所述重组模块,包括:接收子模块,用于所述视联猫服务端网关通过ip协议调用接收函数,接收所述视联网报文;判断子模块,用于所述视联猫服务端判断所述视联网报文中的ip数据包有没有丢失或者乱序;丢弃子模块,用于如果存在丢失或者乱序,则丢弃相应分片;重组子模块,用于如果不存在丢失或者乱序,则将所述ip数据包添加ip头,重组成完整的互联网报文。可选地,还包括:响应数据包接收模块,用于所述视联猫服务端网关通过ip协议调用接收函数,接收所述互联网终端返回的响应数据包;所述响应数据包包含响应目的地址;报文重组模块,用于所述视联猫服务端将所述响应数据包重组为视联网报文;返回发送模块,用于所述视联猫服务端将所述视联网报文发送至对应所述响应地址的所述视联猫客户端;响应数据返回模块,用于所述视联猫客户端解析出所述视联网报文中的视联网数据包,发送至对应至所述响应目的地址的所述视联网终端。本发明实施例包括以下优点:通过在视联网中添加视联猫服务端和视联猫客户端,并利用视联猫服务端和视联猫客户端提供视联网与外网连接的vpn服务,其中,所述视联网终端将待发送的数据报文,通过视联网服务器发送至所述视联猫客户端;所述视联猫客户端将所述待发送的数据报文封装成视联网报文,并通过所述视联猫客户端网关发送至对应目标地址的所述视联猫服务端;所述视联网报文包括目标地址;所述视联猫服务端接收到所述视联网报文,并将所述视联网报文重组为互联网报文;所述视联猫服务端根据所述目标地址查找对应的所述互联网终端,并将所述互联网报文发送至所述互联网终端,实现了在视联网内部将视联网数据重组为互联网数据包,并发送至互联网终端的目的,解决了传统视联网无法访问互联网的问题。取得了可以对视联网终端在不限制应用环境的情况下访问互联网的有益效果。附图说明图1是本发明的一种视联网的组网示意图;图2是本发明的一种节点服务器的硬件结构示意图;图3是本发明的一种接入交换机的硬件结构示意图;图4是本发明的一种以太网协转网关的硬件结构示意图;图5是本发明的一种通信方法实施例的步骤流程图;图5a是本发明的视联网终端通信系统框架的示意图;图5b是本发明的视联网终端通信数据流的示意图;图5c是本发明的视联网终端通信数据流的示意图;图6是本发明的一种通信装置实施例的结构框图。具体实施方式为使本发明的上述目的、特征和优点能够更加明显易懂,下面结合附图和具体实施方式对本发明作进一步详细的说明。视联网是网络发展的重要里程碑,是一个实时网络,能够实现高清视频实时传输,将众多互联网应用推向高清视频化,高清面对面。视联网采用实时高清视频交换技术,可以在一个网络平台上将所需的服务,如高清视频会议、视频监控、智能化监控分析、应急指挥、数字广播电视、延时电视、网络教学、现场直播、vod点播、电视邮件、个性录制(pvr)、内网(自办)频道、智能化视频播控、信息发布等数十种视频、语音、图片、文字、通讯、数据等服务全部整合在一个系统平台,通过电视或电脑实现高清品质视频播放。为使本领域技术人员更好地理解本发明实施例,以下对视联网进行介绍:视联网所应用的部分技术如下所述:网络地址转换(nat,networkaddresstranslation):随着ip网络的普及,目前广泛应用的ipv4版本的ip地址出现严重不足,运行tcp/ip协议的设备原来越多,无法满足每个设备拥有一个ip地址的需求nat网络地址转换,又称地址代理,用来实现私有网络地址与公有网络地址之间的转换。alg应用层网关:简称“alg”(也叫应用层防火墙或应用层代理防火墙),在windows中其进程名是alg.exe,应用层网关通常被描述为第三代防火墙。alg在作为nat穿透的应用时,由于传统的nat不能改变应用层中的ip地址,因此使用alg直接改变应用层的ip地址,在得到终端的私有地址时就直接绑定其公网地址,为此后可能涉及到的互通做好准备。网络技术(networktechnology)视联网的网络技术创新改良了传统以太网(ethernet),以面对网络上潜在的巨大视频流量。不同于单纯的网络分组包交换(packetswitching)或网络电路交换(circuitswitching),视联网技术采用packetswitching满足streaming需求。视联网技术具备分组交换的灵活、简单和低价,同时具备电路交换的品质和安全保证,实现了全网交换式虚拟电路,以及数据格式的无缝连接。交换技术(switchingtechnology)视联网采用以太网的异步和包交换两个优点,在全兼容的前提下消除了以太网缺陷,具备全网端到端无缝连接,直通用户终端,直接承载ip数据包。用户数据在全网范围内不需任何格式转换。视联网是以太网的更高级形态,是一个实时交换平台,能够实现目前互联网无法实现的全网大规模高清视频实时传输,将众多网络视频应用推向高清化、统一化。服务器技术(servertechnology)视联网和统一视频平台上的服务器技术不同于传统意义上的服务器,它的流媒体传输是建立在面向连接的基础上,其数据处理能力与流量、通讯时间无关,单个网络层就能够包含信令及数据传输。对于语音和视频业务来说,视联网和统一视频平台流媒体处理的复杂度比数据处理简单许多,效率比传统服务器大大提高了百倍以上。储存器技术(storagetechnology)统一视频平台的超高速储存器技术为了适应超大容量和超大流量的媒体内容而采用了最先进的实时操作系统,将服务器指令中的节目信息映射到具体的硬盘空间,媒体内容不再经过服务器,瞬间直接送达到用户终端,用户等待一般时间小于0.2秒。最优化的扇区分布大大减少了硬盘磁头寻道的机械运动,资源消耗仅占同等级ip互联网的20%,但产生大于传统硬盘阵列3倍的并发流量,综合效率提升10倍以上。网络安全技术(networksecuritytechnology)视联网的结构性设计通过每次服务单独许可制、设备与用户数据完全隔离等方式从结构上彻底根除了困扰互联网的网络安全问题,一般不需要杀毒程序、防火墙,杜绝了黑客与病毒的攻击,为用户提供结构性的无忧安全网络。服务创新技术(serviceinnovationtechnology)统一视频平台将业务与传输融合在一起,不论是单个用户、私网用户还是一个网络的总合,都不过是一次自动连接。用户终端、机顶盒或pc直接连到统一视频平台,获得丰富多彩的各种形态的多媒体视频服务。统一视频平台采用“菜谱式”配表模式来替代传统的复杂应用编程,可以使用非常少的代码即可实现复杂的应用,实现“无限量”的新业务创新。视联网的组网如下所述:视联网是一种集中控制的网络结构,该网络可以是树型网、星型网、环状网等等类型,但在此基础上网络中需要有集中控制节点来控制整个网络。如图1所示,视联网分为接入网和城域网两部分。接入网部分的设备主要可以分为3类:节点服务器,接入交换机,终端(包括各种机顶盒、编码板、存储器等)。节点服务器与接入交换机相连,接入交换机可以与多个终端相连,并可以连接以太网。其中,节点服务器是接入网中起集中控制功能的节点,可控制接入交换机和终端。节点服务器可直接与接入交换机相连,也可以直接与终端相连。类似的,城域网部分的设备也可以分为3类:城域服务器,节点交换机,节点服务器。城域服务器与节点交换机相连,节点交换机可以与多个节点服务器相连。其中,节点服务器即为接入网部分的节点服务器,即节点服务器既属于接入网部分,又属于城域网部分。城域服务器是城域网中起集中控制功能的节点,可控制节点交换机和节点服务器。城域服务器可直接连接节点交换机,也可直接连接节点服务器。由此可见,整个视联网络是一种分层集中控制的网络结构,而节点服务器和城域服务器下控制的网络可以是树型、星型、环状等各种结构。形象地称,接入网部分可以组成统一视频平台(虚线圈中部分),多个统一视频平台可以组成视联网;每个统一视频平台可以通过城域以及广域视联网互联互通。视联网设备分类1.1本发明实施例的视联网中的设备主要可以分为3类:服务器,交换机(包括以太网网关),终端(包括各种机顶盒,编码板,存储器等)。视联网整体上可以分为城域网(或者国家网、全球网等)和接入网。1.2其中接入网部分的设备主要可以分为3类:节点服务器,接入交换机(包括以太网网关),终端(包括各种机顶盒,编码板,存储器等)。各接入网设备的具体硬件结构为:节点服务器:如图2所示,主要包括网络接口模块201、交换引擎模块202、cpu模块203、磁盘阵列模块204;其中,网络接口模块201,cpu模块203、磁盘阵列模块204进来的包均进入交换引擎模块202;交换引擎模块202对进来的包进行查地址表205的操作,从而获得包的导向信息;并根据包的导向信息把该包存入对应的包缓存器206的队列;如果包缓存器206的队列接近满,则丢弃;交换引擎模202轮询所有包缓存器队列,如果满足以下条件进行转发:1)该端口发送缓存未满;2)该队列包计数器大于零。磁盘阵列模块204主要实现对硬盘的控制,包括对硬盘的初始化、读写等操作;cpu模块203主要负责与接入交换机、终端(图中未示出)之间的协议处理,对地址表205(包括下行协议包地址表、上行协议包地址表、数据包地址表)的配置,以及,对磁盘阵列模块204的配置。接入交换机:如图3所示,主要包括网络接口模块(下行网络接口模块301、上行网络接口模块302)、交换引擎模块303和cpu模块304;其中,下行网络接口模块301进来的包(上行数据)进入包检测模块305;包检测模块305检测包的目地地址(da)、源地址(sa)、数据包类型及包长度是否符合要求,如果符合,则分配相应的流标识符(stream-id),并进入交换引擎模块303,否则丢弃;上行网络接口模块302进来的包(下行数据)进入交换引擎模块303;cpu模块304进来的数据包进入交换引擎模块303;交换引擎模块303对进来的包进行查地址表306的操作,从而获得包的导向信息;如果进入交换引擎模块303的包是下行网络接口往上行网络接口去的,则结合流标识符(stream-id)把该包存入对应的包缓存器307的队列;如果该包缓存器307的队列接近满,则丢弃;如果进入交换引擎模块303的包不是下行网络接口往上行网络接口去的,则根据包的导向信息,把该数据包存入对应的包缓存器307的队列;如果该包缓存器307的队列接近满,则丢弃。交换引擎模块303轮询所有包缓存器队列,在本发明实施例中分两种情形:如果该队列是下行网络接口往上行网络接口去的,则满足以下条件进行转发:1)该端口发送缓存未满;2)该队列包计数器大于零;3)获得码率控制模块产生的令牌;如果该队列不是下行网络接口往上行网络接口去的,则满足以下条件进行转发:1)该端口发送缓存未满;2)该队列包计数器大于零。码率控制模块308是由cpu模块304来配置的,在可编程的间隔内对所有下行网络接口往上行网络接口去的包缓存器队列产生令牌,用以控制上行转发的码率。cpu模块304主要负责与节点服务器之间的协议处理,对地址表306的配置,以及,对码率控制模块308的配置。以太网协转网关:如图4所示,主要包括网络接口模块(下行网络接口模块401、上行网络接口模块402)、交换引擎模块403、cpu模块404、包检测模块405、码率控制模块408、地址表406、包缓存器407和mac添加模块409、mac删除模块410。其中,下行网络接口模块401进来的数据包进入包检测模块405;包检测模块405检测数据包的以太网macda、以太网macsa、以太网lengthorframetype、视联网目地地址da、视联网源地址sa、视联网数据包类型及包长度是否符合要求,如果符合则分配相应的流标识符(stream-id);然后,由mac删除模块410减去macda、macsa、lengthorframetype(2byte),并进入相应的接收缓存,否则丢弃;下行网络接口模块401检测该端口的发送缓存,如果有包则根据包的视联网目地地址da获知对应的终端的以太网macda,添加终端的以太网macda、以太网协转网关的macsa、以太网lengthorframetype,并发送。以太网协转网关中其他模块的功能与接入交换机类似。终端:主要包括网络接口模块、业务处理模块和cpu模块;例如,机顶盒主要包括网络接口模块、视音频编解码引擎模块、cpu模块;编码板主要包括网络接口模块、视音频编码引擎模块、cpu模块;存储器主要包括网络接口模块、cpu模块和磁盘阵列模块。1.3城域网部分的设备主要可以分为2类:节点服务器,节点交换机,城域服务器。其中,节点交换机主要包括网络接口模块、交换引擎模块和cpu模块;城域服务器主要包括网络接口模块、交换引擎模块和cpu模块构成。2、视联网数据包定义2.1接入网数据包定义接入网的数据包主要包括以下几部分:目的地址(da)、源地址(sa)、保留字节、payload(pdu)、crc。如下表所示,接入网的数据包主要包括以下几部分:dasareservedpayloadcrc其中:目的地址(da)由8个字节(byte)组成,第一个字节表示数据包的类型(例如各种协议包、组播数据包、单播数据包等),最多有256种可能,第二字节到第六字节为城域网地址,第七、第八字节为接入网地址;源地址(sa)也是由8个字节(byte)组成,定义与目的地址(da)相同;保留字节由2个字节组成;payload部分根据不同的数据报的类型有不同的长度,如果是各种协议包的话是64个字节,如果是单组播数据包话是32+1024=1056个字节,当然并不仅仅限于以上2种;crc有4个字节组成,其计算方法遵循标准的以太网crc算法。2.2城域网数据包定义城域网的拓扑是图型,两个设备之间可能有2种、甚至2种以上的连接,即节点交换机和节点服务器、节点交换机和节点交换机、节点交换机和节点服务器之间都可能超过2种连接。但是,城域网设备的城域网地址却是唯一的,为了精确描述城域网设备之间的连接关系,在本发明实施例中引入参数:标签,来唯一描述一个城域网设备。本说明书中标签的定义和mpls(multi-protocollabelswitch,多协议标签交换)的标签的定义类似,假设设备a和设备b之间有两个连接,那么数据包从设备a到设备b就有2个标签,数据包从设备b到设备a也有2个标签。标签分入标签、出标签,假设数据包进入设备a的标签(入标签)是0x0000,这个数据包离开设备a时的标签(出标签)可能就变成了0x0001。城域网的入网流程是集中控制下的入网过程,也就意味着城域网的地址分配、标签分配都是由城域服务器主导的,节点交换机、节点服务器都是被动的执行而已,这一点与mpls的标签分配是不同的,mpls的标签分配是交换机、服务器互相协商的结果。如下表所示,城域网的数据包主要包括以下几部分:dasareserved标签payloadcrc即目的地址(da)、源地址(sa)、保留字节(reserved)、标签、payload(pdu)、crc。其中,标签的格式可以参考如下定义:标签是32bit,其中高16bit保留,只用低16bit,它的位置是在数据包的保留字节和payload之间。基于视联网的上述特性,提出了本发明实施例的核心构思之一,遵循视联网的协议,对应用的部分功能模块进行浏览器代理,而对其他功能模块不进行浏览器代理。参照图5,示出了本发明的一种通信方法实施例的步骤流程图,该方法可以应用于视联网中,所述视联网包括:视联网终端、视联网服务器、视联猫服务端、视联猫客户端、互联网终端,具体可以包括如下步骤:步骤501,所述视联网终端将待发送的数据报文,通过视联网服务器发送至所述视联猫客户端;本发明实施例中,如图5a所示视联网中包括视联猫客户端和视联猫服务端,其中,视联猫是一款视联网网关产品,通过对视联网v2v协议和互联网tcp/ip协议的转换,为视联网用户提供网页浏览、即时通信、视频观看等互联网业务接入能力。视联猫产品由视联网isp服务器(即视联猫服务端)、视联网数据代理服务器(即视联猫客户端)组成。其中,视联猫服务端部署于互联网网络侧,视联猫客户端部署于用户侧,二者之间通过视联网建立传输通道。视联猫客户端在视联网端提供服务,而视联猫服务端互联网端提供服务,在下面视联猫客户端和视联猫服务端分别简称为猫和猫王,其中,初始化时,猫王和猫分别在视联网服务器上注册虚拟终端节点,把所有的终端节点和服务器报文类型通过netlink加载到各自的linux内核中,猫王和猫通过视联网服务器入网成功后,拨通可视电话,建立视联网隧道,内核更新终端节点信息,进行数据报文转发。此时视联网终端将待发送的报文数据发送至视联网服务器,有视联网服务器查找该视联网终端地址对应的视联猫客户端,并将该视联网报发送到该视联猫客户端。实际应用中,当视联网终端想访问互联网时,首先通过视联网服务器发送一个互联网通信请求到猫,此时,猫和猫王与视联网服务器交互的v2v信令报文进入linux内核,然后通过libpcab和bpf规则过滤后,使得各自的终端节点入网成功,猫王接收猫发过来的拨通可视电话,建立隧道,开始进行数据面报文转发,所以在连接建立之前包括:优选的,步骤501,包括:子步骤a1-a2;子步骤a1,所述视联网终端将待发送的数据报文,通过视联网接入控制器发送到所述视联网服务器内核协议栈;实际应用中,猫接收到用户的数据报文,从协议栈上送到网桥,网桥处理转发到视联口,根据视联口终端节点信息,将用户报文封装成v2v视联网协议数据。其中,用户的数据报文通过一个虚拟局域网vlan(virtuallocalarea)的ac(accesscontroller,接入控制器)接入从以太口进来送到linux内核协议栈,协议栈软转发上送到网桥,网桥上绑定一个vsi(virtualswitchinterface,虚拟交换接口)转发实例,vsi与vlan一一对应,用户业务数据由此进入内核网桥转发流程。子步骤a2,所述视联网服务器内核协议栈通过虚拟交换接口的转发实例,将所述待发送的数据报文转发至所述视联猫客户端。具体的,参照图5b,当用户业务数据进入内核网桥转发流程,由视联网服务器转发至视联猫客户端,猫收到用户数据报文后,linux内核首先自定义nf_hook_ops存储钩子的数据结构,这个结构体内容注册到nf_hooks链表中。具体的,自定义的钩子函数结构体为:将该结构体注册到内核nf_hooks链表,当运行到iptables机制的nf_br_post_routing挂载点时,会调用vsi_nf_post_routing函数将用户数据报文封装成v2v视联网协议发送到mpls(multi-protocollabelswitching,多协议标签交换)隧道。其中mpls中设置的是视联网与公网的通信协议,以在接收到视联网报文后进行转换并继续发送。除此之外,在系统初始化后,猫和猫王准备接收信令报文,定时器每秒更新终端节点信息。其中,利用linux系统应用程序编程接口每1秒产生一个定时器,系统收到信号后就执行定时器函数,该函数判断每个终端节点的状态,并把每个终端节点的状态信息更新到内核中。步骤502,所述视联猫客户端将所述待发送的数据报文封装成视联网报文,并通过所述视联猫客户端网关发送至对应目标地址的所述视联猫服务端;所述视联网报文包括目标地址;本发明实施例中,根据上述步骤描述的,视联猫客户端想要继续传送,首先要将待传输的数据按照当前网络的通信协议进行封装,其中要将待传输的数据报文按照传送目标的地址,发送至对应的视联网服务端。视联猫客户端网关通过预设传送机制和接口,将封装好的视联网报文传输至对应外网服务端,即视联猫服务端,也称猫王,如图5a所示的,为一个视联网互联网融合网关,与外网连接。优选地,步骤502,包括:子步骤b1-b2;子步骤b1,所述视联猫客户端将所述待发送的数据报文,按照视联网报文封装成视联网报文;具体地,视联猫客户端将接收到的待发送的数据报文,根据视联网通信协议,添加报文头后封装为视联网报文,继续进行传输。子步骤b2,所述视联猫客户端调用点对点发送函数,将所述视联网报文通过虚拟交换接口,发送至对应目标地址的所述视联猫服务端网关。具体地,当钩子结构体运行到iptables机制的nf_br_post_routing挂载点时,会调用v2v发送函数,内核将用户数据分片,并按照v2v视联网协议将用户数据封装成视联网报文,从vsi上的虚拟以太网接口送出并通过mpls隧道透明传输到对端猫王上。步骤503,所述视联猫服务端接收到所述视联网报文,并将所述视联网报文重组为互联网报文;本发明实施例中,如图5b所示的,猫王接收猫发来的视联网报文时,在内核中首先把自定义packet_type结构体注册到type对应linux内核的list_head链表上面,根据第二层设置的ip协议调用接收函数接收已封装好的视联网数据报文。接收报文后直接到vsi转发实例上,根据报文的目的mac找到终端节点。优选的,步骤503包括:子步骤c1-c4;子步骤c1,所述视联猫服务端网关通过ip协议调用接收函数,接收所述视联网报文;子步骤c2,所述视联猫服务端判断所述视联网报文中的ip数据包有没有丢失或者乱序;子步骤c3,如果存在丢失或者乱序,则丢弃相应分片;子步骤c4,如果不存在丢失或者乱序,则将所述ip数据包添加ip头,重组成完整的互联网报文。具体的,猫王接收到视联网报文后,判断发送过来的ip数据包有没有丢失或者乱序,如果有,则丢弃对应确实或者乱序的分片,如果没有,则将互联网ip报文中的视联包数据字段的ip报文复制到ip重组区,计算并添加ip头,重新组合成完整的互联网报文,并且最后转发到互联网。步骤504,所述视联猫服务端根据所述目标地址查找对应的所述互联网终端,并将所述互联网报文发送至所述互联网终端。本发明实施例中,视联猫服务端根据封装成的互联网报文中存储的目标地址,查找对应该地址的互联网终端,一般情况下,该地址为mac地址,存储在视联猫服务端中的是mac地址列表,对应该视联猫服务端管理的或者连接的可以进行数据传输的互联网终端。具体的,当检测到接收的ip包没有丢失和乱序,则把v2v数据报文中的二层用户数据重新组成完整的数据报文,再加上ip头部从桥接设备转发到互联网中。优选的,还包括:步骤505,所述视联猫服务端网关通过ip协议调用接收函数,接收所述互联网终端返回的响应数据包;所述响应数据包包含响应目的地址。本发明实施例中,互联网响应数据包就是一个互联网ip报文,包含响应视联网请求的数据包,其中,当视联猫终端接收到响应数据包后,视联猫服务端网关通过ip协议调用接收函数接收该互联网ip报文。步骤506,所述视联猫服务端将所述响应数据包重组为视联网报文;本发明实施例中,当视联猫服务端接收到该互联网响应数据后进行解析,提取其中的视联网响应数据,并重组为视联网报文。其中需要判断视联网响应数据是否存在丢失和乱序,如果没有,则把v2v数据报文中的二层用户数据重新组成完整的数据报文,再通过视联网通信协议将该数据报文封装成完整的视联网报文从桥接设备转发到视联猫客户端。步骤507,所述视联猫服务端将所述视联网报文发送至对应所述响应地址的所述视联猫客户端。本发明实施例中,通常情况下,在视联猫服务端接收到的互联网响应数据中包含有响应目的地址,视联猫服务端可以根据该地址查找到对应的视联猫客户端,进而转发至该视联猫客户端。步骤508,所述视联猫客户端解析出所述视联网报文中的视联网数据包,发送至对应至所述响应目的地址的所述视联网终端。具体的,猫接收视联网报文后,通过起终点额目的地址找到对应的视联网终端,并转发至该视联网终端,实现视联网与互联网一次完整的数据交互传输。具体过程由图5c所示,描述的是在视联猫客户端或视联猫服务端上应用linux通用的防火墙核心框架,实现数据包的发送和接收。视联网报文从物理网卡进入linux内核协议栈后,调用v2v接收模块,该模块根据视联网报文的目的mac地址找到视联网终端,根据存储的视联网终端信息还原原有的ip报文,并重新发送到linux内核协议栈,进入ip报文转发流程。首先对ip报文进行校验后,进入nf_ip_pre_routing钩子函数处理;经过路由选择,判断数据包不是发往本机,则转发至nf_inet_forward钩子函数处理,过滤需要转发的ip数据包;然后进入nf_ip_post_routing钩子函数处理,调用v2v接收模块,筛选视联猫客户端或视联猫服务端需要发送到网络的数据包,这里发现不是视联网报文,直接发送到网络上,以上是视联网报文的接收过程。ip报文从物理网卡进入协议栈后,调用v2v接收模块,发现不是视联网报文,直接按着上述流程进入nf_ip_post_routing钩子函数处理流程,调用v2v接收模块,根据ip报文的ip地址找到视联网终端,根据存储的视联网终端信息把ip报文封装成v2v报文后,然后从视联猫客户端或视联猫服务端发送到对端,以上是视联网报文的发送过程。在本发明实施例中,所述视联网包括:视联网终端、视联网服务器、视联猫服务端、视联猫客户端、互联网终端,所述方法包括:所述视联网终端将待发送的数据报文,通过视联网服务器发送至所述视联猫客户端;所述视联猫客户端将所述待发送的数据报文封装成视联网报文,并通过所述视联猫客户端网关发送至对应目标地址的所述视联猫服务端;所述视联网报文包括目标地址;所述视联猫服务端接收到所述视联网报文,并将所述视联网报文重组为互联网报文;所述视联猫服务端根据所述目标地址查找对应的所述互联网终端,并将所述互联网报文发送至所述互联网终端。解决了现有技术中在视联网数据与互联网数据不能交互的问题,取得了可以对视联网终端在不限制应用环境的情况下访问互联网的有益效果。需要说明的是,对于方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本发明实施例并不受所描述的动作顺序的限制,因为依据本发明实施例,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于优选实施例,所涉及的动作并不一定是本发明实施例所必须的。参照图6,示出了本发明的一种通信装置实施例的结构框图,所述装置应用于视联网中,所述视联网包括:视联网终端、视联网服务器、视联猫服务端、视联猫客户端、互联网终端,具体可以包括:报文转发装置601,用于所述视联网终端将待发送的数据报文,通过视联网服务器发送至所述视联猫客户端;优选地,所述报文转发装置601,包括:内核转发子模块,用于所述视联网终端将待发送的数据报文,通过视联网接入控制器发送到所述视联网服务器内核协议栈;转发子模块,用于所述视联网服务器内核协议栈通过虚拟交换接口的转发实例,将所述待发送的数据报文转发至所述视联猫客户端。封装模块602,用于所述视联猫客户端将所述待发送的数据报文封装成视联网报文,并通过所述视联猫客户端网关发送至对应目标地址的所述视联猫服务端;所述视联网报文包括目标地址;优选地,所述封装模块602,包括:封装子模块,用于所述视联猫客户端将所述待发送的数据报文,按照视联网报文封装成视联网报文;发送子模块,用于所述视联猫客户端调用点对点发送函数,将所述视联网报文通过虚拟交换接口,发送至对应目标地址的所述视联猫服务端网关。重组模块603,用于所述视联猫服务端接收到所述视联网报文,并将所述视联网报文重组为互联网报文;优选地,所述重组模块603,包括:接收子模块,用于所述视联猫服务端网关通过ip协议调用接收函数,接收所述视联网报文;判断子模块,用于所述视联猫服务端判断所述视联网报文中的ip数据包有没有丢失或者乱序;丢弃子模块,用于如果存在丢失或者乱序,则丢弃相应分片;重组子模块,用于如果不存在丢失或者乱序,则将所述ip数据包添加ip头,重组成完整的互联网报文。发送模块604,用于所述视联猫服务端根据所述目标地址查找对应的所述互联网终端,并将所述互联网报文发送至所述互联网终端。优选地,还包括:还包括:响应数据包接收模块,用于所述视联猫服务端网关通过ip协议调用接收函数,接收所述互联网终端返回的响应数据包;所述响应数据包包含响应目的地址;报文重组模块,用于所述视联猫服务端将所述响应数据包重组为视联网报文;返回发送模块,用于所述视联猫服务端将所述视联网报文发送至对应所述响应地址的所述视联猫客户端;响应数据返回模块,用于所述视联猫客户端解析出所述视联网报文中的视联网数据包,发送至对应至所述响应目的地址的所述视联网终端。在本发明实施例中,通过报文转发装置,用于所述视联网终端将待发送的数据报文,通过视联网服务器发送至所述视联猫客户端;封装模块,用于所述视联猫客户端将所述待发送的数据报文封装成视联网报文,并通过所述视联猫客户端网关发送至对应目标地址的所述视联猫服务端;所述视联网报文包括目标地址;重组模块,用于所述视联猫服务端接收到所述视联网报文,并将所述视联网报文重组为互联网报文;发送模块,用于所述视联猫服务端根据所述目标地址查找对应的所述互联网终端,并将所述互联网报文发送至所述互联网终端。解决了现有技术中在视联网数据与互联网数据不能交互的问题,取得了可以对视联网终端在不限制应用环境的情况下访问互联网的有益效果。对于装置实施例而言,由于其与方法实施例基本相似,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。本说明书中的各个实施例均采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似的部分互相参见即可。本领域内的技术人员应明白,本发明实施例的实施例可提供为方法、装置、或计算机程序产品。因此,本发明实施例可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明实施例可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、cd-rom、光学存储器等)上实施的计算机程序产品的形式。本发明实施例是参照根据本发明实施例的方法、终端设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理终端设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理终端设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理终端设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。这些计算机程序指令也可装载到计算机或其他可编程数据处理终端设备上,使得在计算机或其他可编程终端设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程终端设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。尽管已描述了本发明实施例的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例做出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本发明实施例范围的所有变更和修改。最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者终端设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者终端设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者终端设备中还存在另外的相同要素。以上对本发明所提供的一种通信方法和通信装置,进行了详细介绍,本文中应用了具体个例对本发明的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本发明的方法及其核心思想;同时,对于本领域的一般技术人员,依据本发明的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本发明的限制。当前第1页12当前第1页12
当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1