一种通信方式的实现方法及电子设备与流程

文档序号:18163677发布日期:2019-07-13 09:27阅读:172来源:国知局
一种通信方式的实现方法及电子设备与流程

本申请涉及通信技术领域,尤其涉及一种通信方式的实现方法及电子设备。



背景技术:

在macosx系统下,有多种进行进程间通信的方法,比如cfmessageport。

通过调用osx系统下的corefoundation框架的cfmessageportcreatelocalapi(创建本地接口api)在进程a中创建一个名称为“xxx”的cfmessageport本地端口,然后在另外一个进程b中通过调用cfmessageportcreateremote创建一个名称同样为“xxx”的cfmessageport远程端口。这样进程a和进程b便通过名称为“xxx”的端口建立起了通信连接。

但是上述方式只适合一对一的通信方式,不适合一对多的方式。如果进程a是一个服务器,而进程b是一个客户端,如果有多个客户端和一个服务器进行通信,那么cfmessageport这种技术方案就不合适。



技术实现要素:

本发明了提供了一种通信方式的实现方法及电子设备,以解决或者部分解决目前在osx系统下不能够实现一对多的通信的技术问题。

为解决上述技术问题,本发明提供了一种通信方式的实现方法,所述方法包括:

注册一虚拟服务名称,并创建微内核的监听端口;

基于多个客户端的获取请求,将所述监控接口发送给多个客户端,使得所述多个客户端基于所述监听接口发送各自的连接请求给所述监控接口;

接收所述多个客户端发送的各自的连接请求;

利用微内核信息服务器的线程为每个连接请求对应创建微内核消息会话实例,并生成各微内核消息会话实例的连接应答消息发送给各连接请求对应的客户端。

优选的,所述注册一虚拟服务名称,并创建微内核mach的监听端口,包括:

调用osx系统的bootstrap_check_in函数,将虚拟服务名称对应的字符串注册到osx系统中,并获取到所述监听端口。

优选的,所述接收所述多个客户端发送的各自的连接请求,具体包括:

利用微内核信息服务器的线程调用调用mach_msg系统函数接收来自各客户端的连接请求,其中各客户端的连接请求中携带有各客户端的端口名。

优选的,所述利用微内核信息服务器的线程为每个连接请求对应创建微内核消息会话实例,具体包括:

通过调用微内核信息服务器的allocsession函数,为各连接请求创建各自的一个machmessagesession会话实例;

调用machmessagesession的createfrom方法来初始化该各machmessagesession会话实例,使各machmessagesession会话实例包含有两个参数:对应的客户端的端口名,本地端口名。

优选的,所述生成各微内核消息会话实例的连接应答消息发送给各连接请求对应的客户端,包括:

将各machmessagesession会话实例的本地端口名封装到各自的连接应答消息中,并发送给对应的客户端的端口。

优选的,所述生成各微内核消息会话实例的连接应答消息发送给各连接请求对应的客户端之后,所述方法还包括:

将各machmessagesession会话实例放入到m_sessions列表中进行管理。

优选的,所述将各machmessagesession会话实例放入到m_sessions列表中进行管理之后,所述方法还包括:

在recvsessionmsg函数中对m_sessions列表中的所有machmessagesession进行读取操作,以获取对应的客户端发送的通信消息。

本发明公开了一种电子设备,包括:

注册模块,用以注册一虚拟服务名称,并创建微内核的监听端口;

发送模块,用以基于多个客户端的获取请求,将所述监控接口发送给多个客户端,使得所述多个客户端基于所述监听接口发送各自的连接请求给所述监控接口;

接收模块,用以接收所述多个客户端发送的各自的连接请求;

创建模块,用以利用微内核信息服务器的线程为每个连接请求对应创建微内核消息会话实例,并生成各微内核消息会话实例的连接应答消息发送给各连接请求对应的客户端。

本发明公开了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现上述方法的步骤。

本发明公开了一种计算机设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,所述处理器执行所述程序时实现上述方法的步骤。

通过本发明的一个或者多个技术方案,本发明具有以下有益效果或者优点:

本发明公开了一种通信方式的实现方法及电子设备,该方法包括:先注册一虚拟服务名称,并创建微内核的监听端口;会基于多个客户端的获取请求,将监控接口发送给多个客户端,使得多个客户端基于监听接口发送各自的连接请求给监控接口;然后接收多个客户端发送的各自的连接请求,并利用微内核信息服务器的线程为每个连接请求对应创建微内核消息会话实例,并生成各微内核消息会话实例的连接应答消息发送给对应的客户端。由此可见,本申请通过注册一虚拟服务名称来建立一监听接口,并利用微内核信息服务器的线程为每个连接请求对应创建微内核消息会话实例用来和各自的客户端进行通信,由此实现利用一个监听接口即可以和多个客户端实现‘一对多’的方式的通信。

附图说明

图1为本发明实施例中一种通信方式的实现方法的实施过程图;

图2为本发明实施例中电子设备的组成示意图。

具体实施方式

为了使本申请所属技术领域中的技术人员更清楚地理解本申请,下面结合附图,通过具体实施例对本申请技术方案作详细描述。

在本发明实施例中,采用了osx系统的mach微内核概念。通过在mach微内核中注册一个虚拟服务名称并创建微内核的一个监听端口,利用该监听接口和多个客户端进行通信,实现一对多的方式。在具体的实施过程中,首先会基于多个客户端的获取请求,将所述监控接口发送给多个客户端,使得所述多个客户端基于所述监听接口发送各自的连接请求给所述监控接口;然后接收所述多个客户端发送的各自的连接请求,并利用微内核信息服务器的线程为每个连接请求对应创建微内核消息会话实例,并生成各微内核消息会话实例的连接应答消息发送给对应的客户端。由此可见,本申请通过注册一虚拟服务名称来建立一监听接口,并利用微内核信息服务器的线程为每个连接请求对应创建微内核消息会话实例用来和各自的客户端进行通信,由此实现利用一个监听接口即可以和多个客户端实现‘一对多’的方式的通信。

下面介绍mach微内核。

osx系统是基于mach微内核的,而mach微内核中,一切的通信都是基于machmessage也就是mach消息来进行的。在mach消息中,最重要的概念就是machport也就是mach端口的概念。在osx系统中,消息的传递都是从一个mach端口传递到另外一个mach端口。

所以根据上述的osx特性,要实现进程间的通信,其实就是通过进程a中的mach端口将消息发送到进程b中的mach端口上。由于osx系统自带的cfmessageport其底层都是依赖于mach端口。所以本案也是在mach端口的基础上,根据自定义服务名称实现一对多的进程间通信的方法。在该通信过程开始时,服务端只需要注册一个虚拟的(也即任意的不存在的)服务名称,客户端便可以建立起连接。从而实现进程间的通信。

而mach消息的发送与接收的过程中,在osx中,都是通过mach_msg来接收和发送消息。该函数的第一个参数为mach_msg_header_t的指针,表示要发送或者接收的消息,第二个参数指明是要接收消息还是发送消息,当值为mach_send_msg时表示要发送消息,值为mach_rcv_msg时,表示要接收消息,第三个参数表示要发送的数据大小,第四个参数表示要接收的数据大小。本案后面在利用mach_msg接收和发送消息时,都是按上述方法进行的,所以后面不在赘述。

mach_msg_header_t结构,该结构是一个非常重要的结构,任何的mach消息的发送和接收都依赖于该结构。该结构的msgh_size表示要发送或者接收的数据大小,msgh_remote_port表示远程端口,在发送消息时一定要设置该字段值;msgh_local_port表示本地端口,在接收消息时一定要设置该字段值。

在本技术方案中有如下的几个名称:

machmessageserver,表示一个mach通信的服务器,通过一个具体的服务名称字符,用于处理来自machmessageclient客户端的连接请求,并创建一个machmessagesession对象表示一个与machmessageclient的连接。

machmessagesession,表示一个由machmesssageserver服务器类生成的一个会话器,当machmessageserver检测到一个来自machmessageclient的连接请求后,就会创建一个machmessagesession实例,以后就由该machmessagesession实例与machmessageclient进行数据的通信。这里便实现了一对多的概念。一个machmessageserver服务器实例通过创建多个machmessagesession实例,通过machmessagesession实例与其相对应的每个machmessageclient进行通信。

machmessageclient,该模块表示一个mach通信的客户端,该客户端通过一个具体的服务名称字符,向machmessageserver发送连接请求,并等待来自machmessageserver的请求应答,如果请求通过,便建立起了与machmessageserver的通信通道,如果请求被拒绝,那么通信失败。

machmessageconnect,该结构是本案中machmessageclient向machmessageserver发送的用于建立连接请求的消息。该消息中的第一个字段为类型为mach_msg_header_t的header字段(任何的mach消息都必须包括这个mach_msg_header_t的头部结构和一个名称为portname的字符串,该字符串表示machmessageclient的本地mach端口名称。

machmessageconnectresult,该结构是本案中machmessageserver向machmessageclient发送的用于应答连接请求的结果消息。同样第一个字段为mach_msg_header_t的header字段,一个名称为sessionid的整型字段,和一个名称为portname的字符串,该字符串表示与该machmessageclient进行通信的远程mach端口名称。

通过上述对machmessageserver、machmessagesession以及machmessageclient的介绍,下面来阐述相互怎样进行建立连接以及数据接收的。

参看图1,在本发明实施过程中,公开了一种通信方式的实现方法,该方法包括:

步骤11,注册一虚拟服务名称,并创建微内核的监听端口。

在具体的实施过程中,调用osx系统的bootstrap_check_in函数,将虚拟服务名称对应的字符串注册到osx系统中,并获取到所述监听端口。

进一步的,machmessageserver服务器调用osx系统的bootstrap_check_in函数,将服务名称为‘xxx’的字符串注册到系统中,并判断该函数的返回值,如果该函数的返回值为0,则代表注册服务成功,并获取到一个名称为m_listenport的监听端口,并进入到下面的步骤2)。如果返回值不等于0,则注册服务失败,直接退出系统。

步骤12,基于多个客户端的获取请求,将所述监控接口发送给多个客户端,使得所述多个客户端基于所述监听接口发送各自的连接请求给所述监控接口。

步骤13,接收所述多个客户端发送的各自的连接请求。

具体来说,本发明实施例是利用微内核信息服务器的线程调用调用mach_msg系统函数接收来自各客户端的连接请求,其中各客户端的连接请求中携带有各客户端的端口名。

步骤14,利用微内核信息服务器的线程为每个连接请求对应创建微内核消息会话实例,并生成各微内核消息会话实例的连接应答消息发送给各连接请求对应的客户端。

在具体的实施过程中,主要是通过调用微内核信息服务器的allocsession函数,为各连接请求创建各自的一个machmessagesession会话实例;然后调用machmessagesession的createfrom方法来初始化该各machmessagesession会话实例,使各machmessagesession会话实例包含有两个参数:对应的客户端的端口名,本地端口名。

进一步的,会将各machmessagesession会话实例的本地端口名封装到各自的连接应答消息中,并发送给对应的客户端的端口。

而作为一种可选的实施方式,所述生成各微内核消息会话实例的连接应答消息发送给对应的客户端之后,还会将各machmessagesession会话实例放入到m_sessions列表中进行管理。之后,当服务器和客户端正式通信时,会在recvsessionmsg函数中对m_sessions列表中的所有machmessagesession进行读取操作,以获取对应的客户端发送的通信消息。

上述是本发明针对各客户端建立各machmessagesession会话实例用以和对应的客户端进行通信的方式。而为了便于说明和解释本发明,下述实施例将采用建立一个machmessagesession会话实例和一个客户端之间的通信的方式来进行描述。

1)注册服务名称,并创建mach监听端口

调用osx系统的bootstrap_check_in函数,将服务名称为xxx的字符串注册到系统中,并判断该函数的返回值,如果该函数的返回值为0,则代表注册服务成功,并获取到一个名称为m_listenport的监听端口,并进入到下面的步骤2)。如果返回值不等于0,则注册服务失败,直接退出系统。

2)创建machmessageserver的线程循环

上一步调用成功后,创建一个线程来循环的处理来自客户端的连接请求,并接收每个machmessagesession对应的machmessageclient的消息。在线程循环中,通过调用machmessageserver的listenportloop函数来处理来自客户端的连接请求,通过recvsessionmsg来接收来自客户端的消息

3)listenportloop处理连接请求

在该函数中通过调用mach_msg系统函数,来接收来自客户端的连接请求,为了防止该函数阻塞线程循环,在调用该函数时,设定1毫秒的超时时间。如果该函数的返回值为mach_msg_success,表示成功的接收到了一条mach消息。然后判断该消息结构的mach_msg_header_t结构中的msgh_id字段是否等于mmt_connect值,如果相等,则代表该消息是一个类型为machmessageconnect的连接请求消息。进入到下面的步骤a)

a)创建machmessagesession

通过调用machmessageserver的allocsession函数,创建一个machmessagesession会话实例,然后调用machmessagesession的createfrom方法来初始化该session,该函数有两个特别重要的参数,一个是remoteportname,代表machmessageclient客户端的端口名,一个是localportname代表该session的本地端口名。客户端在向machmessageserver发送machmessageconnect连接请求消息时,会带有一个portname的字符串,该字符串就是createfrom所需要的remoteportname参数,而localportname则通过生成一个随机的guid字符串来代表。在createfrom函数内部,通过调用bootstrap_look_up来获取remoteportname所代表的远程端口,标记为m_remoteport,并通过调用bootstrap_check_in来创建一个本地端口,标记为m_localport。完成之后,machmessagesession便可以向m_remoteport发送消息给machmessageclient,并通过m_localport接收来自machmessageclient的消息。

b)向客户端返回连接请求结果消息

上步骤中的createfrom完成之后,便成功的创建了一个machmessagesession,同machmessageclient进行通信。此时必须向machmessageclient发送一个messagemessageconnectresult的连接应答消息,该消息中包含有在步骤a)中创建的localportname字符串。machmessageclient通过向该localportname所对应的端口上向该machmessagesession发送消息。

c)将创建的machmessagesession放入到m_sessions列表中进行管理。

4)recvsessionmsg接收客户端消息

在recvsessionmsg函数中对m_sessions列表中的所有machmessagesession进行读取操作,也就是调用machmessagesession的read方法,来获取来自machmessageclient的通信消息。

一、machmessageclient客户端逻辑

上面讲述了machmessageserver如何监听来自machmessageclient的连接请求,以及创建相应的machmessagesession同machmessageclient进行数据通信,以及向client发送machmessageconnectresult连接结果消息。下面主要讲述machmessageclient向server发起连接请求的主要步骤

1)获取machmessageserver注册的服务名称端口

通过调用bootstrap_look_up函数获取server端所注册的名称为xxx的监听端口,如果该函数的返回值等于0,则进入到下面的步骤2)

2)创建一个随机guid字符串,并通过该字符串创建一个mach端口

创建一个随机的guid字符串,然后调用bootstrap_check_in来获取该guid字符端所对应的端口,client并依赖该端口接收消息。

3)发送machmessageconnect连接请求消息

将步骤2)中的guid字符串填充到machmessageconnect的portname字段中,然后调用mach_msg函数向server发送连接请求消息。

4)等待连接请求结果

machmessageconnect消息发送出去后,调用mach_msg函数接收来自server的machmessageconnectresult连接结果消息。然后获取machmessageconnectresult结构中的portname字段,然后调用bootstrap_loop_up函数获取portname所对应的远程mach端口,从而client便可以通过该端口向machmessagesession发送消息。

通过上述对machmessageserver和machmessageclient进行连接请求和应答的介绍,实现了利用mach端口进行一对多的进程间通信的方法。在该通信过程开始时,服务端只需要注册一个任意的不存在的服务名称,各客户端便可以建立起连接。从而实现进程间的通信。

基于同一发明构思,本发明实施例还公开了一种电子设备,参看图2,包括:

注册模块21,用以注册一虚拟服务名称,并创建微内核的监听端口;

发送模块22,用以基于多个客户端的获取请求,将所述监控接口发送给多个客户端,使得所述多个客户端基于所述监听接口发送各自的连接请求给所述监控接口;

接收模块23,用以接收所述多个客户端发送的各自的连接请求;

创建模块24,用以利用微内核信息服务器的线程为每个连接请求对应创建微内核消息会话实例,并生成各微内核消息会话实例的连接应答消息发送给各连接请求对应的客户端。

基于与前述实施例中同样的发明构思,本发明还提供一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现前文任一所述方法的步骤。

基于与前述实施例中同样的发明构思,本发明还提供一种计算机设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,所述处理器执行所述程序时实现前文任一所述方法的步骤。

通过本发明的一个或者多个实施例,本发明具有以下有益效果或者优点:

本发明公开了一种通信方式的实现方法及电子设备,先注册一虚拟服务名称,并创建微内核的监听端口;会基于多个客户端的获取请求,将监控接口发送给多个客户端,使得多个客户端基于监听接口发送各自的连接请求给监控接口;然后接收多个客户端发送的各自的连接请求,并利用微内核信息服务器的线程为每个连接请求对应创建微内核消息会话实例,并生成各微内核消息会话实例的连接应答消息发送给对应的客户端。由此可见,本申请通过注册一虚拟服务名称来建立一监听接口,并利用微内核信息服务器的线程为每个连接请求对应创建微内核消息会话实例用来和各自的客户端进行通信,由此实现利用一个监听接口即可以和多个客户端实现‘一对多’的方式的通信。

尽管已描述了本申请的优选实施例,但本领域内的普通技术人员一旦得知了基本创造性概念,则可对这些实施例作出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本申请范围的所有变更和修改。

显然,本领域的技术人员可以对本申请进行各种改动和变型而不脱离本申请的精神和范围。这样,倘若本申请的这些修改和变型属于本申请权利要求及其等同技术的范围之内,则本申请也意图包含这些改动和变型在内。

当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1