CN109491804A - 消息传输方法和装置 - Google Patents

消息传输方法和装置 Download PDF

Info

Publication number
CN109491804A
CN109491804A CN201811184645.XA CN201811184645A CN109491804A CN 109491804 A CN109491804 A CN 109491804A CN 201811184645 A CN201811184645 A CN 201811184645A CN 109491804 A CN109491804 A CN 109491804A
Authority
CN
China
Prior art keywords
functional module
message
module
sent
message center
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.)
Pending
Application number
CN201811184645.XA
Other languages
English (en)
Inventor
崔博
赵明
刘宝臣
王艳辉
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Visionvera Information Technology Co Ltd
Original Assignee
Visionvera Information Technology Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Visionvera Information Technology Co Ltd filed Critical Visionvera Information Technology Co Ltd
Priority to CN201811184645.XA priority Critical patent/CN109491804A/zh
Publication of CN109491804A publication Critical patent/CN109491804A/zh
Pending legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/546Message passing systems or structures, e.g. queues
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/547Remote procedure calls [RPC]; Web services

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

本发明实施例提供了一种消息传输方法及装置,应用于视联网终端中,视联网终端包括消息中心模块及多个功能模块。其中方法包括:消息中心模块分别检测各个功能模块是否存在待发送的消息;消息中心模块从检测结果为存在的源功能模块中提取所述待发送的消息;所述待发送的消息中包括目的功能模块的标识;消息中心模块依据所述目的功能模块的标识,将所述待发送的消息转发到所述目的功能模块。本发明实施例中通过消息中心模块统一进行各个功能模块之间消息的传输,而各个功能模块之间无需再直接调用,降低了功能模块之间的耦合性,避免了对视联网终端系统的运行产生影响。

Description

消息传输方法和装置
技术领域
本发明涉及视联网技术领域,特别是涉及一种消息传输方法和一种消息传输装置。
背景技术
随着网络科技的快速发展,用户越来越多地通过网络进行各种通信。用户用于进行网络通信的终端也迅速发展,比如手机、平板电脑,等等。终端中包括多个功能模块,每个功能模块可以实现不同的功能,比如采集模块可以用于采集数据,发送模块可以用于发送数据,等等。
现有技术中,各个功能模块之间如果想要相互传输消息,则需要实现模块之间的调用,也即要发送消息的功能模块调用要接收消息的功能模块,通过模块之间的相互调用实现消息的传输。
但是,上述方式中需要各个功能模块之间具有较强的耦合性,并且模块之间的频繁调用可能会影响系统的正常运行。
发明内容
鉴于上述问题,提出了本发明实施例以便提供一种克服上述问题或者至少部分地解决上述问题的一种消息传输方法和相应的一种消息传输装置。
为了解决上述问题,本发明实施例公开了一种消息传输方法,所述方法应用于视联网终端中,所述视联网终端包括消息中心模块及多个功能模块,所述方法包括:
所述消息中心模块分别检测各个功能模块是否存在待发送的消息;
所述消息中心模块从检测结果为存在的源功能模块中提取所述待发送的消息;所述待发送的消息中包括目的功能模块的标识;
所述消息中心模块依据所述目的功能模块的标识,将所述待发送的消息转发到所述目的功能模块。
优选地,在所述消息中心模块分别检测各个功能模块是否存在待发送的消息的步骤之前,还包括:所述消息中心模块分别接收各个功能模块发送的注册信息,进行所述功能模块向所述消息中心模块的注册。
优选地,所述功能模块包括预设的发送接口及发送队列,所述消息中心模块分别检测各个功能模块是否存在待发送的消息的步骤,包括:所述消息中心模块通过各个功能模块的发送接口,遍历各个功能模块的发送队列,检测所述发送队列中是否存在待发送的消息。
优选地,所述功能模块包括预设的接收接口及接收队列,所述消息中心模块依据所述目的功能模块的标识,将所述待发送的消息转发到所述目的功能模块的步骤,包括:所述消息中心模块依据所述目的功能模块的标识,通过所述目的功能模块的接收接口,将所述待发送的消息转发到所述目的功能模块的接收队列中。
优选地,所述功能模块包括预设的发送接口及发送队列,所述消息中心模块从检测结果为存在的源功能模块中提取所述待发送的消息的步骤,包括:所述消息中心模块通过所述源功能模块的发送接口,从所述源功能模块的发送队列中提取所述待发送的消息。
另一方面,本发明实施例还公开了一种消息传输装置,所述装置应用于视联网终端中,所述视联网终端包括消息中心模块及多个功能模块,所述消息中心模块包括:
检测单元,用于分别检测各个功能模块是否存在待发送的消息;
提取单元,用于从检测结果为存在的源功能模块中提取所述待发送的消息;所述待发送的消息中包括目的功能模块的标识;
转发单元,用于依据所述目的功能模块的标识,将所述待发送的消息转发到所述目的功能模块。
优选地,所述消息中心模块还包括:注册单元,用于分别接收各个功能模块发送的注册信息,进行所述功能模块向所述消息中心模块的注册。
优选地,所述功能模块包括预设的发送接口及发送队列,所述检测单元,具体用于通过各个功能模块的发送接口,遍历各个功能模块的发送队列,检测所述发送队列中是否存在待发送的消息。
优选地,所述功能模块包括预设的接收接口及接收队列,所述转发单元,具体用于依据所述目的功能模块的标识,通过所述目的功能模块的接收接口,将所述待发送的消息转发到所述目的功能模块的接收队列中。
优选地,所述功能模块包括预设的发送接口及发送队列,所述提取单元,具体用于通过所述源功能模块的发送接口,从所述源功能模块的发送队列中提取所述待发送的消息。
本发明实施例中,消息传输方法应用于视联网终端中,视联网终端包括消息中心模块及多个功能模块。在进行消息传输过程中,消息中心模块分别检测各个功能模块是否存在待发送的消息;消息中心模块从检测结果为存在的源功能模块中提取所述待发送的消息,所述待发送的消息中包括目的功能模块的标识;消息中心模块依据所述目的功能模块的标识,将所述待发送的消息转发到所述目的功能模块。由此可知,本发明实施例中通过消息中心模块统一进行各个功能模块之间消息的传输,而各个功能模块之间无需再直接调用,降低了功能模块之间的耦合性,避免了对视联网终端系统的运行产生影响。
附图说明
图1是本发明的一种视联网的组网示意图;
图2是本发明的一种节点服务器的硬件结构示意图;
图3是本发明的一种接入交换机的硬件结构示意图;
图4是本发明的一种以太网协转网关的硬件结构示意图;
图5是本发明实施例一的一种消息传输方法的步骤流程图;
图6是本发明实施例二的一种消息传输方法的步骤流程图;
图7是本发明实施例三的一种消息传输装置的结构框图。
具体实施方式
为使本发明的上述目的、特征和优点能够更加明显易懂,下面结合附图和具体实施方式对本发明作进一步详细的说明。
视联网是网络发展的重要里程碑,是一个实时网络,能够实现高清视频实时传输,将众多互联网应用推向高清视频化,高清面对面。
视联网采用实时高清视频交换技术,可以在一个网络平台上将所需的服务,如高清视频会议、视频监控、智能化监控分析、应急指挥、数字广播电视、延时电视、网络教学、现场直播、VOD点播、电视邮件、个性录制(PVR)、内网(自办)频道、智能化视频播控、信息发布等数十种视频、语音、图片、文字、通讯、数据等服务全部整合在一个系统平台,通过电视或电脑实现高清品质视频播放。
为使本领域技术人员更好地理解本发明实施例,以下对视联网进行介绍:
视联网所应用的部分技术如下所述:
网络技术(Network Technology)
视联网的网络技术创新改良了传统以太网(Ethernet),以面对网络上潜在的巨大视频流量。不同于单纯的网络分组包交换(Packet Switching)或网络电路交换(CircuitSwitching),视联网技术采用Packet Switching满足Streaming需求。视联网技术具备分组交换的灵活、简单和低价,同时具备电路交换的品质和安全保证,实现了全网交换式虚拟电路,以及数据格式的无缝连接。
交换技术(Switching Technology)
视联网采用以太网的异步和包交换两个优点,在全兼容的前提下消除了以太网缺陷,具备全网端到端无缝连接,直通用户终端,直接承载IP数据包。用户数据在全网范围内不需任何格式转换。视联网是以太网的更高级形态,是一个实时交换平台,能够实现目前互联网无法实现的全网大规模高清视频实时传输,将众多网络视频应用推向高清化、统一化。
服务器技术(Server Technology)
视联网和统一视频平台上的服务器技术不同于传统意义上的服务器,它的流媒体传输是建立在面向连接的基础上,其数据处理能力与流量、通讯时间无关,单个网络层就能够包含信令及数据传输。对于语音和视频业务来说,视联网和统一视频平台流媒体处理的复杂度比数据处理简单许多,效率比传统服务器大大提高了百倍以上。
储存器技术(Storage Technology)
统一视频平台的超高速储存器技术为了适应超大容量和超大流量的媒体内容而采用了最先进的实时操作系统,将服务器指令中的节目信息映射到具体的硬盘空间,媒体内容不再经过服务器,瞬间直接送达到用户终端,用户等待一般时间小于0.2秒。最优化的扇区分布大大减少了硬盘磁头寻道的机械运动,资源消耗仅占同等级IP互联网的20%,但产生大于传统硬盘阵列3倍的并发流量,综合效率提升10倍以上。
网络安全技术(Network Security Technology)
视联网的结构性设计通过每次服务单独许可制、设备与用户数据完全隔离等方式从结构上彻底根除了困扰互联网的网络安全问题,一般不需要杀毒程序、防火墙,杜绝了黑客与病毒的攻击,为用户提供结构性的无忧安全网络。
服务创新技术(Service Innovation Technology)
统一视频平台将业务与传输融合在一起,不论是单个用户、私网用户还是一个网络的总合,都不过是一次自动连接。用户终端、机顶盒或PC直接连到统一视频平台,获得丰富多彩的各种形态的多媒体视频服务。统一视频平台采用“菜谱式”配表模式来替代传统的复杂应用编程,可以使用非常少的代码即可实现复杂的应用,实现“无限量”的新业务创新。
视联网的组网如下所述:
视联网是一种集中控制的网络结构,该网络可以是树型网、星型网、环状网等等类型,但在此基础上网络中需要有集中控制节点来控制整个网络。
如图1所示,视联网分为接入网和城域网两部分。
接入网部分的设备主要可以分为3类:节点服务器,接入交换机,终端(包括各种机顶盒、编码板、存储器等)。节点服务器与接入交换机相连,接入交换机可以与多个终端相连,并可以连接以太网。
其中,节点服务器是接入网中起集中控制功能的节点,可控制接入交换机和终端。节点服务器可直接与接入交换机相连,也可以直接与终端相连。
类似的,城域网部分的设备也可以分为3类:城域服务器,节点交换机,节点服务器。城域服务器与节点交换机相连,节点交换机可以与多个节点服务器相连。
其中,节点服务器即为接入网部分的节点服务器,即节点服务器既属于接入网部分,又属于城域网部分。
城域服务器是城域网中起集中控制功能的节点,可控制节点交换机和节点服务器。城域服务器可直接连接节点交换机,也可直接连接节点服务器。
由此可见,整个视联网络是一种分层集中控制的网络结构,而节点服务器和城域服务器下控制的网络可以是树型、星型、环状等各种结构。
形象地称,接入网部分可以组成统一视频平台(虚线圈中部分),多个统一视频平台可以组成视联网;每个统一视频平台可以通过城域以及广域视联网互联互通。
1、视联网设备分类
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模块204进来的数据包进入交换引擎模块303;交换引擎模块303对进来的包进行查地址表306的操作,从而获得包的导向信息;如果进入交换引擎模块303的包是下行网络接口往上行网络接口去的,则结合流标识符(stream-id)把该包存入对应的包缓存器307的队列;如果该包缓存器307的队列接近满,则丢弃;如果进入交换引擎模块303的包不是下行网络接口往上行网络接口去的,则根据包的导向信息,把该数据包存入对应的包缓存器307的队列;如果该包缓存器307的队列接近满,则丢弃。
交换引擎模块303轮询所有包缓存器队列,在本发明实施例中分两种情形:
如果该队列是下行网络接口往上行网络接口去的,则满足以下条件进行转发:1)该端口发送缓存未满;2)该队列包计数器大于零;3)获得码率控制模块产生的令牌;
如果该队列不是下行网络接口往上行网络接口去的,则满足以下条件进行转发:1)该端口发送缓存未满;2)该队列包计数器大于零。
码率控制模块208是由CPU模块204来配置的,在可编程的间隔内对所有下行网络接口往上行网络接口去的包缓存器队列产生令牌,用以控制上行转发的码率。
CPU模块304主要负责与节点服务器之间的协议处理,对地址表306的配置,以及,对码率控制模块308的配置。
以太网协转网关
如图4所示,主要包括网络接口模块(下行网络接口模块401、上行网络接口模块402)、交换引擎模块403、CPU模块404、包检测模块405、码率控制模块408、地址表406、包缓存器407和MAC添加模块409、MAC删除模块410。
其中,下行网络接口模块401进来的数据包进入包检测模块405;包检测模块405检测数据包的以太网MAC DA、以太网MAC SA、以太网length or frame type、视联网目的地址DA、视联网源地址SA、视联网数据包类型及包长度是否符合要求,如果符合则分配相应的流标识符(stream-id);然后,由MAC删除模块410减去MAC DA、MAC SA、length or frame type(2byte),并进入相应的接收缓存,否则丢弃;
下行网络接口模块401检测该端口的发送缓存,如果有包则根据包的视联网目的地址DA获知对应的终端的以太网MAC DA,添加终端的以太网MAC DA、以太网协转网关的MACSA、以太网length or frame type,并发送。
以太网协转网关中其他模块的功能与接入交换机类似。
终端:
主要包括网络接口模块、业务处理模块和CPU模块;例如,机顶盒主要包括网络接口模块、视音频编解码引擎模块、CPU模块;编码板主要包括网络接口模块、视音频编码引擎模块、CPU模块;存储器主要包括网络接口模块、CPU模块和磁盘阵列模块。
1.3城域网部分的设备主要可以分为2类:节点服务器,节点交换机,城域服务器。其中,节点交换机主要包括网络接口模块、交换引擎模块和CPU模块;城域服务器主要包括网络接口模块、交换引擎模块和CPU模块构成。
2、视联网数据包定义
2.1接入网数据包定义
接入网的数据包主要包括以下几部分:目的地址(DA)、源地址(SA)、保留字节、payload(PDU)、CRC。
如下表所示,接入网的数据包主要包括以下几部分:
DA SA Reserved Payload CRC
其中:
目的地址(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-Protocol Label Switch,多协议标签交换)的标签的定义类似,假设设备A和设备B之间有两个连接,那么数据包从设备A到设备B就有2个标签,数据包从设备B到设备A也有2个标签。标签分入标签、出标签,假设数据包进入设备A的标签(入标签)是0x0000,这个数据包离开设备A时的标签(出标签)可能就变成了0x0001。城域网的入网流程是集中控制下的入网过程,也就意味着城域网的地址分配、标签分配都是由城域服务器主导的,节点交换机、节点服务器都是被动的执行而已,这一点与MPLS的标签分配是不同的,MPLS的标签分配是交换机、服务器互相协商的结果。
如下表所示,城域网的数据包主要包括以下几部分:
DA SA Reserved 标签 Payload CRC
即目的地址(DA)、源地址(SA)、保留字节(Reserved)、标签、payload(PDU)、CRC。其中,标签的格式可以参考如下定义:标签是32bit,其中高16bit保留,只用低16bit,它的位置是在数据包的保留字节和payload之间。
实施例一
本发明实施例的消息传输方法可以应用于视联网终端中。在视联网终端中可以包括多个功能模块,比如UI模块(界面模块)、Player模块(播放模块)、Capture模块(采集模块)、发送模块、接收模块,等等。本发明实施例的视联网终端中还预先设置有消息中心模块,该消息中心模块用于统一管理各个功能模块之间的消息传输,如消息的提取、发送,等等。
视联网终端是视联网上业务落地设备,视联网业务的实际参与者或服务者,视联网终端可以为各种机顶盒、流媒体网关、存储网关、媒体合成器、编码板,等等。视联网终端需要注册到视联网服务器上方可进行正常业务。
参照图5,示出了本发明实施例一的一种消息传输方法的步骤流程图。
本发明实施例的消息传输方法可以包括以下步骤:
步骤501,消息中心模块分别检测各个功能模块是否存在待发送的消息。
本发明实施例中,消息中心模块可以对各个功能模块进行监听,以便检测各个功能模块是否存在待发送的消息。
步骤502,消息中心模块从检测结果为存在的源功能模块中提取所述待发送的消息。
如果消息中心模块检测到某个功能模块存在待发送的消息,则可以将该功能模块作为源功能模块。消息中心模块即可从源功能模块中提取出,该源功能模块存在的待发送的消息。
步骤503,消息中心模块依据所述目的功能模块的标识,将所述待发送的消息转发到所述目的功能模块。
在待发送的消息中可以包括源功能模块的标识、目的功能模块的标识,等等。消息中心模块可以依据目的功能模块的标识定位到目的功能模块,并将源功能模块中的待发送的消息转发到对应的目的功能模块中。目的功能模块接收到对应的消息后,即可执行与该消息相应的动作。因此,实现了在不进行功能模块之间直接调用的情况下,源功能模块到目的功能模块之间的消息传输。
本发明实施例中通过消息中心模块统一进行各个功能模块之间消息的传输,而各个功能模块之间无需再直接调用,降低了功能模块之间的耦合性,避免了对视联网终端系统的运行产生影响。
实施例二
参照图6,示出了本发明实施例二的一种消息传输方法的步骤流程图。
本发明实施例的消息传输方法可以包括以下步骤:
步骤601,消息中心模块分别接收各个功能模块发送的注册信息,进行所述功能模块向所述消息中心模块的注册。
本发明实施例中,预先在视联网终端中创建消息中心模块,各个功能模块可以分别向消息中心模块发送注册信息,以便实现各个功能模块在消息中心模块中进行注册。
在一种具体实现方式中,每个功能模块可以具有标识、发送队列、接收队列、发送接口、接收接口,等等。其中,功能模块的标识可以为功能模块的名称,如UI模块、Player模块、Capture模块,等等。在注册时,功能模块可以将自身的标识、发送队列、接收队列、发送接口、接收接口等信息作为一个结构体,该结构体作为该功能模块的注册信息,该功能模块将注册信息发送给消息中心模块。消息中心模块中可以预设功能模块列表,当接收到某个功能模块的注册信息后,消息中心模块可以将该功能模块的注册信息添加到功能模块列表中,完成该功能模块在消息中心模块中的注册。
步骤602,消息中心模块分别检测各个功能模块是否存在待发送的消息。
消息中心模块可以依据各个功能模块的注册信息与各个功能模块进行交互。比如,消息中心模块可以根据功能模块的标识定位到对应的功能模块,可以通过调用功能模块的发送接口访问该功能模块的发送队列,通过调用功能模块的接收接口访问该功能模块的接收队列,等等。
在一种具体实现方式中,如果某个功能模块想要向其他功能模块发送消息,则该功能模块可以将待发送的消息放入自身的发送队列中。消息中心模块中可以预设一用于监听各个功能模块的监听线程,消息中心模块可以在自身启动后,启动该监听线程。在监听线程中,消息中心模块可以通过调用功能模块的发送接口访问功能模块的发送队列,具体地可以通过各个功能模块的发送接口,遍历各个功能模块的发送队列,检测所述发送队列中是否存在待发送的消息。
其中,遍历可以为循环遍历,也即消息中心模块可以循环、不间断地遍历各个功能模块的发送队列。如果想要暂停遍历,或者继续遍历,或者终止遍历等,则视联网终端可以向消息中心模块发送对应的暂停命令,或者继续命令,或者终止命令等,消息中心模块接收到暂停命令后暂停遍历,接收到继续命令后继续遍历,接收到终止命令后终止遍历。
遍历也可以为定期遍历,也即消息中心模块可以每隔预设时间定期遍历一遍各个功能模块的发送队列。其中,预设时间可以为100ms、200ms,等等,本发明实施例对具体的数值并不加以限制。
步骤603,消息中心模块从检测结果为存在的源功能模块中提取所述待发送的消息。
消息中心模块对各个功能模块进行检测之后,有的功能模块检测结果可能为存在,有的功能模块检测结果可能为不存在。对于检测结果为存在的功能模块可以将其作为源功能模块。其中,源功能模块可能有一个,也可能有多个。一个源功能模块的发送队列中存在的待发送的消息可能有一个,也可能有多个。
消息中心模块可以从检测结果为存在的源功能模块中提取待发送的消息。在一种具体实现方式中,消息中心模块可以通过调用源功能模块的发送接口访问源功能模块的发送队列,具体地可以通过所述源功能模块的发送接口,从所述源功能模块的发送队列中提取待发送的消息。
步骤604,消息中心模块依据所述目的功能模块的标识,将所述待发送的消息转发到所述目的功能模块。
在待发送的消息中可以包括源功能模块的标识、目的功能模块的标识等信息,消息中心模块可以依据目的功能模块的标识,将待发送的消息转发到对应的目的功能模块。
在一种具体实现方式中,消息中心模块可以通过调用目的功能模块的接收接口访问目的功能模块的接收队列,具体地消息中心模块可以依据所述目的功能模块的标识定位到所述目的功能模块,并通过所述目的功能模块的接收接口,将所述待发送的消息转发到所述目的功能模块的接收队列中。
目的功能模块可以检测自身的接收队列中是否存在对应的源功能模块发出的消息,如果存在则依据该消息执行相应的动作。
比如,UI模块收到遥控器命令,要发布直播,则UI模块可以向Player模块发送初始化消息,以使Player模块进行初始化,为后续动作做准备;UI模块还可以向Capture模块发送开始采集消息,以使Capture模块开始采集数据。
因此,UI模块作为源功能模块,UI模块将初始化消息和开始采集消息均放入自身的发送队列中。其中,初始化消息中包括的源功能模块的标识为UI模块的标识,目的功能模块的标识为Player模块的标识;开始采集消息中包括的源功能模块的标识为UI模块的标识,目的功能模块的标识为Capture模块的标识。
消息中心模块通过各个功能模块的发送接口,遍历各个功能模块的发送队列,当遍历到UI模块的发送队列后,可以检测到其中存在初始化消息和开始采集消息。因此,消息中心模块可以通过UI模块的发送接口,从UI模块的发送队列中提取初始化消息和开始采集消息。
消息中心模块根据初始化消息中包括的源功能模块的标识为UI模块的标识,目的功能模块的标识为Player模块的标识,可以定位到Player模块,并通过Player模块的接收接口,将初始化消息发送到Player模块的接收队列中。Player模块检测到自身的接收队列中存在UI模块发出的初始化消息后,可以进行初始化操作,比如创建解码器等等。
消息中心模块根据开始采集消息中包括的源功能模块的标识为UI模块的标识,目的功能模块的标识为Capture模块的标识,可以定位到Capture模块,并通过Capture模块的接收接口,将初始化消息发送到Capture模块的接收队列中。Capture模块检测到自身的接收队列中存在UI模块发出的开始采集消息后,可以进行采集操作,开始采集外部的数据,比如音频数据、视频数据,等等。
视联网终端的Capture模块在采集数据后,还可以将采集的数据发送至视联网终端的发送模块,发送模块可以基于视联网协议将采集的数据封装为视联网协议数据包,并将该视联网协议数据包发送至视联网服务器。视联网服务器可以根据需求,按照对其它视联网终端分配的下行通信链路,将该视联网协议数据包下发至其它视联网终端,以实现不同视联网终端之间的相互通信。
在实际应用中,视联网为具有集中控制功能的网络,包括主控服务器和下级网络设备,该下级网络设备包括终端,视联网的核心构思之一在于,通过由主控服务器通知交换设备针对当次服务的下行通信链路配表,然后基于该配置的表进行数据包的传送。
即,视联网中的通信方法包括:
主控服务器配置当次服务的下行通信链路。
将源终端(如采集数据的视联网终端)发送的当次服务的数据包,按照所述下行通信链路传送至目标终端(如其它要接收数据的视联网终端)。
在本发明实施例中,配置当次服务的下行通信链路包括:通知当次服务的下行通信链路所涉及的交换设备配表。
进一步而言,按照下行通信链路传送包括:查询所配置的表,交换设备对所接收的数据包通过相应端口进行传送。
在具体实现中,服务包括单播通信服务和组播通信服务。即无论是组播通信还是单播通信,都可以采用上述配表—用表的核心构思实现视联网中的通信。
如前所述,视联网包括接入网部分,在接入网中,该主控服务器为节点服务器,下级网络设备包括接入交换机和终端。
对于接入网中的单播通信服务而言,所述主控服务器配置当次服务的下行通信链路的步骤可以包括以下步骤:
子步骤S11,主控服务器依据源终端发起的服务请求协议包,获取当次服务的下行通信链路信息,下行通信链路信息包括,参与当次服务的主控服务器和接入交换机的下行通信端口信息。
子步骤S12,主控服务器依据主控服务器的下行通信端口信息,在其内部的数据包地址表中设置当次服务的数据包所导向的下行端口;并依据接入交换机的下行通信端口信息,向相应的接入交换机发送端口配置命令。
子步骤S13,接入交换机依据端口配置命令在其内部的数据包地址表中,设置当次服务的数据包所导向的下行端口。
对于接入网中的组播通信服务(如视频会议)而言,主控服务器获取当次服务的下行通信链路信息的步骤可以包括以下子步骤:
子步骤S21,主控服务器获得目标终端发起的申请组播通信服务的服务请求协议包,服务请求协议包中包括服务类型信息、服务内容信息和目标终端的接入网地址。
其中,服务内容信息中包括服务号码。
子步骤S22,主控服务器依据所述服务号码在预置的内容-地址映射表中,提取源终端的接入网地址。
子步骤S23,主控服务器获取源终端对应的组播地址,并分配给目标终端;以及,依据服务类型信息、源终端和目标终端的接入网地址,获取当次组播服务的通信链路信息。
本发明实施例中,通过消息中心模块,可以实现各个功能模块之间的消息传输,各个功能模块之间可以不再进行直接交互。消息中心模块可以为一个模块类,里面实现了消息的注册,发送,接收接口,想要发送接收的类,只要继承这个模块类就可以实现发送,接收消息功能。
需要说明的是,对于方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本发明实施例并不受所描述的动作顺序的限制,因为依据本发明实施例,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于优选实施例,所涉及的动作并不一定是本发明实施例所必须的。
实施例三
参照图7,示出了本发明实施例三的一种消息传输装置的结构框图。本发明实施例的消息传输装置可以应用于视联网终端中,所述视联网终端包括消息中心模块及多个功能模块。
本发明实施例的消息传输装置可以包括以下位于消息中心模块中的单元:
所述消息中心模块包括:
检测单元701,用于分别检测各个功能模块是否存在待发送的消息;
提取单元702,用于从检测结果为存在的源功能模块中提取所述待发送的消息;所述待发送的消息中包括目的功能模块的标识;
转发单元703,用于依据所述目的功能模块的标识,将所述待发送的消息转发到所述目的功能模块。
在一种优选实施方式中,所述消息中心模块还包括:注册单元,用于分别接收各个功能模块发送的注册信息,进行所述功能模块向所述消息中心模块的注册。
在一种优选实施方式中,所述功能模块包括预设的发送接口及发送队列,所述检测单元,具体用于通过各个功能模块的发送接口,遍历各个功能模块的发送队列,检测所述发送队列中是否存在待发送的消息。
在一种优选实施方式中,所述功能模块包括预设的接收接口及接收队列,所述转发单元,具体用于依据所述目的功能模块的标识,通过所述目的功能模块的接收接口,将所述待发送的消息转发到所述目的功能模块的接收队列中。
在一种优选实施方式中,所述功能模块包括预设的发送接口及发送队列,所述提取单元,具体用于通过所述源功能模块的发送接口,从所述源功能模块的发送队列中提取所述待发送的消息。
本发明实施例中通过消息中心模块统一进行各个功能模块之间消息的传输,而各个功能模块之间无需再直接调用,降低了功能模块之间的耦合性,避免了对视联网终端系统的运行产生影响。
对于装置实施例而言,由于其与方法实施例基本相似,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
本说明书中的各个实施例均采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似的部分互相参见即可。
本领域内的技术人员应明白,本发明实施例的实施例可提供为方法、装置、或计算机程序产品。因此,本发明实施例可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明实施例可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本发明实施例是参照根据本发明实施例的方法、终端设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理终端设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理终端设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理终端设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理终端设备上,使得在计算机或其他可编程终端设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程终端设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
尽管已描述了本发明实施例的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例做出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本发明实施例范围的所有变更和修改。
最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者终端设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者终端设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者终端设备中还存在另外的相同要素。
以上对本发明所提供的一种消息传输方法和一种消息传输装置,进行了详细介绍,本文中应用了具体个例对本发明的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本发明的方法及其核心思想;同时,对于本领域的一般技术人员,依据本发明的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本发明的限制。

Claims (10)

1.一种消息传输方法,其特征在于,所述方法应用于视联网终端中,所述视联网终端包括消息中心模块及多个功能模块,所述方法包括:
所述消息中心模块分别检测各个功能模块是否存在待发送的消息;
所述消息中心模块从检测结果为存在的源功能模块中提取所述待发送的消息;所述待发送的消息中包括目的功能模块的标识;
所述消息中心模块依据所述目的功能模块的标识,将所述待发送的消息转发到所述目的功能模块。
2.根据权利要求1所述的方法,其特征在于,在所述消息中心模块分别检测各个功能模块是否存在待发送的消息的步骤之前,还包括:
所述消息中心模块分别接收各个功能模块发送的注册信息,进行所述功能模块向所述消息中心模块的注册。
3.根据权利要求1所述的方法,其特征在于,所述功能模块包括预设的发送接口及发送队列,所述消息中心模块分别检测各个功能模块是否存在待发送的消息的步骤,包括:
所述消息中心模块通过各个功能模块的发送接口,遍历各个功能模块的发送队列,检测所述发送队列中是否存在待发送的消息。
4.根据权利要求1所述的方法,其特征在于,所述功能模块包括预设的接收接口及接收队列,所述消息中心模块依据所述目的功能模块的标识,将所述待发送的消息转发到所述目的功能模块的步骤,包括:
所述消息中心模块依据所述目的功能模块的标识,通过所述目的功能模块的接收接口,将所述待发送的消息转发到所述目的功能模块的接收队列中。
5.根据权利要求1所述的方法,其特征在于,所述功能模块包括预设的发送接口及发送队列,所述消息中心模块从检测结果为存在的源功能模块中提取所述待发送的消息的步骤,包括:
所述消息中心模块通过所述源功能模块的发送接口,从所述源功能模块的发送队列中提取所述待发送的消息。
6.一种消息传输装置,其特征在于,所述装置应用于视联网终端中,所述视联网终端包括消息中心模块及多个功能模块,
所述消息中心模块包括:
检测单元,用于分别检测各个功能模块是否存在待发送的消息;
提取单元,用于从检测结果为存在的源功能模块中提取所述待发送的消息;所述待发送的消息中包括目的功能模块的标识;
转发单元,用于依据所述目的功能模块的标识,将所述待发送的消息转发到所述目的功能模块。
7.根据权利要求6所述的装置,其特征在于,所述消息中心模块还包括:
注册单元,用于分别接收各个功能模块发送的注册信息,进行所述功能模块向所述消息中心模块的注册。
8.根据权利要求6所述的装置,其特征在于,所述功能模块包括预设的发送接口及发送队列,
所述检测单元,具体用于通过各个功能模块的发送接口,遍历各个功能模块的发送队列,检测所述发送队列中是否存在待发送的消息。
9.根据权利要求6所述的装置,其特征在于,所述功能模块包括预设的接收接口及接收队列,
所述转发单元,具体用于依据所述目的功能模块的标识,通过所述目的功能模块的接收接口,将所述待发送的消息转发到所述目的功能模块的接收队列中。
10.根据权利要求6所述的装置,其特征在于,所述功能模块包括预设的发送接口及发送队列,
所述提取单元,具体用于通过所述源功能模块的发送接口,从所述源功能模块的发送队列中提取所述待发送的消息。
CN201811184645.XA 2018-10-11 2018-10-11 消息传输方法和装置 Pending CN109491804A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201811184645.XA CN109491804A (zh) 2018-10-11 2018-10-11 消息传输方法和装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201811184645.XA CN109491804A (zh) 2018-10-11 2018-10-11 消息传输方法和装置

Publications (1)

Publication Number Publication Date
CN109491804A true CN109491804A (zh) 2019-03-19

Family

ID=65690144

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201811184645.XA Pending CN109491804A (zh) 2018-10-11 2018-10-11 消息传输方法和装置

Country Status (1)

Country Link
CN (1) CN109491804A (zh)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110166363A (zh) * 2019-05-06 2019-08-23 视联动力信息技术股份有限公司 一种组播链路监测方法及装置
CN115543270A (zh) * 2022-10-08 2022-12-30 睿珀智能科技有限公司 基于消息驱动的软件架构方法、系统及设备

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101174225A (zh) * 2006-11-02 2008-05-07 华为技术有限公司 一种实现消息通信的装置及方法
CN102004891A (zh) * 2009-09-03 2011-04-06 上海宝信软件股份有限公司 Rfid中间件进程间数据通讯的方法及装置
WO2012159305A1 (zh) * 2011-06-28 2012-11-29 华为技术有限公司 一种分布式多进程通信方法和装置
CN105516265A (zh) * 2015-11-27 2016-04-20 山东中创软件商用中间件股份有限公司 一种短消息传输方法及装置
US20180139297A1 (en) * 2016-11-16 2018-05-17 Oath (Americas) Inc. SYSTEMS AND METHODS FOR TRACKING DEVICE IDs FOR VIRTUALIZED APPLICATIONS
CN108111523A (zh) * 2017-12-28 2018-06-01 网易(杭州)网络有限公司 数据传输方法和装置
CN108182121A (zh) * 2017-12-29 2018-06-19 广州小鹏汽车科技有限公司 一种Android中控大屏系统模块间通信方法及系统
CN108319513A (zh) * 2018-01-23 2018-07-24 北京东土科技股份有限公司 一种多分区操作系统中的消息传递方法及装置

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101174225A (zh) * 2006-11-02 2008-05-07 华为技术有限公司 一种实现消息通信的装置及方法
CN102004891A (zh) * 2009-09-03 2011-04-06 上海宝信软件股份有限公司 Rfid中间件进程间数据通讯的方法及装置
WO2012159305A1 (zh) * 2011-06-28 2012-11-29 华为技术有限公司 一种分布式多进程通信方法和装置
CN105516265A (zh) * 2015-11-27 2016-04-20 山东中创软件商用中间件股份有限公司 一种短消息传输方法及装置
US20180139297A1 (en) * 2016-11-16 2018-05-17 Oath (Americas) Inc. SYSTEMS AND METHODS FOR TRACKING DEVICE IDs FOR VIRTUALIZED APPLICATIONS
CN108111523A (zh) * 2017-12-28 2018-06-01 网易(杭州)网络有限公司 数据传输方法和装置
CN108182121A (zh) * 2017-12-29 2018-06-19 广州小鹏汽车科技有限公司 一种Android中控大屏系统模块间通信方法及系统
CN108319513A (zh) * 2018-01-23 2018-07-24 北京东土科技股份有限公司 一种多分区操作系统中的消息传递方法及装置

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110166363A (zh) * 2019-05-06 2019-08-23 视联动力信息技术股份有限公司 一种组播链路监测方法及装置
CN115543270A (zh) * 2022-10-08 2022-12-30 睿珀智能科技有限公司 基于消息驱动的软件架构方法、系统及设备
CN115543270B (zh) * 2022-10-08 2023-06-16 睿珀智能科技有限公司 基于消息驱动的软件架构方法、系统及设备

Similar Documents

Publication Publication Date Title
CN107995231B (zh) 一种远程控制设备的方法和装置
CN108173804B (zh) 一种通过视联网访问互联网的方法及视联猫客户端
CN108173803B (zh) 一种通过视联网访问互联网的方法及视联猫服务端
CN109120946A (zh) 收看直播的方法和装置
CN110233984A (zh) 一种基于视联网的监控系统和方法
CN110121059A (zh) 监控视频处理方法、装置及存储介质
CN109547417A (zh) 码流传输方法和装置
CN108965224A (zh) 一种视频点播的方法和装置
CN107888401B (zh) 一种实时监控视联网终端cpu利用率的方法和系统
CN108322809A (zh) 一种互联网下控制视频文件在视联网下播放的方法及系统
CN109818776A (zh) 微服务模块异常定位方法和装置
CN109889779A (zh) 一种报文乱序的处理方法和装置
CN109379254A (zh) 一种基于视频会议的网络连接的检测方法和系统
CN109302642A (zh) 数据采集方法和装置
CN110049346A (zh) 一种视频直播的方法和系统
CN110049273A (zh) 一种基于视联网的会议录制方法和中转服务器
CN109462594A (zh) 一种基于视联网的数据处理方法及系统
CN110035297A (zh) 视频处理方法和装置
CN110149305A (zh) 一种基于视联网的多方播放音视频的方法和中转服务器
CN109729184A (zh) 一种视联网业务处理的方法和装置
CN109640027A (zh) 通话方法和装置
CN108989850A (zh) 一种视频播放控制方法及控制系统
CN109491804A (zh) 消息传输方法和装置
CN110519331A (zh) 一种视联网资源处理方法及装置
CN109889755A (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
RJ01 Rejection of invention patent application after publication
RJ01 Rejection of invention patent application after publication

Application publication date: 20190319