CN107819734A - 一种基于网络套接字的程序间通讯方法及通讯系统 - Google Patents

一种基于网络套接字的程序间通讯方法及通讯系统 Download PDF

Info

Publication number
CN107819734A
CN107819734A CN201610824294.9A CN201610824294A CN107819734A CN 107819734 A CN107819734 A CN 107819734A CN 201610824294 A CN201610824294 A CN 201610824294A CN 107819734 A CN107819734 A CN 107819734A
Authority
CN
China
Prior art keywords
message
information node
switching unit
node
web socket
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
CN201610824294.9A
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.)
Shanghai Fossett Control Technology Co., Ltd.
Original Assignee
Shanghai Foresight Robotics 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 Shanghai Foresight Robotics Co Ltd filed Critical Shanghai Foresight Robotics Co Ltd
Priority to CN201610824294.9A priority Critical patent/CN107819734A/zh
Publication of CN107819734A publication Critical patent/CN107819734A/zh
Pending legal-status Critical Current

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/16Implementation or adaptation of Internet protocol [IP], of transmission control protocol [TCP] or of user datagram protocol [UDP]
    • H04L69/161Implementation details of TCP/IP or UDP/IP stack architecture; Specification of modified or new header fields
    • H04L69/162Implementation details of TCP/IP or UDP/IP stack architecture; Specification of modified or new header fields involving adaptations of sockets based mechanisms

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Information Transfer Between Computers (AREA)

Abstract

本发明提供一种基于网络套接字的程序间通讯方法及通讯系统,包括在需要通讯的程序内创建消息节点;创建消息交换机;所述消息交换机和各个所述消息节点启动后,基于网络套接字建立所述消息节点与所述消息交换机之间的连接,以使需要通讯的程序通过所述消息交换机实现相互通讯。本发明的基于网络套接字的程序间通讯方法及通讯系统,基于网络套接字实现了程序间的通讯,使得程序间的通讯有着统一的接口,程序运行时互相可以发送和接收消息。

Description

一种基于网络套接字的程序间通讯方法及通讯系统
技术领域
本发明涉及网络通讯的技术领域,特别是涉及一种基于网络套接字的程序间通讯方法及通讯系统。
背景技术
随着计算机软件技术的飞速发展,其已经渗透到各行各业。很多应用环境下不止包括一个程序,而是由多个程序软件构成一个软件系统。随着软件系统越来越庞大,软件之间需要互相通讯以进行传输数据。
程序间通讯,也叫进程间通讯,一直以来都是软件项目中的难题。因此,提供一种通用性强的程序间通讯机制成为当前的热点研究问题。
发明内容
鉴于以上所述现有技术的缺点,本发明的目的在于提供一种基于网络套接字的程序间通讯方法及通讯系统,基于网络套接字实现了程序间的通讯,使得程序间的通讯有着统一的接口,程序运行时互相可以发送和接收消息。
为实现上述目的及其他相关目的,本发明提供一种基于网络套接字的程序间通讯方法,包括:在需要通讯的程序内创建消息节点,所述消息节点用于通过网络套接字发送或接收消息;创建消息交换机,所述消息交换机用于通过网络套接字实现源消息节点与目的消息节点之间的通讯;所述消息交换机和各个所述消息节点启动后,基于网络套接字建立所述消息节点与所述消息交换机之间的连接,以使需要通讯的程序通过所述消息交换机实现相互通讯。
根据上述的基于网络套接字的程序间通讯方法,其中:所述消息节点与所述消息交换机之间建立连接通过以下步骤实现:
消息交换机和消息节点分别创建网络套接字;
消息节点向消息交换机发送注册信息,所述注册信息包括消息节点对应的网络套接字;
消息交换机接收并解析消息节点发送的注册信息,将消息节点的注册信息存储至一个节点列表,并反馈注册成功消息至消息节点。
根据上述的基于网络套接字的程序间通讯方法,其中:需要通讯的程序通过所述消息交换机实现相互通讯的方式为:
消息交换机接收源消息节点发送来的消息,所述消息需要传送至目的消息节点;
消息交换机查询自身维护的节点列表,找到目的消息节点对应的网络套接字;所述节点列表用于存储消息节点在消息交换机上的注册信息,所述注册信息包括消息节点对应的网络套接字;
消息交换机通过目的消息节点对应的网络套接字将消息发送至目的消息节点。
根据上述的基于网络套接字的程序间通讯方法,其中:需要通讯的程序通过所述消息交换机实现相互通讯的方式为:
基于消息节点的网络套接字,消息交换机建立源消息节点与目的消息节点之间的直接连接;
源消息节点与目的消息节点通过相互之间的直接连接,进行消息传送。
根据上述的基于网络套接字的程序间通讯方法,其中:所述程序还创建有广播节点和/或订阅节点;所述广播节点用于通过所述消息交换机进行消息广播;所述订阅节点用于通过所述消息交换机进行消息订阅。
同时,本发明还提供一种基于网络套接字的程序间通讯系统,包括消息节点创建模块、消息交换机创建模块和连接模块;
所述消息节点创建模块用于在需要通讯的程序内创建消息节点,所述消息节点用于通过网络套接字发送或接收消息;
所述消息交换机创建模块用于创建消息交换机,所述消息交换机用于通过网络套接字实现源消息节点与目的消息节点之间的通讯;
所述连接模块用于在所述消息交换机和各个所述消息节点启动后,基于网络套接字建立所述消息节点与所述消息交换机之间的连接,以使需要通讯的程序通过所述消息交换机实现相互通讯。
根据上述的基于网络套接字的程序间通讯系统,其中:所述连接模块中,所述消息节点与所述消息交换机之间建立连接通过以下步骤实现:
消息交换机和消息节点分别创建网络套接字;
消息节点向消息交换机发送注册信息,所述注册信息包括消息节点对应的网络套接字;
消息交换机接收并解析消息节点发送的注册信息,将消息节点的注册信息存储至一个节点列表,并反馈注册成功消息至消息节点。
根据上述的基于网络套接字的程序间通讯系统,其中:需要通讯的程序通过所述消息交换机实现相互通讯的方式为:
消息交换机接收源消息节点发送来的消息,所述消息需要传送至目的消息节点;
消息交换机查询自身维护的节点列表,找到目的消息节点对应的网络套接字;所述节点列表用于存储消息节点在消息交换机上的注册信息,所述注册信息包括消息节点对应的网络套接字;
消息交换机通过目的消息节点对应的网络套接字将消息发送至目的消息节点。
根据上述的基于网络套接字的程序间通讯系统,其中:需要通讯的程序通过所述消息交换机实现相互通讯的方式为:
基于消息节点的网络套接字,消息交换机建立源消息节点与目的消息节点之间的直接连接;
源消息节点与目的消息节点通过相互之间的直接连接,进行消息传送。
根据上述的基于网络套接字的程序间通讯系统,其中:还包括定制节点创建模块,所述定制节点创建模块用于创建有广播节点和/或订阅节点;所述广播节点用于通过所述消息交换机进行消息广播;所述订阅节点用于通过所述消息交换机进行消息订阅。
如上所述,本发明的基于网络套接字的程序间通讯方法及通讯系统,具有以下有益效果:
(1)通用性强,应用广泛;
(2)支持各类通讯场景,如阻塞方式下的点对点发送、非阻塞方式下的点对点发送、非阻塞方式下的点对多发送;支持广播模式、订阅模式以及请求响应模式;其中,阻塞方式是指发送消息后需要等待反馈消息才能继续进行消息发送;非阻塞方式是指无间断的消息发送;
(3)能够根据各类程序的负载和功能需求来设计符合要求的消息节点(MessageNode);
(4)能够自定义消息报文和发送方式;
(5)兼容第三方程序,只需具有指定结构的消息节点即可;
(6)对外部来讲,无需完全了解网络拓扑结构,无需为每个消息节点间建立连接。
附图说明
图1显示为本发明的基于网络套接字的程序间通讯方法的流程图;
图2显示为本发明的消息节点的应用结构示意图;
图3显示为本发明的基于网络套接字的程序间通讯时连接过程的时序图;
图4显示为本发明的基于网络套接字的程序间通讯系统的结构示意图。
元件标号说明
1 消息节点创建模块
2 消息交换机创建模块
3 连接模块
具体实施方式
以下通过特定的具体实例说明本发明的实施方式,本领域技术人员可由本说明书所揭露的内容轻易地了解本发明的其他优点与功效。本发明还可以通过另外不同的具体实施方式加以实施或应用,本说明书中的各项细节也可以基于不同观点与应用,在没有背离本发明的精神下进行各种修饰或改变。需说明的是,在不冲突的情况下,以下实施例及实施例中的特征可以相互组合。
需要说明的是,以下实施例中所提供的图示仅以示意方式说明本发明的基本构想,遂图式中仅显示与本发明中有关的组件而非按照实际实施时的组件数目、形状及尺寸绘制,其实际实施时各组件的型态、数量及比例可为一种随意的改变,且其组件布局型态也可能更为复杂。
本发明的基于网络套接字的程序间通讯方法采用类似以太网局域网的网络拓扑,参照局域网的网络交换机与PC机的硬件连接的方式,来构建程序间软件通讯模块架构。
网络套接字(socket)用于描述IP地址和端口,是一个通信链的句柄,可以用来实现不同虚拟机或不同计算机之间的通信。在Internet上的主机一般运行了多个服务软件,同时提供几种服务。每种服务都打开一个socket,并绑定到一个端口上,不同的端口对应于不同的服务。根据连接启动的方式以及套接字要连接的目标,套接字之间的连接过程可以分为以下三个步骤:
(1)服务器监听
服务器端套接字并不定位具体的客户端套接字,而是处于等待连接的状态,实时监控网络状态。
(2)客户端请求
由客户端的套接字提出连接请求,要连接的目标是服务器端的套接字。为此,客户端的套接字必须首先描述它要连接的服务器的套接字,指出服务器端套接字的地址和端口号,然后就向服务器端套接字提出连接请求。
(3)连接确认
当服务器端套接字监听到或者说接收到客户端套接字的连接请求,则响应客户端套接字的请求,建立一个新的线程,把服务器端套接字的描述发给客户端,一旦客户端确认了此描述,连接就建立好了。而服务器端套接字继续处于监听状态,继续接收其他客户端套接字的连接请求。
参照图1,本发明的基于网络套接字的程序间通讯方法包括以下内容:
(1)在需要通讯的程序内创建消息节点(Message Node),该消息节点用于通过网络套接字发送或接收消息。
具体地,每个消息节点中都包括一个发送线程和一个接收线程。发送线程用于实现消息的发送;接收线程用于实现非阻塞的数据接收。对于同一个消息节点,既可以作为源消息节点,也可以作为目的消息节点。
消息节点的应用结构如图2所示,其中APP_A和APP_B表示两个应用程序各自负责通讯的对象,它们内部创建了消息节点对象,以这个消息节点对象作为窗口,来发送接收消息。
(2)创建消息交换机,该消息交换机用于通过网络套接字实现源消息节点与目的消息节点之间的通讯。
消息交换机类似于网络交换机,消息节点类似于对应的PC机。类似于PC机间通过网络交换机进行信息交换的模式,消息节点间通过消息交换机来实现相互通讯。
其中,消息交换机与各个程序相互独立,其接收源消息节点发送来的消息,通过初步解析,确定目的消息节点,并将消息转发至所确定的消息节点。具体地,消息交换机维护一个节点列表(Node List),该节点列表用于存储消息节点在消息交换机上的注册信息。其中,注册信息包括消息节点对应的网络套接字。当需要转发消息时,消息交换机通过查询这个节点列表来确定目的消息节点对应的网络套接字。
(3)消息交换机和各个消息节点启动后,基于网络套接字建立消息节点与消息交换机之间的连接,以使需要通讯的程序通过所述消息交换机实现相互通讯。
消息节点与消息交换机之间建立连接包括以下步骤:
a)消息交换机和消息节点分别创建网络套接字socket;
b)消息节点向消息交换机发送注册(Register)消息;
c)消息交换机接收并解析消息节点发送的注册信息,将消息节点的注册信息存储至一个节点列表,并反馈注册成功消息至消息节点。
消息节点与消息交换机建立连接的时序图如图3所示。其中,消息交换机和消息节点可以随着程序的启动而启动,也可以在需要进行通讯的时候再进行启动。
在一个启动周期内,消息节点只需向消息交换机发送一次注册信息,消息交换机所维护的节点列表始终保持有效。当消息交换机再次启动时,消息节点需重新向消息交换机发送注册信息,消息交换机需重新维护节点列表。
当程序间进行通讯时,基于消息节点和消息交换机的网络套接字,通过消息交换机实现消息节点间的相互通讯。
具体地,消息节点间通讯包括非阻塞方式和阻塞方式。其中,非阻塞方式是指消息节点间进行通讯时,需要经过消息交换机来转发。阻塞方式是指消息节点间进行通讯时,不经过消息交换机,通过消息交换机建立的消息节点间的直接连接来通讯。
具体地,非阻塞方式的消息节点间通讯包括以下步骤:
11)消息交换机接收消息节点A发送来的消息,该消息需要传送至消息节点B;
22)消息交换机查询自己维护的节点列表,找到消息节点B对应的网络套接字socket;
23)消息交换机通过消息节点B对应的网络套接字socket将消息发送至消息节点B。
阻塞方式的消息节点间通讯包括以下步骤:
21)基于消息节点的网络套接字,消息交换机建立消息节点A与消息节点B之间的直接连接;
22)消息节点A与消息节点B通过相互之间的直接连接,进行消息传送。
需要说明的是,所有的消息节点均与消息交换机相连,从而能够通过消息交换机实现任意两个消息节点间的通讯。
在本发明的优选实施例中,消息节点可以根据应用场景进行定制和扩展。为了降低目标节点的通信负载,消息节点可以扩展为广播节点(Broadcast Node)、订阅节点(Subscribe Node)等等。其中,广播节点通过消息交换机进行消息广播;订阅节点通过消息交换机进行消息订阅。
具体地,对于一个程序,其可包括一个消息节点,一个订阅节点和一个广播节点,以分别进行消息的收发、订阅和广播。其中,广播节点能够指定发送目标,可以全部广播,也可以根据各个接收方的需求来指定发送。订阅节点可以通过发送订阅消息来订阅自己感兴趣的消息;广播节点向订阅这个类型的消息的节点进行广播。发送给广播节点的消息,默认为需要待广播消息和订阅消息两种。
因此,本发明的基于网络套接字的程序间通讯方法具有极强的通用性,使用范围广。这是因为:
(1)网络套接字socket作为以太网协议的一部分,被广泛支持,能够接入以太网的系统,不论是嵌入式还是PC机,不论是Linux还是Windows;
(2)编程语言多种多样,包括有脚本语言、编译二进制执行类语言、虚拟机运行语言等等,其中很多语言有局限性,如无法直接操作共享内存等等,但只要它们支持以太网应用,就可以采用本发明的方案,故本发明能够适应于多种编程语言和系统平台;
(3)程序间通讯的对象的多样性,只要采用本发明的消息数据报文,即可实现程序间的互相通讯,比如A程序是C语言编写,B程序是JAVA编写,C程序是PYTHON编写,ABC程序也可以采用本发明来实现相互通讯,并构建混合软件系统;
(4)能够根据需要扩展兼容以太网主机间通讯,这是因为套接字本身不仅可以实现程序间通讯,也可以实现主机间的通讯。
参照图4,本发明的基于网络套接字的程序间通讯系统包括消息节点创建模块1、消息交换机创建模块2和连接模块3。
消息节点创建模块1用于在需要通讯的程序内创建消息节点,该消息节点用于通过网络套接字发送或接收消息。
具体地,每个消息节点中都包括一个发送线程和一个接收线程。发送线程用于实现消息的发送;接收线程用于实现非阻塞的数据接收。
消息交换机创建模块2用于创建消息交换机,该消息交换机用于通过网络套接字实现源消息节点与目的消息节点之间的通讯。
消息交换机类似于网络交换机,消息节点类似于对应的PC机。类似于PC机间通过网络交换机进行信息交换的模式,消息节点间通过消息交换机来实现相互通讯。
其中,消息交换机与各个程序相互独立,其接收源消息节点发送来的消息,通过初步解析,确定目的消息节点,并将消息转发至所确定的消息节点。对于同一个消息节点,既可以作为源消息节点,也可以作为目的消息节点。
具体地,消息交换机维护一个节点列表(Node List),该节点列表用于存储消息节点在消息交换机上的注册信息。其中,注册信息包括消息节点对应的网络套接字。当需要转发消息时,消息交换机通过查询这个节点列表来确定目的消息节点对应的网络套接字。
具体地,消息交换机维护一个节点列表,该节点列表用于存储消息节点在消息交换机上的注册信息。当需要转发消息时,消息交换机通过查询这个列表来确定目的消息节点。
连接模块3用于在消息交换机和各个消息节点启动后,基于网络套接字建立消息节点与消息交换机之间的连接,以使需要通讯的程序通过所述消息交换机实现相互通讯。
消息节点与消息交换机之间建立连接包括以下步骤:
a)消息交换机和消息节点分别创建网络套接字socket;
b)消息节点向消息交换机发送注册信息;
c)消息交换机接收并解析消息节点发送的注册信息,将消息节点的注册信息存储至一个节点列表,并反馈注册成功消息至消息节点。
其中,消息交换机和消息节点可以随着程序的启动而启动,也可以在需要进行通讯的时候再进行启动。
在一个启动周期内,消息节点只需向消息交换机发送一次注册信息,消息交换机所维护的节点列表始终保持有效。当消息交换机再次启动时,消息节点需重新向消息交换机发送注册信息,消息交换机需重新维护节点列表。
在程序间进行通讯时,基于消息节点和消息交换机的网络套接字,通过消息交换机实现消息节点间的相互通讯。
具体地,消息节点间通讯包括非阻塞方式和阻塞方式。其中,非阻塞方式是指消息节点间进行通讯时,需要经过消息交换机来转发。阻塞方式是指消息节点间进行通讯时,不经过消息交换机,通过消息交换机建立的消息节点间的直接连接来通讯。
具体地,非阻塞方式的消息节点间通讯包括以下步骤:
11)消息交换机接收消息节点A发送来的消息,该消息需要传送至消息节点B;
22)消息交换机查询自身维护的节点列表,找到消息节点B对应的网络套接字socket;
23)消息交换机通过消息节点B对应的网络套接字socket将消息发送至消息节点B。
阻塞方式的消息节点间通讯包括以下步骤:
21)基于消息节点的网络套接字,消息交换机建立消息节点A与消息节点B之间的直接连接;
22)消息节点A与消息节点B通过相互之间的直接连接,进行消息传送。
需要说明的是,所有的消息节点均与消息交换机相连,从而能够通过消息交换机实现任意两个消息节点间的通讯。
在本发明的优选实施例中,消息节点可以根据应用场景进行定制和扩展。故还包括定制节点创建模块,该定制节点创建模块用于创建广播节点和/或订阅节点。
具体地,为了降低目标节点的通信负载,消息节点可以扩展为广播节点(Broadcast Node)、订阅节点(Subscribe Node)等等。其中,广播节点通过消息交换机进行消息广播;订阅节点通过消息交换机进行消息订阅。
具体地,对于一个程序,其可包括一个消息节点,一个订阅节点和一个广播节点,以分别进行消息的收发、订阅和广播。其中,广播节点能够指定发送目标,可以全部广播,也可以根据各个接收方的需求来指定发送。订阅节点可以通过发送订阅消息来订阅自己感兴趣的消息;广播节点向订阅这个类型的消息的节点进行广播。发送给广播节点的消息,默认为需要待广播消息和订阅消息两种。
综上所述,本发明的基于网络套接字的程序间通讯方法及通讯系统通用性强,应用广泛;支持各类通讯场景,如阻塞方式下的点对点发送、非阻塞方式下的点对点发送、非阻塞方式下的点对多发送;支持广播模式、订阅模式以及请求响应模式;能够根据各类程序的负载和功能需求来设计符合要求的消息节点;能够自定义消息报文和发送方式;兼容第三方程序,只需具有指定结构的消息节点即可;对外部来讲,无需完全了解网络拓扑结构,无需为每个消息节点间建立连接。所以,本发明有效克服了现有技术中的种种缺点而具高度产业利用价值。
上述实施例仅例示性说明本发明的原理及其功效,而非用于限制本发明。任何熟悉此技术的人士皆可在不违背本发明的精神及范畴下,对上述实施例进行修饰或改变。因此,举凡所属技术领域中具有通常知识者在未脱离本发明所揭示的精神与技术思想下所完成的一切等效修饰或改变,仍应由本发明的权利要求所涵盖。

Claims (10)

1.一种基于网络套接字的程序间通讯方法,其特征在于:包括:
在需要通讯的程序内创建消息节点,所述消息节点用于通过网络套接字发送或接收消息;
创建消息交换机,所述消息交换机用于通过网络套接字实现源消息节点与目的消息节点之间的通讯;
所述消息交换机和各个所述消息节点启动后,基于网络套接字建立所述消息节点与所述消息交换机之间的连接,以使需要通讯的程序通过所述消息交换机实现相互通讯。
2.根据权利要求1所述的基于网络套接字的程序间通讯方法,其特征在于:所述消息节点与所述消息交换机之间建立连接通过以下步骤实现:
消息交换机和消息节点分别创建网络套接字;
消息节点向消息交换机发送注册信息,所述注册信息包括消息节点对应的网络套接字;
消息交换机接收并解析消息节点发送的注册信息,将消息节点的注册信息存储至一个节点列表,并反馈注册成功消息至消息节点。
3.根据权利要求1所述的基于网络套接字的程序间通讯方法,其特征在于:需要通讯的程序通过所述消息交换机实现相互通讯的方式为:
消息交换机接收源消息节点发送来的消息,所述消息需要传送至目的消息节点;
消息交换机查询自身维护的节点列表,找到目的消息节点对应的网络套接字;所述节点列表用于存储消息节点在消息交换机上的注册信息,所述注册信息包括消息节点对应的网络套接字;
消息交换机通过目的消息节点对应的网络套接字将消息发送至目的消息节点。
4.根据权利要求1所述的基于网络套接字的程序间通讯方法,其特征在于:需要通讯的程序通过所述消息交换机实现相互通讯的方式为:
基于消息节点的网络套接字,消息交换机建立源消息节点与目的消息节点之间的直接连接;
源消息节点与目的消息节点通过相互之间的直接连接,进行消息传送。
5.根据权利要求1所述的基于网络套接字的程序间通讯方法,其特征在于:所述程序还创建有广播节点和/或订阅节点;所述广播节点用于通过所述消息交换机进行消息广播;所述订阅节点用于通过所述消息交换机进行消息订阅。
6.一种基于网络套接字的程序间通讯系统,其特征在于:包括消息节点创建模块、消息交换机创建模块和连接模块;
所述消息节点创建模块用于在需要通讯的程序内创建消息节点,所述消息节点用于通过网络套接字发送或接收消息;
所述消息交换机创建模块用于创建消息交换机,所述消息交换机用于通过网络套接字实现源消息节点与目的消息节点之间的通讯;
所述连接模块用于在所述消息交换机和各个所述消息节点启动后,基于网络套接字建立所述消息节点与所述消息交换机之间的连接,以使需要通讯的程序通过所述消息交换机实现相互通讯。
7.根据权利要求6所述的基于网络套接字的程序间通讯系统,其特征在于:所述连接模块中,所述消息节点与所述消息交换机之间建立连接通过以下步骤实现:
消息交换机和消息节点分别创建网络套接字;
消息节点向消息交换机发送注册信息,所述注册信息包括消息节点对应的网络套接字;
消息交换机接收并解析消息节点发送的注册信息,将消息节点的注册信息存储至一个节点列表,并反馈注册成功消息至消息节点。
8.根据权利要求6所述的基于网络套接字的程序间通讯系统,其特征在于:需要通讯的程序通过所述消息交换机实现相互通讯的方式为:
消息交换机接收源消息节点发送来的消息,所述消息需要传送至目的消息节点;
消息交换机查询自身维护的节点列表,找到目的消息节点对应的网络套接字;所述节点列表用于存储消息节点在消息交换机上的注册信息,所述注册信息包括消息节点对应的网络套接字;
消息交换机通过目的消息节点对应的网络套接字将消息发送至目的消息节点。
9.根据权利要求6所述的基于网络套接字的程序间通讯系统,其特征在于:需要通讯的程序通过所述消息交换机实现相互通讯的方式为:
基于消息节点的网络套接字,消息交换机建立源消息节点与目的消息节点之间的直接连接;
源消息节点与目的消息节点通过相互之间的直接连接,进行消息传送。
10.根据权利要求6所述的基于网络套接字的程序间通讯系统,其特征在于:还包括定制节点创建模块,所述定制节点创建模块用于创建有广播节点和/或订阅节点;所述广播节点用于通过所述消息交换机进行消息广播;所述订阅节点用于通过所述消息交换机进行消息订阅。
CN201610824294.9A 2016-09-14 2016-09-14 一种基于网络套接字的程序间通讯方法及通讯系统 Pending CN107819734A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201610824294.9A CN107819734A (zh) 2016-09-14 2016-09-14 一种基于网络套接字的程序间通讯方法及通讯系统

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201610824294.9A CN107819734A (zh) 2016-09-14 2016-09-14 一种基于网络套接字的程序间通讯方法及通讯系统

Publications (1)

Publication Number Publication Date
CN107819734A true CN107819734A (zh) 2018-03-20

Family

ID=61601334

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201610824294.9A Pending CN107819734A (zh) 2016-09-14 2016-09-14 一种基于网络套接字的程序间通讯方法及通讯系统

Country Status (1)

Country Link
CN (1) CN107819734A (zh)

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101326508A (zh) * 2005-01-06 2008-12-17 特维拉有限公司 智能消息传递应用编程接口
CN101971593A (zh) * 2008-02-27 2011-02-09 诺基亚公司 独立于传输方式的架构
CN102831018A (zh) * 2011-06-15 2012-12-19 塔塔咨询服务有限公司 低延迟先进先出消息交换系统
US20150095469A1 (en) * 2013-09-30 2015-04-02 Electronics And Telecommunications Research Institute Identifier-based communication method using application program interface
CN104618475A (zh) * 2015-01-28 2015-05-13 清华大学 用于异构sdn网络的水平方向通信方法和sdn系统
CN105677495A (zh) * 2016-02-24 2016-06-15 京信通信技术(广州)有限公司 进程间通信方法和系统

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101326508A (zh) * 2005-01-06 2008-12-17 特维拉有限公司 智能消息传递应用编程接口
CN101971593A (zh) * 2008-02-27 2011-02-09 诺基亚公司 独立于传输方式的架构
CN102831018A (zh) * 2011-06-15 2012-12-19 塔塔咨询服务有限公司 低延迟先进先出消息交换系统
US20150095469A1 (en) * 2013-09-30 2015-04-02 Electronics And Telecommunications Research Institute Identifier-based communication method using application program interface
CN104618475A (zh) * 2015-01-28 2015-05-13 清华大学 用于异构sdn网络的水平方向通信方法和sdn系统
CN105677495A (zh) * 2016-02-24 2016-06-15 京信通信技术(广州)有限公司 进程间通信方法和系统

Similar Documents

Publication Publication Date Title
US10791195B2 (en) Common device interface framework for IoT/smart device application
US9578081B2 (en) System and method for providing an actively invalidated client-side network resource cache
CN109194660A (zh) 移动终端的入网方法和装置
CN109478179A (zh) IoT设备连接、发现和联网
EP2485443A1 (en) System and method for managing multiple queues of non-persistent messages in a networked environment
CN108093206A (zh) 一种资源监控方法及系统
EP3257199B1 (en) Service performance monitoring in a virtualized communication network
CN101990663A (zh) 对以太网光纤通道设备的发现
CN101848235A (zh) 一种支持nat穿越的实时多媒体数据p2p传输方案
CN105871719A (zh) 路由状态和/或策略信息的处理方法及装置
CN112134866A (zh) 业务访问控制方法、装置、系统及计算机可读存储介质
CN114449459B (zh) 消息传输方法、平台功能应用功能
CN102546646A (zh) 一种实现语音对讲功能的系统及方法
CN113556359B (zh) 一种通讯协议转换方法、设备、系统及网关设备
CN112511598A (zh) 一种投屏显示方法、智能终端、存储介质
CN109672632A (zh) Fc-ae-asm网络数据通讯方法及系统
Li et al. 6G cloud-native system: Vision, challenges, architecture framework and enabling technologies
CN105306276B (zh) 基于软件定义网络的oam协议封装方法、系统及epon接入网
CN106100960B (zh) 跨存储区域网络Fabric互通的方法、装置及系统
WO2015043679A1 (en) Moving stateful applications
WO2021254442A1 (zh) 会话发起方法、装置和系统,电子设备,及计算机可读存储介质
US20160344689A1 (en) Network Management of Devices Residing Behind a Network Device
KR102130005B1 (ko) 응용프로그램 간 데이터 전송 지원 방법 및 이를 위한 서버
KR20140021157A (ko) 그룹통화 서비스를 제공하는 장치 및 그 방법
CN104468213B (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
TA01 Transfer of patent application right

Effective date of registration: 20181225

Address after: Room 1102, Building No. 188, Yizhou Road, Xuhui District, Shanghai 200000

Applicant after: Shanghai Fossett Control Technology Co., Ltd.

Address before: 200230 Room 305, Kai Ke mansion, A, 1801 Hongmei Road, Xuhui District, Shanghai.

Applicant before: SHANGHAI FORESIGHT ROBOTICS CO., LTD.

TA01 Transfer of patent application right
CB02 Change of applicant information

Address after: Room 1102, Building No. 188, Yizhou Road, Xuhui District, Shanghai 200000

Applicant after: Real-time Chivalrous Intelligent Control Technology Co., Ltd.

Address before: Room 1102, Building No. 188, Yizhou Road, Xuhui District, Shanghai 200000

Applicant before: Shanghai Fossett Control Technology Co., Ltd.

CB02 Change of applicant information
RJ01 Rejection of invention patent application after publication

Application publication date: 20180320

RJ01 Rejection of invention patent application after publication