CN112839065A - 信息处理方法、装置、第一设备及存储介质 - Google Patents
信息处理方法、装置、第一设备及存储介质 Download PDFInfo
- Publication number
- CN112839065A CN112839065A CN201911157221.9A CN201911157221A CN112839065A CN 112839065 A CN112839065 A CN 112839065A CN 201911157221 A CN201911157221 A CN 201911157221A CN 112839065 A CN112839065 A CN 112839065A
- Authority
- CN
- China
- Prior art keywords
- module
- agent module
- communication channel
- communication
- state quantity
- 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
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/2866—Architectures; Arrangements
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
- H04L67/1097—Protocols in which an application is distributed across nodes in the network for distributed storage of data in networks, e.g. transport arrangements for network file system [NFS], storage area networks [SAN] or network attached storage [NAS]
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Hardware Redundancy (AREA)
- Computer And Data Communications (AREA)
Abstract
本公开是关于一种信息处理方法、装置、第一设备及存储介质;所述信息处理方法,包括:在所述第一设备中为第一进程配置第一代理模块,其中,所述第一进程为由所述第一设备运行的进程;基于所述第一代理模块,进行所述第一进程与运行在第二设备的第二进程之间的进程间通信,其中,所述第二进程和所述第一进程为同一个任务中执行不同子任务的并行进程。
Description
技术领域
本公开涉及分布式技术领域,尤其涉及一种信息处理方法、装置、第一设备及存储介质。
背景技术
相关技术中,通常需要多种设备协同合作,以共同完成一套复杂的生产系统等。在分布式环境中,往往很难实现不同设备或者同一设备中不同应用程序的进程间的数据交互或状态同步。
发明内容
本公开提供一种信息处理方法、装置、第一设备及存储介质。
根据本公开实施例的第一方面,提供一种信息处理方法,应用于第一设备,包括:
在所述第一设备中为第一进程配置第一代理模块,其中,所述第一进程为由所述第一设备运行的进程;
基于所述第一代理模块,进行所述第一进程与运行在第二设备的第二进程之间的进程间通信,其中,所述第二进程和所述第一进程为同一个任务中执行不同子任务的并行进程。
上述方案中,所述方法包括:
为所述第一进程和所述第一代理模块配置第一通信通道;
所述基于所述第一代理模块,进行所述第一进程与运行在第二设备的第二进程之间的进程间通信,包括:
基于所述第一通信通道,进行所述第一进程与所述第一代理模块之间的通信;
所述第一代理模块基于网络传输,与在所述第二设备中为所述第二进程配置的第二代理模块进行通信;其中,所述第二代理模块,用于基于第二通信通道与所述第二进程进行通信;所述第二通信通道为在所述第二进程和所述第二代理模块之间配置的通道。
上述方案中,所述方法还包括:
基于所述第一进程的执行状态,确定所述第一通信通道的第一状态量;
所述第一代理模块基于网络传输,与在所述第二设备中为所述第二进程配置的第二代理模块进行通信,包括:
所述第一代理模块基于所述网络传输将所述第一状态量同步给所述第二进程。
上述方案中,所述第一代理模块基于所述网络传输将所述第一状态量同步给所述第二进程,包括:
所述第一代理模块按照预定时间间隔读取所述第一通信通道的第一状态量,并基于所述网络传输将所述第一状态量同步给所述第二进程;或者,
所述第一代理模块监控所述第一状态量,并在所述第一状态量发生改变时,基于所述网络传输将变化后的所述第一状态量同步给所述第二进程。
上述方案中,所述基于所述第一代理模块,进行所述第一进程与运行在第二设备的第二进程之间的进程间通信,包括:
所述第一代理模块接收所述第二代理模块发送的第二状态量,并将所述第二状态量通过所述第一通信通道发送给所述第一进程;
所述第一进程基于表征所述第二进程有数据输出的所述第二状态量,通过所述第一通信通道向所述第一代理模块发送第一读取请求;
所述第一代理模块将所述第一读取请求基于所述网络传输发送给所述第二代理模块,其中,所述第一读取请求,用于供所述第二代理模块基于所述第二通信通道发送给所述第二进程;
所述第一代理模块接收所述第二代理模块转发的基于所述第一读取请求返回的第一数据;
所述第一代理模块通过所述第一通信通道将所述第一数据发送给所述第一进程。
上述方案中,所述基于所述第一代理模块,进行所述第一进程与运行在第二设备的第二进程之间的进程间通信,包括:
所述第一代理模块接收所述第二代理模块基于所述网络传输发送的所述第二进程的第二读取请求,并将所述第二读取请求通过所述第一通信通道发送给所述第一进程;
所述第一进程基于所述第二读取请求通过所述第一通信通道向所述第一代理模块发送第二数据;
所述第一代理模块将所述第二数据基于所述网络传输发送给所述第二代理模块,其中,所述第二数据,用于供所述第二代理模块基于所述第二通信通道发送给所述第二进程。
上述方案中,所述方法还包括:
所述第一代理模块将待发送数据进行序列化处理,得到待发送的数据队列,其中,所述待发送数据包括:函数和/或输入参数和/或所述第一通信通道的标识信息;用于所述第一代理模块按照所述数据队列将待发送数据通过所述网络传输发送给所述第二代理模块。
上述方案中,所述方法还包括:
在所述第一设备中为所述第一进程配置第三代理模块;
基于所述第三代理模块,进行所述第一进程与第三进程之间的进程间通信,其中,所述第三进程为由所述第一设备运行的进程;所述第三进程与所述第一进程为同一任务中执行不同子任务的并行进程。
上述方案中,所述方法还包括:
为所述第一进程和所述第三代理模块配置第三通信通道;
所述基于所述第三代理模块,进行所述第一进程与第三进程之间的进程间通信,包括:
基于所述第三通信通道,进行所述第一进程与所述第三代理模块之间的通信;
所述第三代理模块基于应用程序接口,与在所述第一设备中为所述第三进程配置的第四代理模块进行通信;其中,所述第四代理模块用于基于第四通信通道与所述第三进程进行通信;所述第四通信通道为在所述第三进程和所述第四代理模块之间配置的通道。
根据本公开实施例的第二方面,提供一种信息处理装置,包括:
配置模块,用于在第一设备中为第一进程配置第一代理模块,其中,所述第一进程为由所述第一设备运行的进程;
通信模块,用于基于所述第一代理模块,进行所述第一进程与运行在第二设备的第二进程之间的进程间通信,其中,所述第二进程和所述第一进程为同一个任务中执行不同子任务的并行进程。
上述方案中,所述配置模块,还用于为所述第一进程和所述第一代理模块配置第一通信通道;
所述通信模块,包括:
第一通信单元,用于基于所述第一通信通道,进行所述第一进程与所述第一代理模块之间的通信;
第二通信单元,用于所述第一代理模块基于网络传输,与在所述第二设备中为所述第二进程配置的第二代理模块进行通信;其中,所述第二代理模块,用于基于第二通信通道与所述第二进程进行通信;所述第二通信通道为在所述第二进程和所述第二代理模块之间配置的通道。
上述方案中,所述配置模块,还用于基于所述第一进程的执行状态,确定所述第一通信通道的第一状态量;
所述第二通信单元,用于所述第一代理模块基于所述网络传输将所述第一状态量同步给所述第二进程。
上述方案中,所述第二通信单元,用于所述第一代理模块按照预定时间间隔读取所述第一通信通道的第一状态量,并基于所述网络传输将所述第一状态量同步给所述第二进程;或者,
用于所述第一代理模块监控所述第一状态量,并在所述第一状态量发生改变时,基于所述网络传输将变化后的所述第一状态量同步给所述第二进程。
上述方案中,所述第二通信单元,用于所述第一代理模块接收所述第二代理模块发送的第二状态量,并将所述第二状态量通过所述第一通信通道发送给所述第一进程;
所述第一通信单元,用于所述第一进程基于表征所述第二进程有数据输出的所述第二状态量,通过所述第一通信通道向所述第一代理模块发送第一读取请求;
所述第二通信单元,用于所述第一代理模块将所述第一读取请求基于所述网络传输发送给所述第二代理模块,其中,所述第一读取请求,用于供所述第二代理模块基于所述第二通信通道发送给所述第二进程;
所述第二通信单元,还用于所述第一代理模块接收所述第二代理模块转发的基于所述第一读取请求返回的第一数据;
所述第一通信单元,还用于所述第一代理模块通过所述第一通信通道将所述第一数据发送给所述第一进程。
上述方案中,所述第二通信单元,用于所述第一代理模块接收所述第二代理模块基于所述网络传输发送的所述第二进程的第二读取请求,并将所述第二读取请求通过所述第一通信通道发送给所述第一进程;
所述第一通信单元,用于所述第一进程基于所述第二读取请求通过所述第一通信通道向所述第一代理模块发送第二数据;
所述第二通信单元,还用于所述第一代理模块将所述第二数据基于所述网络传输发送给所述第二代理模块,其中,所述第二数据,用于供所述第二代理模块基于所述第二通信通道发送给所述第二进程。
上述方案中,还包括:
序列化模块,用于所述第一代理模块将待发送数据进行序列化处理,得到待发送的数据队列,其中,所述待发送数据包括:函数和/或输入参数和/或所述第一通信通道的标识信息;
所述第一代理模块按照所述数据队列将待发送数据通过所述网络传输发送给所述第二代理模块。
上述方案中,所述配置模块,用于在所述第一设备中为所述第一进程配置第三代理模块;
所述通信模块,用于基于所述第三代理模块,进行所述第一进程与第三进程之间的进程间通信,其中,所述第三进程为由所述第一设备运行的进程;所述第三进程与所述第一进程为同一任务中执行不同子任务的并行进程。
上述方案中,所述配置模块,用于为所述第一进程和所述第三代理模块配置第三通信通道;
第一通信单元,用于基于所述第三通信通道,进行所述第一进程与所述第三代理模块之间的通信;
所述通信模块还包括:第三通信单元,用于所述第三代理模块基于应用程序接口,与在所述第一设备中为所述第三进程配置的第四代理模块进行通信;其中,所述第四代理模块用于基于第四通信通道与所述第三进程进行通信;所述第四通信通道为在所述第三进程和所述第四代理模块之间配置的通道。
根据本公开实施例的第三方面,提供一种第一设备,包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为:用于运行计算机服务时,实现本公开任一实施例所述的信息处理方法。
根据本公开实例的第四方面,提供一种非临时性计算机可读存储介质,所述非临时性计算机可读存储介质存储有可执行程序,其中,所述可执行程序被处理器执行时实现本公开任一实施例所述的信息处理方法。
本公开的实施例提供的技术方案可以包括以下有益效果:
通过在所述第一设备中为第一进程配置第一代理模块,其中,所述第一进程为由所述第一设备运行的进程;基于所述第一代理模块,进行所述第一进程与运行在第二设备的第二进程之间的进程间通信,其中,所述第二进程和所述第一进程为同一个任务中执行不同子任务的并行进程;可以利用第一代理模块实现在不同设备中并发进程的通信,从而使得在一个设备的进程可以与另一个设备的进程实现数据交互或状态同步等通信;若将上述方法应用在分布式系统中,在执行同一个任务时,实现不同设备间进程之间的状态和数据共享,使用不同设备加速任务的执行。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本发明的实施例,并与说明书一起用于解释本发明的原理。
图1是根据一示例性实施例示出的一种信息处理方法的流程图。
图2是根据一示例性实施例示出的另一种信息处理方法的流程图。
图3是根据一示例性实施例示出的一种信息处理方法的示意图。
图4是根据一示例性实施例示出的第一种分布式系统的框图。
图5是根据一示例性实施例示出的第二种分布式系统的框图。
图6是根据一示例性实施例示出的第三种分布式系统的框图。
图7是根据一示例性实施例示出的不同进程之间通信的示意图。
图8是根据一示例性实施例示出的又一种信息处理方法的流程图。
图9是根据一示例性实施例示出的一种信息处理装置的框图。
图10是根据一示例性实施例示出的另一种信息处理装置的框图。
具体实施方式
这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本发明相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本发明的一些方面相一致的装置和方法的例子。
图1是根据一示例性实施例示出的一种分布式处理方法的流程图,如图1所示,所述方法应用于第一设备,包括以下步骤。
步骤S11,在所述第一设备中为第一进程配置第一代理模块,其中,所述第一进程为由所述第一设备运行的进程;
步骤S12,基于所述第一代理模块,进行所述第一进程与运行在第二设备的第二进程之间的进程间通信,其中,所述第二进程和所述第一进程为同一个任务中执行不同子任务的并行进程。
这里,所述第一设备、所述第二设备均为分布式系统中的设备。例如,所述第一设备和所述第二设备为分布式系统中的PC机或服务器,等等。
在一实施例中,所述第一设备可以为本地设备、所述第二设备可以为远程设备。
可以理解的是,若所述第一进程和所述第二进程在不同设备中,或者,所述第一进程和所述第二进程为不同应用程序的进程,则所述第一进程和所述第二进程很难实现直接通信。在本公开实施例中,通过在所述第一设备中为第一进程配置第一代理模块,所述第一代理模块可以用于代表所述第二进程,与所述第一进程通信;如此,可以基于所述第一代理模块实现所述第一进程与所述第二进程进行通信,从而实现了进程间的通信。
这里,所述进行所述第一进程与运行在第二设备的第二进程之间的进程间通信包括:所述第一进程与所述第二进程进行状态同步和/或数据交互。
在本公开实施例中,通过在所述第一设备中为第一进程配置第一代理模块,其中,所述第一进程为由所述第一设备运行的进程;基于所述第一代理模块,进行所述第一进程与运行在第二设备的第二进程之间的进程间通信,其中,所述第二进程和所述第一进程为同一个任务中执行不同子任务的并行进程;可以利用第一代理模块实现在不同设备中并发进程的通信,从而使得在一个设备的进程可以与另一个设备的进程实现数据交互或状态同步等通信;若将上述方法应用在分布式系统中,在执行同一个任务时,实现不同设备间进程之间的状态和数据共享,使用不同设备加速任务的执行。
在一些实施例中,如图2所示,所述方法还包括:
步骤S10,为所述第一进程和所述第一代理模块配置第一通信通道;
所述步骤S12,包括:步骤S121,基于所述第一通信通道,进行所述第一进程与所述第一代理模块之间的通信;步骤S122,所述第一代理模块基于网络传输,与在所述第二设备中为所述第二进程配置的第二代理模块进行通信;其中,所述第二代理模块,用于基于第二通信通道与所述第二进程进行通信;所述第二通信通道为在所述第二进程和所述第二代理模块之间配置的通道。
这里,所述第一通信通道和所述第二通信通道使用相同的规则描述语言的通信通道。
这里,所述第一通信通道和所述第二通信通均可以是一个或多个。
可以理解的是,所述第一进程和所述第二进程之间可能存在多个通信通道,如此,所述第一通信通道和所述第二通信通道可以为多个。
这里,所述网络传输为利用设备底层通信接口进行通信的传输;其中,为所述第一设备配置第一通信接口,为所述第二设备配置第二通信接口;所述第一通信接口和所述第二通信接口使用了相同的规则描述语言。
这里,所述第二代理模块用于代表所述第一进程,与第二进程通信。
例如,如图3所示,在第一设备中运行有第一进程,在第二设备中运行有第二进程,期望实现所述第一进程和所述第二进程的进程间通信。具体的实现方式为以下:在所述第一设备中为所述第一进程配置第一代理模块,在所述第二设备中为所述第二进程配置所述第二代理模块;其中,所述第一代理模块用于代表所述第二进程,所述第二代理模块用于代表所述第一进程;其中,所述第一代理模块用于代表所述第二进程,具体用于代表所述第二进程进行通信。同样的,所述第二代理模块用于代表所述第一进程,具体用于代表所述第一进程进行通信。如此,所述第一进程与所述第一代理模块位于一个应用程序内,所述第一进程与所述第一代理模块可以基于配置的第一通信通道进行通信。同样的,所述第二进程与所述第二代理模块位于一个应用程序内,所述第二进程与所述第二代理模块可以基于配置的第二通信通道进行通信;且所述第一代理模块和所述第二代理模块可以基于设备的底层通信接口,进行网络传输。其中,所述第一代理模块和所述第二代理模块可以基于应用程序接口(Application Programming Interface,API)连接所述底层通信接口。
在一实施例中,所述第一进程可以为本地设备上的本地进程,所述第二进程为远程设备上的远程进程;所述第二进程基于所述第一进程发起;所述第一代理模块可以为代理(Stub);所述第二代理模块可以为桩(Proxy)。
这里,所述Stub与所述Proxy采用同样的代理机制。
这里,代理-桩(Stub-Proxy)为一一对应的。
在一些实施例中,所述第一设备和所述第二设备中存在多对Stub-Proxy。例如,在所述第一设备中存在多个Stub,则所述第一设备可配置一个第一管理模块(Stub Manager)用于管理所述多个Stub;所述第二设备中存在多个Proxy,则所述第二设备可配置一个第二管理模块(Proxy Manager)用于管理所述多个Proxy。
在相关技术中,通常需要多种设备协同工作,包括PC、仪表、治具、DUT等等。所述多种设备运行于不同硬件(例如,x86、Arm或Soc等)结构上,提供不同的硬件资源(例如,计算资源、显示资源、治具动作或测量信号等)。所述多种设备通过各种方式(例如,USB、网线、WIFI或蓝牙等)相互连接;如此,所述多种设备构成一套复杂生产系统。
而在相关技术中,提供了以下几种多种设备协同工作的方式:
方式一:如图4所示,公开了第一种分布式系统的框图。所述第一种分布式系统可配置不同功能设计的模块,例如,客户端模块、显示器模块及手机模块;其中,所述客户端模块基于传输控制协议/网际协议(TCP/IP)与服务器端模块进行通信;所述显示器模块基于网络套接(WebSocket)协议与监视器进行通信,其中,所述WebSocket协议是一种在单个TCP连接上进行全双工通信的协议;所述手机模块基于安卓调试桥/总线远(ADB/USB)与测试机进行通信。
方式二:如图5所示,公开了第二种分布式系统的框图。所述第二种分布式系统为以映射-归约(MapReduce)为代表的系统,其中,所述MapReduce是一种编程模型,用于大规模数据集(大于1TB)的并行运算。其中,所述第二种分布式系统包括管理节点,映射节点和归约节点;其中,所述映射节点包括至少一台设备;所述归约节点包括至少一台设备。例如,所述映射节点包括:映射节点1、映射节点2和映射节点3;所述归约节点包括:归约节点1、归约节点2和归约节点3。这里,所述管理节点用于将所述分布式系统中的任务分为多个子任务,将所述多个子任务分配给多个映射节点,并基于多个归约节点收集结果;其中,所述映射节点将分配给自己的子任务按照不同的键值(key,value)对,将所述子任务的结果发送给对应的归约节点;所述归约节点处理同一键值(key)下所有的键值对,并将归约节点处理后的结果发送给所述管理节点;所述管理节点用于汇总所述归约节点处理后的结果。
方式三:如图6所示,公开了第三种分布式系统的框图。所述第三种分布式系统为以远程过程调用(Remote Procedure Call,RPC)为代表的系统;其中,所述RPC是一种第三方的客户程序通过接口调用SAP内部的标准或自定义函数,并获得所述标准或自定义函数返回的结果的方式。这里,所述第三种分布式系统包括客户端和服务器;当所述客户端的本地程序需要在所述服务器运行函数f(request)时,将函数(f)和输入参数(request)序列化成数据,并通过网络传输发送给服务器;所述服务器将获得的所述数据进行反序列化,并运行函数response=f(request),并将运行结果同样通过序列化处理返回给所述客户端;其中,所述客户端通过在不同线程上运行f的回调函数(cb(response))来获取本地程序与远程函数之间的并行性。
在上述方式一中,所述第一种分布式系统没有定义统一的语义、没有统一接口实现等,来实现硬件的并行性;其各个模块单独运行。若利用上述方式一中的系统进行生产时,软件难以充分利用硬件资源、无法高效生产。
在上述方式二中,所述第二种分布式系统虽调节了各个设备,为各设备间并行资源和通信提供了统一的方法;但是,所述分布式系统着重于同样的任务的分配,主要复用不同设备上相同的计算资源。所述第二种分布式系统并不适应不同任务的运算,不能共用不同设备上不同的计算资源。
在上述方式三中,所述第三种分布式系统仅支持输入请求和返回结果之间的通信,并不能实现并行过程(如函数)之间的通信。若当多个过程并行存在和运行时,需要过程间数据交互或者同步,本地程序需要使用共享内存来实现;但是,由于分布式系统中各设备不存在共享的物理内存资源,因而若采用所述第三种分布式系统,并不能实现进程间的物理内存资源的共享。
而在本公开实施例中,由于在第一设备中为第一进程配置了第一代理模块,在第二设备中为第二进程配置了第二代理模块;所述第一进程和所述第一代理模块在同一应用程序中,可基于第一通信通道进行通信,所述第二进程和所述第二代理模块在同一应用程序中,可基于第二通信通道进行通信;所述第一代理模式与所述第二代理模块基于网络传输进行通信;如此,实现了在执行同一个任务时,不同设备间的不同进程间的通信。所述第一设备可以共享到所述第二设备的物理内存资源。
可以理解的是,当并行运行的进程在同一设备的同一程序时,可以基于进程间的通信通道进行通信;当并行运行的进程在不同设备或者不同程序中时,需要基于通信通道算法进行通信。
例如,如图7所示,进程1和进程2运行在本地设备的本地应用程序,则所述进程1和所述进程2可基于所述通信通道进行通信;进程3运行在远程设备的远程应用程序,所述进程1和所述进程3为运行在不同设备的进程,则所述进程1和所述进程3可通过通信通道算法进行通信。这里,可以在通信通道之间设置通信通道算法;然后根据两个进程的执行状态等,确定通信通道的通道状态;若所述通信状态为传输状态时,利用所述通信通道在所述两个进程之间进行通行(例如数据的传输)。
在一些实施例中,所述方法还包括:
基于所述第一进程的执行状态,确定所述第一通信通道的第一状态量;
所述第一代理模块基于网络传输,与在所述第二设备中为所述第二进程配置的第二代理模块进行通信,包括:
所述第一代理模块基于所述网络传输将所述第一状态量同步给所述第二进程。
这里,所述基于所述第一进程的执行状态,确定所述第一通信通道的第一状态量,包括:所述第一通信通道根据所述第一进程的执行状态,确定所述第一通信通道的第一状态量。
这里,所述第一进程的执行状态包括:读状态和/或写状态。所述第一通信通道的第一状态量可以表征所述第一进程的执行状态。
在一实施例中,所述第一状态量可以为0或1;其中,所述0表征所述第一进程为读的执行状态;所述1表征所述第一进程为写的执行状态。
在另一实施例中,所述第一状态量可以为0、1、2、3、4或5;其中,所述0表征所述第一进程为读的执行状态;所述1表征所述第一进程为写的执行状态;所述2表征所述第一通信通道为等待状态;所述3表征所述第一通信通道为准备状态;所述4表征所述第一通信通道为传输状态;所述5表征所述第一通信通道为拥塞状态。
这里,所述第一代理模块基于所述网络传输将所述第一状态量同步给所述第二进程,包括:
所述第一代理模块基于所述网络传输将所述第一状态量发送给所述第二代理模块,所述第二代理模块基于第二通信通道将所述第一状态量发送给第二进程。
可以理解的是,在本示例中,所述第二通信通道及所述第二进程均可获得所述第一通信通道的第一状态量。
在本公开实施例中,可以通过第一代理模块,基于网络传输将所述第一进程的执行状态同步给所述第二进程,以使得所述第一进程与所述第二进程可以实现所述进程间的状态同步。
可以理解的是,在其它实施例中,第二代理模块也可以基于网络传输,将所述第二通信通道的第二状态量,同步给所述第一进程。
这里,所述第二状态量也可以表征以下至少之一:
第二进程为读的执行状态;第二进程为写的执行状态;第二通信通道为等待状态;第二通信通道为准备状态;第二通信通道为传输状态;第二通信通道为拥塞状态。
如此,在分布式系统中,可以有利于各个设备中进程与其它一个或多个设备的进程并行运行时,可以知道其它一个或多设备的进程的执行状态。
在一些实施例中,所述第一代理模块基于所述网络传输将所述第一状态量同步给所述第二进程,包括:
所述第一代理模块按照预定时间间隔读取所述第一通信通道的第一状态量,并基于所述网络传输将所述第一状态量同步给所述第二进程;或者,
所述第一代理模块监控所述第一状态量,并在所述第一状态量发生改变时,基于所述网络传输将变化后的所述第一状态量同步给所述第二进程。
这里,一种实现所述第一代理模块按照预定时间间隔读取所述第一通信通道的第一状态量的方式为:在管理所述第一代理模块的第一管理模块上设置触发器;其中,所述触发器可以基于设置的预定时间间隔,触发所述第一代理模块读取所述第一通信通道的第一状态量。
这里,一种实现所述第一代理模块监控所述第一状态量,并在所述第一状态量发生改变时,基于所述网络传输将变化后的所述第一状态量同步给所述第二进程的方式为:所述第一代理模块获取第一时刻的所述第一状态量;若确定所述第一时刻获取的所述第一状态量与所述第二时刻获取的所述第一状态量不同,所述第一代理模块将所述第一时刻获取的所述第一状态量发送给所述第二代理模块;所述第二代理模块用于将所述第一时刻获取的所述第一状态量发送给所述第二进程;其中,所述第二时刻早于所述第一时刻的预定时间间隔。
当然,在本公开实施例中,还可以基于其它任意的方式,使得所述第一代理模块按照预定时间间隔读取所述第一通信通道的第一状态量,在此不作限制。
这里,所述第一状态量发生改变为一种状态量改变为另一种状态量。例如,所述第一状态量由0改变为1,或者由1改变为0,等等。
在本公开实施例中,可以按照预定时间间隔同步所述第一通信通道的状态量同步给第二进程,或者可以当检测到所述第一通信通道的状态量发生改变时,将所述第一通信通道的状态量同步给第二进程;如此,本公开实施例提供了多种同步所述第一通信通道的第一状态量的方式,有利于所述第二进程知晓所述第一进程的执行状态,方便后续的数据交互等。
在一应用场景中,将所述第一通信通道的第一状态量通过给所述第二通信通道后,所述第二通信通道的状态量会引起改变。如此,可以将所述第二通信通道的状态量的改变结果再返回给所述第一通信通道,以使所述第一通信通道知晓所述第二通信通道的状态量的改变。
可以理解的是,在其它实施例中,所述第二代理模块也可以基于网络传输将所述第二通信通道的第二状态量发送给所述第一进程;具体地,所述第二代理模块按照预定时间间隔读取所述第二通信通道的第二状态量,并基于网络传输将所述第二通信状态的第二状态量同步给所述第一进程。如此,也提供了多种同步所述第二通信通道的第二状态量的方式,有利于所述第一进程知晓所述第二进程的执行状态。
在一些实施例中,所述基于所述第一代理模块,进行所述第一进程与运行在第二设备的第二进程之间的进程间通信,包括:
所述第一代理模块接收所述第二代理模块发送的第二状态量,并将所述第二状态量通过所述第一通信通道发送给所述第一进程;
所述第一进程基于表征所述第二进程有数据输出的所述第二状态量,通过所述第一通信通道向所述第一代理模块发送第一读取请求;
所述第一代理模块将所述第一读取请求基于所述网络传输发送给所述第二代理模块,其中,所述第一读取请求,用于供所述第二代理模块基于所述第二通信通道发送给所述第二进程;
所述第一代理模块接收所述第二代理模块转发的基于所述第一读取请求返回的第一数据;
所述第一代理模块通过所述第一通信通道将所述第一数据发送给所述第一进程。
这里,所述第二状态量为所述第二通信通道的状态量。所述第二状态量可以表征所述第二进程的执行状态;所述第二进程的执行状态包括:读状态和/或写状态。
在一实施例中,所述第二状态量可以为0或1;其中,所述0表征所述第二进程为读的执行状态;所述1表征所述第二进程为写的执行状态。
在本公开实施例中,若第一进程接收到表征第二进程有数据输出的第二状态量时,可通过第一通信通道向第一代理模块发送第一读取请求;所述第一代理模块将所述第一读取请求基于网络传输发送给第二代理模块,并基于所述第一代理模块接收所述第二代理模块基于第一读取请求返回的第一数据,从而实现将所述第一数据从第一进程传输到所述第二进程。如此,可以在第一设备和第二设备在执行同一任务时,所述第一设备可以基于第一通信通道、第二通信通道以及网络传输,共享所述第二设备中的物理内存资源等,使用不同设备加速任务的执行。
且,在本公开实施例中,由于在所述第一代理模块向所述第二代理模块发送第一读取请求之前,还接收所述第二通信通道的第二状态量,基于表征所述第二进程有数据输出的第二状态量,才确定发送第一读取请求,还能够大大提高数据交互的效率。
在一些实施例中,所述基于所述第一代理模块,进行所述第一进程与运行在第二设备的第二进程之间的进程间通信,包括:
所述第一代理模块接收所述第二代理模块基于所述网络传输发送的所述第二进程的第二读取请求,并将所述第二读取请求通过所述第一通信通道发送给所述第一进程;
所述第一进程基于所述第二读取请求通过所述第一通信通道向所述第一代理模块发送第二数据;
所述第一代理模块将所述第二数据基于所述网络传输发送给所述第二代理模块,其中,所述第二数据,用于供所述第二代理模块基于所述第二通信通道发送给所述第二进程。
这里,所述第二数据为基于所述第二读取请求确定的数据。
在本公开实施例中,若第一代理模块接收到第二代理模块发送的第二读取请求时,所述第一进程可以直接将所述第二数据(基于所述第二请求模块确定的数据)发送给所述第二代理模块,进而基于所述第二代理模块返回第二数据给所述第二进程。如此,可以在执行同一任务时,所述第二设备可以基于第二通信通道、第一通信通道及网络传输,共享所述第一设备中的物理内存资源等,使用不同设备加速任务的执行。
且,由于本公开实施例中,在所述第一代理模块将所述第二数据发送给第二代理模块之前,不需要再将第一通信通道的状态量发送给第二代理模块,可以进一步提高获取数据的效率。
在一些实施例中,所述方法还包括:
所述第一代理模块将待发送数据进行序列化处理,得到待发送的数据队列,其中,所述待发送数据包括:函数和/或输入参数和/或所述第一通信通道的标识信息;
所述第一代理模块按照所述数据队列将待发送数据通过所述网络传输发送给所述第二代理模块。
这里,所述序列化处理用于将待发送数据的对象状态转换为可保持或传输的格式。例如,可以利用谷歌的protobuf对数据进行序列化处理。其中,protobuf是一种结构化数据存储格式;所述protobuf用于数据序列化。
这里,所述第一通信通的标识信息包括:通道个数、通道类型的信息。
这里,所述待发送数据还可以包括:所述第一进程和所述进程交互的数据。
在一些实施例中,所述方法还包括:对所述第一通信通道的第一状态量进行序列化处理。
在本公开实施例中,可以将待发送数据进行序列化处理,以获取能够基于网络传输能够传输的数据,并基于所述网络传输发送给第二代理模块。并且,将待发送数据进行序列化处理后,得到待发送的数据队列进行传输,能够减少出错概率。
在一些实施例中,所述方法还包括:
在所述第一设备中为所述第一进程配置第三代理模块;
基于所述第三代理模块,进行所述第一进程与第三进程之间的进程间通信,其中,所述第三进程为由所述第一设备运行的进程;所述第三进程与所述第一进程为同一任务中执行不同子任务的并行进程。
这里,所述第三代理模块用于代表所述第三进程。具体地,所述第三代理模块用于代表所述第三进程用于通信的特性,并不能代表所述第三进程的计算特性。
这里,所述第一进程和所述第三进程均运行在所述第一设备中;所述第一进程和所述第三进程为不同应用程序的进程。
在本公开实施例中,通过在所述第一设备中为第三进程配置第三代理模块,并基于所述第三代理模块,进行所述第一进程与所述第三进程之间的进程间通信;如此,可以实现同一设备中不同应用程序的进程的数据交互或状态同步等通信。
在一些实施例中,所述方法还包括:
为所述第一进程和所述第三代理模块配置第三通信通道;
所述基于所述第三代理模块,进行所述第一进程与第三进程之间的进程间通信,包括:
基于所述第三通信通道,进行所述第一进程与所述第三代理模块之间的通信;
所述第三代理模块基于应用程序接口,与在所述第一设备中为所述第三进程配置的第四代理模块进行通信;其中,所述第四代理模块用于基于第四通信通道与所述第三进程进行通信;所述第四通信通道为在所述第三进程和所述第四代理模块之间配置的通道。
这里,一个应用程序中进程可以基于所述应用程序接口与同一设备中另一应用程序的进程进行通信。
在本公开实施例中,由于在第一设备中为第一进程配置了第三代理模块,在第二设备中为第二进程配置了第四代理模块;所述第一进程和所述第一代理模块在同一应用程序中,可基于第三通信通道进行通信,所述第三进程和所述第四代理模块在同一应用程序中,可基于第四通信通道进行通信;所述第三代理模式与所述第四代理模块基于应用程序接口进行应用程序之间的通信;如此,实现了同一设备中不同应用程序中进程间的通信。
示例1:
图8是根据一示例性实施例示出的一种信息处理方法,如图8所示,所述信息处理方法,所述信息处理方法应用于分布式系统中,所述分布式系统包括第一设备和第二设备;在所述第一设备中运行第一进程,在所述第二设备中运行第二进程;其中,第一管理模块运行于所述第一设备中,所述第一管理模块用于管理至少一个第一代理模块;所述第二管理模块运行于所述第二设备中,所述第二管理模块用于管理至少一个第二代理模块。所述信息处理方法包括以下步骤:
步骤S201:创建并发送第一通信通道、函数及输入参数;
可选地,所述第一进程在所述第一设备上创建第一通信通道(channel1)、函数(fch)及输入参数(request);并基于所述第一通信通道将所述第一通信通道、所述函数、及所述输入参数发送给所述第一管理模块。
这里,所述第一通信通道用于所述第一进程与所述第一代理模块之间的通信。
步骤S202:将函数及输入参数发送给第二管理模块;
可选地,所述第一管理模块,将所述函数及所述输入参数发送给所述第二管理模块。
步骤S203:将标识信息发送给第一管理模块;
可选地,所述第二管理模块确定接收到所述第一管理模块发送的所述函数及所述输入参数后,将标识信息发送给所述第一管理模块;所述标识信息用于表征所述第二管理模块确定接收到所述函数及所述输入参数。
步骤S204:创建第二代理模块;
可选地,所述第二管理模块创建第二代理模块。
步骤S205:创建第一代理模块;
可选地,所述第一管理模块确定接收到所述标识信息后,创建第一代理模块。
步骤S206:创建第二通信通道;
可选地,所述第二管理模块基于所述函数,创建第二通信通道(channel2)。
在一实施例中,所述步骤S206还可以是:所述第二代理模块基于所述函数,创建所述第二通信通道。
这里,所述第二通信通道用于第二进程与所述第二代理模块之间的通信。
步骤S207:返回所述标识信息;
可选地,所述第一代理模块将所述标识信息返回给所述第一进程。
步骤S208:将所述第二通信通道及输入参数发送给第二进程;
可选地,所述第二代理模块将所述第二通信通道及所述输入参数发送给所述第二进程。
步骤S209:同步所述第一通信通道的第一状态量;
可选地,所述第一代理模块将所述第一通信通道的第一状态量发送给所述第二代理模块。
这里,可以在第一设备中设置第一触发器;基于所述第一触发器,触发执行所述步骤S209。具体地,所述第一触发器可以基于预设时间间隔进行触发,或者若确定所述第一状态量改变而触发。
这里,可以理解的是,所述步骤S209是由第一代理模块触发的状态同步。
步骤S210:发送第一数据给第一代理模块;
可选地,所述第二代理模块将所述第一数据发送给所述第一代理模块。
这里,若有第一数据从第二代理模块发送给第二代理模块;当所述第二代理模块接收到所述第一代理模块发送的所述第一状态量,所述第二代理模块可以直接将所述第一数据发送给所述第一代理模块,不需要所述第二代理模块再同步所述第二通信通道的第二状态量给所述第一代理模块。
步骤S211a:同步所述第二通信通道的第二状态量;
可选地,所述第二代理模块将所述第二通信通道的第二状态量发送给所述第一代理模块。
步骤S211b:发送第二数据给第二代理模块;
可选地,所述第一代理模块将所述第二数据发送给所述第二代理模块。
这里,若有第二数据从第一代理模块发送给第二代理模块;需要先利用所述第二代理模块将所述第二通信通道的第二状态量发送给所述第一代理模块,所述第一代理模块再基于所述第二状态量,来确定是否发送给所述第二代理模块的所述第二数据。
步骤S212:同步所述第二通信通道的第三状态量;
可选地,所述第二代理模块将所述第二通信通道的第三状态量发送给所述第一代理模块。
这里,可以在第二设备中设置第二触发器;基于所述第二触发器,触发执行所述步骤S212。具体地,所述第二触发器可以基于预设时间间隔进行触发,或者若确定所述第一状态量改变而触发。
步骤S213:执行第一同步阶段;
可选地,所述第一代理模块强制执行第一同步阶段。
这里,可以理解是,所述步骤S212是由所述第二代理模块触发的状态同步。如此,通过在所述第二代理模块将所述第三状态量发送给所述第一代理模块后,强制执行一次第一同步阶段,可以使得所述分布式处理方法中状态同步,总是从所述第一代理模块写入到所述第二代理模块,可以实现避免状态量的写入的数据竞争。
步骤S214:将响应结果发送给第二代理模块;
可选地,所述第二进程基于所述函数和所述输入参数,生成响应结果;并将所述响应结果发送给所述第二代理模块。
步骤S215:执行第二同步阶段;
可选地,所述第二代理模块强制执行第二同步阶段。
这里,若所述第二代理模块接收到所述响应结果后,表征第一进程与第二进程进行通信的事件即将结束;如此,可通过所述第二代理模块强制执行一次第二同步阶段以更新所述第一通信通道和第二通信通道的状态量。
步骤S216:将所述响应结果发送给第一代理模块;
可选地,所述第二代理模块将所述响应结果发送给所述第一代理模块。
步骤S217:关闭所述第二代理模块;
可选地,所述第二管理模块关闭所述第二代理模块。
步骤S218:关闭所述第一代理模块;
可选地,所述第一管理模块关闭所述第一代理模块。
步骤S219:将所述响应结果发送给第一进程。
可选地,所述第一管理模块将所述响应结果送给所述第一进程。
在另一实施例中,所述步骤S219可以为:所述第一代理模块将所述响应结果发送给第一进程;且所述步骤S218在步骤S218执行之后执行。如此,在本实施例中,可以先基于所述第一代理模块,将所述响应结果发送给所述第一进程后;再通过所述第一管理模块将所述第一代理模块关闭。
在上述实施例中,所述信息处理方法可分为四个阶段:开始阶段、第一同步阶段、第二同步阶段、结束阶段;其中,所述第一同步阶段为所述第一代理模块触发的同步阶段;所述第二同步阶段为所述第二代理模块触发的同步阶段;其中,所述开始阶段为上述步骤S201至步骤S208;所述第一同步阶段为上述步骤S209至步骤S211b;所述第二同步阶段为上述步骤S212至步骤S213;所述结束阶段为上述步骤S215至步骤S219。
可以理解的是,图8中的开始条件1可以包括:第一触发器触发所述第一代理模块进程同步,或者,基于所述步骤S213的条件;图8中的开始条件2可以包括:第二触发器触发所述第二代理模块同步,或者,基于所述步骤S215的条件。
其中,所述步骤S213中执行第一同步阶段应理解为:执行一次所述第一同步阶段,并不是无限循环;所述步骤S215中执行第二同步阶段应理解为:执行一次所述第二同步阶段,并不是无限循环。
在本公开实施例中,可以通过为所述第一进程配置所述第一代理模块和第一通信通道,为所述第二进程配置第二代理模块和第二通信通道;并基于第一通信通道实现第一进程与第一代理模块(或第一管理模块)之间的通信,基于第二通信通道实现第二进程与第二代理模块(第二管理模块)之间的通信,从而实现所述第一进程和所述第二进程之间的通信。如此,实现了在执行同一任务时,跨设备的进程间的通信;并且,该种方式的通信不需要复杂的算法,简单易实现。
且,本公开实施例只需要通过创建一对第一代理模块和第二代理模块,用于所述第一进程和所述第二进程的通信;其中,所述第一代理模块和所述代理模块,仅具备通信的特性,不具备计算的特性;从而本公开实施例还是一种轻量级的通信处理方法。
图9是根据一示例性实施例示出的一种信息处理装置。参照图9,该装置包括:配置模块31和通信模块32;其中,
配置模块31,用于在第一设备中为第一进程配置第一代理模块,其中,所述第一进程为由所述第一设备运行的进程;
通信模块32,用于基于所述第一代理模块,进行所述第一进程与运行在第二设备的第二进程之间的进程间通信,其中,所述第二进程和所述第一进程为同一个任务中执行不同子任务的并行进程。
在一些实施例中,所述配置模块31,还用于为所述第一进程和所述第一代理模块配置第一通信通道;
所述通信模块32,包括:
第一通信单元321,用于基于所述第一通信通道,进行所述第一进程与所述第一代理模块之间的通信;
第二通信单元322,用于所述第一代理模块基于网络传输,与在所述第二设备中为所述第二进程配置的第二代理模块进行通信;其中,所述第二代理模块,用于基于第二通信通道与所述第二进程进行通信;所述第二通信通道为在所述第二进程和所述第二代理模块之间配置的通道。
在一些实施例中,所述配置模块31,还用于基于所述第一进程的执行状态,确定所述第一通信通道的第一状态量;
所述第二通信单元322,用于所述第一代理模块基于所述网络传输将所述第一状态量同步给所述第二进程。
在一些实施例中,所述第二通信单元322,用于所述第一代理模块按照预定时间间隔读取所述第一通信通道的第一状态量,并基于所述网络传输将所述第一状态量同步给所述第二进程;或者,
用于所述第一代理模块监控所述第一状态量,并在所述第一状态量发生改变时,基于所述网络传输将变化后的所述第一状态量同步给所述第二进程。
在一些实施例中,所述第二通信单元322,用于所述第一代理模块接收所述第二代理模块发送的第二状态量,并将所述第二状态量通过所述第一通信通道发送给所述第一进程;
所述第一通信单元321,用于所述第一进程基于表征所述第二进程有数据输出的所述第二状态量,通过所述第一通信通道向所述第一代理模块发送第一读取请求;
所述第二通信单元322,用于所述第一代理模块将所述第一读取请求基于所述网络传输发送给所述第二代理模块,其中,所述第一读取请求,用于供所述第二代理模块基于所述第二通信通道发送给所述第二进程;
所述第二通信单元322,还用于所述第一代理模块接收所述第二代理模块转发的基于所述第一读取请求返回的第一数据;
所述第一通信单元321,还用于所述第一代理模块通过所述第一通信通道将所述第一数据发送给所述第一进程。
在一些实施例中,所述第二通信单元322,用于所述第一代理模块接收所述第二代理模块基于所述网络传输发送的所述第二进程的第二读取请求,并将所述第二读取请求通过所述第一通信通道发送给所述第一进程;
所述第一通信单元321,用于所述第一进程基于所述第二读取请求通过所述第一通信通道向所述第一代理模块发送第二数据;
所述第二通信单元322,还用于所述第一代理模块将所述第二数据基于所述网络传输发送给所述第二代理模块,其中,所述第二数据,用于供所述第二代理模块基于所述第二通信通道发送给所述第二进程。
在一些实施例中,还包括:
序列化模块33,用于所述第一代理模块将待发送数据进行序列化处理,得到待发送的数据队列,其中,所述待发送数据包括:函数和/或输入参数和/或所述第一通信通道的标识信息;用于所述第一代理模块按照所述数据队列将待发送数据通过所述网络传输发送给所述第二代理模块。
在一些实施例中,所述配置模块31,用于在所述第一设备中为所述第一进程配置第三代理模块;
所述通信模块32,用于基于所述第三代理模块,进行所述第一进程与第三进程之间的进程间通信,其中,所述第三进程为由所述第一设备运行的进程;所述第三进程与所述第一进程为同一任务中执行不同子任务的并行进程。
在一些实施例中,所述配置模块31,用于为所述第一进程和所述第三代理模块配置第三通信通道;
第一通信单元321,用于基于所述第三通信通道,进行所述第一进程与所述第三代理模块之间的通信;
所述通信模块32还包括:第三通信单元323,用于所述第三代理模块基于应用程序接口,与在所述第一设备中为所述第三进程配置的第四代理模块进行通信;其中,所述第四代理模块用于基于第四通信通道与所述第三进程进行通信;所述第四通信通道为在所述第三进程和所述第四代理模块之间配置的通道。
关于上述实施例中的装置,其中各个模块执行操作的具体方式已经在有关该方法的实施例中进行了详细描述,此处将不做详细阐述说明。
本公开实施例还提供了一种第一设备,包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为:用于运行计算机服务时,实现前述任一实施例所述的信息处理方法。
存储器可包括各种类型的存储介质,该存储介质为非临时性计算机存储介质,在通信设备掉电之后能够继续记忆存储其上的信息。
处理器可以通过总线等存储器连接,用于读取存储器上存储的可执行程序,例如,如图1、图2、图8所示方法的至少其中之一。
本公开实施例还提供了一种非临时性计算机可读存储介质,所述非临时性计算机可读存储介质存储有可执行程序,其中,所述可执行程序被处理器执行时实现前述任一实施例所述的信息处理方法。例如,实现如图1、图2、图8所示方法的至少其中之一。
关于上述实施例中的装置,其中各个模块执行操作的具体方式已经在有关该方法的实施例中进行了详细描述,此处将不做详细阐述说明。
图10是根据一示例性实施例示出的一种信息处理装置800的框图。例如,装置800可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
参照图10,装置800可以包括以下一个或多个组件:处理组件802,存储器804,电源组件806,多媒体组件808,音频组件810,输入/输出(I/O)的接口812,传感器组件814,以及通信组件816。
处理组件802通常控制装置800的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理组件802可以包括一个或多个处理器820来执行指令,以完成上述的方法的全部或部分步骤。此外,处理组件802可以包括一个或多个模块,便于处理组件802和其他组件之间的交互。例如,处理组件802可以包括多媒体模块,以方便多媒体组件808和处理组件802之间的交互。
存储器804被配置为存储各种类型的数据以支持在设备800的操作。这些数据的示例包括用于在装置800上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图片,视频等。存储器804可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
电源组件806为装置800的各种组件提供电力。电源组件806可以包括电源管理系统,一个或多个电源,及其他与为装置800生成、管理和分配电力相关联的组件。
多媒体组件808包括在所述装置800和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件808包括一个前置摄像头和/或后置摄像头。当设备800处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件810被配置为输出和/或输入音频信号。例如,音频组件810包括一个麦克风(MIC),当装置800处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器804或经由通信组件816发送。在一些实施例中,音频组件810还包括一个扬声器,用于输出音频信号。
I/O接口812为处理组件802和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件814包括一个或多个传感器,用于为装置800提供各个方面的状态评估。例如,传感器组件814可以检测到设备800的打开/关闭状态,组件的相对定位,例如所述组件为装置800的显示器和小键盘,传感器组件814还可以检测装置800或装置800一个组件的位置改变,用户与装置800接触的存在或不存在,装置800方位或加速/减速和装置800的温度变化。传感器组件814可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件814还可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件814还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信组件816被配置为便于装置800和其他设备之间有线或无线方式的通信。装置800可以接入基于通信标准的无线网络,如WiFi,2G或3G,或它们的组合。在一个示例性实施例中,通信组件816经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,所述通信组件816还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
在示例性实施例中,装置800可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述方法。
在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器804,上述指令可由装置800的处理器820执行以完成上述方法。例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本发明的其它实施方案。本申请旨在涵盖本发明的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本发明的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本发明的真正范围和精神由下面的权利要求指出。
应当理解的是,本发明并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本发明的范围仅由所附的权利要求来限制。
Claims (20)
1.一种信息处理方法,其特征在于,应用于第一设备,包括:
在所述第一设备中为第一进程配置第一代理模块,其中,所述第一进程为由所述第一设备运行的进程;
基于所述第一代理模块,进行所述第一进程与运行在第二设备的第二进程之间的进程间通信,其中,所述第二进程和所述第一进程为同一个任务中执行不同子任务的并行进程。
2.根据权利要求1所述的方法,其特征在于,所述方法包括:
为所述第一进程和所述第一代理模块配置第一通信通道;
所述基于所述第一代理模块,进行所述第一进程与运行在第二设备的第二进程之间的进程间通信,包括:
基于所述第一通信通道,进行所述第一进程与所述第一代理模块之间的通信;
所述第一代理模块基于网络传输,与在所述第二设备中为所述第二进程配置的第二代理模块进行通信;其中,所述第二代理模块,用于基于第二通信通道与所述第二进程进行通信;所述第二通信通道为在所述第二进程和所述第二代理模块之间配置的通道。
3.根据权利要求2所述的方法,其特征在于,所述方法还包括:
基于所述第一进程的执行状态,确定所述第一通信通道的第一状态量;
所述第一代理模块基于网络传输,与在所述第二设备中为所述第二进程配置的第二代理模块进行通信,包括:
所述第一代理模块基于所述网络传输将所述第一状态量同步给所述第二进程。
4.根据权利要求3所述的方法,所述第一代理模块基于所述网络传输将所述第一状态量同步给所述第二进程,包括:
所述第一代理模块按照预定时间间隔读取所述第一通信通道的第一状态量,并基于所述网络传输将所述第一状态量同步给所述第二进程;或者,
所述第一代理模块监控所述第一状态量,并在所述第一状态量发生改变时,基于所述网络传输将变化后的所述第一状态量同步给所述第二进程。
5.根据权利要求2所述的方法,其特征在于,所述基于所述第一代理模块,进行所述第一进程与运行在第二设备的第二进程之间的进程间通信,包括:
所述第一代理模块接收所述第二代理模块发送的第二状态量,并将所述第二状态量通过所述第一通信通道发送给所述第一进程;
所述第一进程基于表征所述第二进程有数据输出的所述第二状态量,通过所述第一通信通道向所述第一代理模块发送第一读取请求;
所述第一代理模块将所述第一读取请求基于所述网络传输发送给所述第二代理模块,其中,所述第一读取请求,用于供所述第二代理模块基于所述第二通信通道发送给所述第二进程;
所述第一代理模块接收所述第二代理模块转发的基于所述第一读取请求返回的第一数据;
所述第一代理模块通过所述第一通信通道将所述第一数据发送给所述第一进程。
6.根据权利要求2所述的方法,其特征在于,所述基于所述第一代理模块,进行所述第一进程与运行在第二设备的第二进程之间的进程间通信,包括:
所述第一代理模块接收所述第二代理模块基于所述网络传输发送的所述第二进程的第二读取请求,并将所述第二读取请求通过所述第一通信通道发送给所述第一进程;
所述第一进程基于所述第二读取请求通过所述第一通信通道向所述第一代理模块发送第二数据;
所述第一代理模块将所述第二数据基于所述网络传输发送给所述第二代理模块,其中,所述第二数据,用于供所述第二代理模块基于所述第二通信通道发送给所述第二进程。
7.根据权利要求3或4所述的方法,其特征在于,所述方法还包括:
所述第一代理模块将待发送数据进行序列化处理,得到待发送的数据队列,其中,所述待发送数据包括:函数和/或输入参数和/或所述第一通信通道的标识信息;
所述第一代理模块按照所述数据队列将待发送数据通过所述网络传输发送给所述第二代理模块。
8.根据权利要求1或2所述的方法,其特征在于,所述方法还包括:
在所述第一设备中为所述第一进程配置第三代理模块;
基于所述第三代理模块,进行所述第一进程与第三进程之间的进程间通信,其中,所述第三进程为由所述第一设备运行的进程;所述第三进程与所述第一进程为同一任务中执行不同子任务的并行进程。
9.根据权利要求8所述的方法,其特征在于,所述方法还包括:
为所述第一进程和所述第三代理模块配置第三通信通道;
所述基于所述第三代理模块,进行所述第一进程与第三进程之间的进程间通信,包括:
基于所述第三通信通道,进行所述第一进程与所述第三代理模块之间的通信;
所述第三代理模块基于应用程序接口,与在所述第一设备中为所述第三进程配置的第四代理模块进行通信;其中,所述第四代理模块用于基于第四通信通道与所述第三进程进行通信;所述第四通信通道为在所述第三进程和所述第四代理模块之间配置的通道。
10.一种信息处理装置,其特征在于,包括:
配置模块,用于在第一设备中为第一进程配置第一代理模块,其中,所述第一进程为由所述第一设备运行的进程;
通信模块,用于基于所述第一代理模块,进行所述第一进程与运行在第二设备的第二进程之间的进程间通信,其中,所述第二进程和所述第一进程为同一个任务中执行不同子任务的并行进程。
11.根据权利要求10所述的装置,其特征在于,所述配置模块,还用于为所述第一进程和所述第一代理模块配置第一通信通道;
所述通信模块,包括:
第一通信单元,用于基于所述第一通信通道,进行所述第一进程与所述第一代理模块之间的通信;
第二通信单元,用于所述第一代理模块基于网络传输,与在所述第二设备中为所述第二进程配置的第二代理模块进行通信;其中,所述第二代理模块,用于基于第二通信通道与所述第二进程进行通信;所述第二通信通道为在所述第二进程和所述第二代理模块之间配置的通道。
12.根据权利要求11所述的装置,其特征在于,所述配置模块,还用于基于所述第一进程的执行状态,确定所述第一通信通道的第一状态量;
所述第二通信单元,用于所述第一代理模块基于所述网络传输将所述第一状态量同步给所述第二进程。
13.根据权利要求12所述的装置,其特征在于,所述第二通信单元,用于所述第一代理模块按照预定时间间隔读取所述第一通信通道的第一状态量,并基于所述网络传输将所述第一状态量同步给所述第二进程;或者,
用于所述第一代理模块监控所述第一状态量,并在所述第一状态量发生改变时,基于所述网络传输将变化后的所述第一状态量同步给所述第二进程。
14.根据权利要求11所述的装置,其特征在于,所述第二通信单元,用于所述第一代理模块接收所述第二代理模块发送的第二状态量,并将所述第二状态量通过所述第一通信通道发送给所述第一进程;
所述第一通信单元,用于所述第一进程基于表征所述第二进程有数据输出的所述第二状态量,通过所述第一通信通道向所述第一代理模块发送第一读取请求;
所述第二通信单元,用于所述第一代理模块将所述第一读取请求基于所述网络传输发送给所述第二代理模块,其中,所述第一读取请求,用于供所述第二代理模块基于所述第二通信通道发送给所述第二进程;
所述第二通信单元,还用于所述第一代理模块接收所述第二代理模块转发的基于所述第一读取请求返回的第一数据;
所述第一通信单元,还用于所述第一代理模块通过所述第一通信通道将所述第一数据发送给所述第一进程。
15.根据权利要求11所述的装置,其特征在于,所述第二通信单元,用于所述第一代理模块接收所述第二代理模块基于所述网络传输发送的所述第二进程的第二读取请求,并将所述第二读取请求通过所述第一通信通道发送给所述第一进程;
所述第一通信单元,用于所述第一进程基于所述第二读取请求通过所述第一通信通道向所述第一代理模块发送第二数据;
所述第二通信单元,还用于所述第一代理模块将所述第二数据基于所述网络传输发送给所述第二代理模块,其中,所述第二数据,用于供所述第二代理模块基于所述第二通信通道发送给所述第二进程。
16.根据权利要求12或13所述的装置,其特征在于,还包括:
序列化模块,用于所述第一代理模块将待发送数据进行序列化处理,得到待发送的数据队列,其中,所述待发送数据包括:函数和/或输入参数和/或所述第一通信通道的标识信息;用于所述第一代理模块按照所述数据队列将待发送数据通过所述网络传输发送给所述第二代理模块。
17.根据权利要求10或11所述的装置,其特征在于,所述配置模块,用于在所述第一设备中为所述第一进程配置第三代理模块;
所述通信模块,用于基于所述第三代理模块,进行所述第一进程与第三进程之间的进程间通信,其中,所述第三进程为由所述第一设备运行的进程;所述第三进程与所述第一进程为同一任务中执行不同子任务的并行进程。
18.根据权利要求17所述的装置,其特征在于,所述配置模块,用于为所述第一进程和所述第三代理模块配置第三通信通道;
第一通信单元,用于基于所述第三通信通道,进行所述第一进程与所述第三代理模块之间的通信;
所述通信模块还包括:第三通信单元,用于所述第三代理模块基于应用程序接口,与在所述第一设备中为所述第三进程配置的第四代理模块进行通信;其中,所述第四代理模块用于基于第四通信通道与所述第三进程进行通信;所述第四通信通道为在所述第三进程和所述第四代理模块之间配置的通道。
19.一种第一设备,其特征在于,包括
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为:用于运行计算机服务时,实现权利要求1-9任一项所述的信息处理方法。
20.一种非临时性计算机可读存储介质,所述非临时性计算机可读存储介质存储有可执行程序,其中,所述可执行程序被处理器执行时实现权利要求1-9任一项所述的信息处理方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201911157221.9A CN112839065B (zh) | 2019-11-22 | 2019-11-22 | 信息处理方法、装置、第一设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201911157221.9A CN112839065B (zh) | 2019-11-22 | 2019-11-22 | 信息处理方法、装置、第一设备及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN112839065A true CN112839065A (zh) | 2021-05-25 |
CN112839065B CN112839065B (zh) | 2023-05-12 |
Family
ID=75922759
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201911157221.9A Active CN112839065B (zh) | 2019-11-22 | 2019-11-22 | 信息处理方法、装置、第一设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN112839065B (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN114172958A (zh) * | 2021-11-19 | 2022-03-11 | 云从科技集团股份有限公司 | 隐私计算节点、系统、方法、装置以及存储介质 |
CN115883654A (zh) * | 2022-11-29 | 2023-03-31 | 深圳市汇川技术股份有限公司 | 进程通信方法、装置、设备及存储介质 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102291467A (zh) * | 2011-09-15 | 2011-12-21 | 电子科技大学 | 一种适应私有云环境的通信平台和通信方法 |
US20160072908A1 (en) * | 2014-09-09 | 2016-03-10 | James Dinan | Technologies for proxy-based multi-threaded message passing communication |
CN107613312A (zh) * | 2017-10-09 | 2018-01-19 | 武汉斗鱼网络科技有限公司 | 一种直播的方法和装置 |
CN108491279A (zh) * | 2018-03-15 | 2018-09-04 | 南京智格电力科技有限公司 | 一种基于对象机制的分布式系统进程间通讯方法 |
-
2019
- 2019-11-22 CN CN201911157221.9A patent/CN112839065B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102291467A (zh) * | 2011-09-15 | 2011-12-21 | 电子科技大学 | 一种适应私有云环境的通信平台和通信方法 |
US20160072908A1 (en) * | 2014-09-09 | 2016-03-10 | James Dinan | Technologies for proxy-based multi-threaded message passing communication |
CN107613312A (zh) * | 2017-10-09 | 2018-01-19 | 武汉斗鱼网络科技有限公司 | 一种直播的方法和装置 |
CN108491279A (zh) * | 2018-03-15 | 2018-09-04 | 南京智格电力科技有限公司 | 一种基于对象机制的分布式系统进程间通讯方法 |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN114172958A (zh) * | 2021-11-19 | 2022-03-11 | 云从科技集团股份有限公司 | 隐私计算节点、系统、方法、装置以及存储介质 |
CN114172958B (zh) * | 2021-11-19 | 2023-10-20 | 云从科技集团股份有限公司 | 隐私计算节点、系统、方法、装置以及存储介质 |
CN115883654A (zh) * | 2022-11-29 | 2023-03-31 | 深圳市汇川技术股份有限公司 | 进程通信方法、装置、设备及存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN112839065B (zh) | 2023-05-12 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP3389230B1 (en) | System for providing dialog content | |
WO2016041312A1 (zh) | 应用程序运行方法及装置 | |
US20220400137A1 (en) | Widget display method and apparatus | |
CN110858173B (zh) | 一种数据处理方法、装置和用于数据处理的装置 | |
KR102566622B1 (ko) | 멀티코어 통신방법, 장치, 전자기기 및 저장매체 | |
CN113420338B (zh) | 一种数据处理方法、装置和用于数据处理的装置 | |
US20210136017A1 (en) | Method and apparatus for updating group member data, and terminal, system and storage medium | |
CN113377465A (zh) | 基于服务的sdk调用方法及装置、电子设备和存储介质 | |
CN112187862B (zh) | 一种任务处理方法、装置和用于任务处理的装置 | |
CN112839065B (zh) | 信息处理方法、装置、第一设备及存储介质 | |
CN111338971B (zh) | 应用测试方法、装置、电子设备及存储介质 | |
CN112925788A (zh) | 一种数据集管理方法及系统、装置、电子设备和存储介质 | |
CN112270410A (zh) | 在线推理服务系统、提供在线推理服务的方法及装置 | |
EP3823249B1 (en) | Discovery of iot devices and subsequent capability information exchange for invoking functions corresponding to capabilities of said iot devices | |
CN111314419B (zh) | 网络请求方法及装置 | |
CN112685104A (zh) | 应用程序启动控制方法、装置、电子设备和存储介质 | |
CN116089099A (zh) | 一种通信方法、装置、电子设备及存储介质 | |
WO2023124657A1 (zh) | 微应用的运行方法、装置、设备、存储介质及程序产品 | |
CN114430410B (zh) | 基于虚拟域名的系统访问方法、装置及设备 | |
CN110908814A (zh) | 消息处理方法、装置、电子设备及存储介质 | |
CN115589432A (zh) | 消息推送管理方法、装置、介质及设备 | |
CN111274590B (zh) | 请求处理方法、装置、电子设备及存储介质 | |
CN111245822B (zh) | 远程过程调用处理方法、装置及计算机存储介质 | |
CN108984294B (zh) | 资源调度方法、装置及存储介质 | |
CN115190158A (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 | ||
GR01 | Patent grant | ||
GR01 | Patent grant |