CN114979240B - 一种分布式WebSocket接入***及方法 - Google Patents

一种分布式WebSocket接入***及方法 Download PDF

Info

Publication number
CN114979240B
CN114979240B CN202210884320.2A CN202210884320A CN114979240B CN 114979240 B CN114979240 B CN 114979240B CN 202210884320 A CN202210884320 A CN 202210884320A CN 114979240 B CN114979240 B CN 114979240B
Authority
CN
China
Prior art keywords
message
client
websocket
server
access device
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.)
Active
Application number
CN202210884320.2A
Other languages
English (en)
Other versions
CN114979240A (zh
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.)
Hangzhou Wonderful Miaoxing Network Technology Co ltd
Original Assignee
Hangzhou Wonderful Miaoxing Network 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 Hangzhou Wonderful Miaoxing Network Technology Co ltd filed Critical Hangzhou Wonderful Miaoxing Network Technology Co ltd
Priority to CN202210884320.2A priority Critical patent/CN114979240B/zh
Publication of CN114979240A publication Critical patent/CN114979240A/zh
Application granted granted Critical
Publication of CN114979240B publication Critical patent/CN114979240B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/14Session management
    • H04L67/141Setup of application sessions
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/02Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
    • 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
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D30/00Reducing energy consumption in communication networks
    • Y02D30/70Reducing energy consumption in communication networks in wireless communication networks

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Security & Cryptography (AREA)
  • Computer And Data Communications (AREA)

Abstract

本申请涉及一种分布式WebSocket接入***,该***包括:代理接入器和消息服务器,其中,代理接入器用于,分别与消息服务器和客户端进行双向通信,其中,***中分布式部署多个代理接入器,且每个代理接入器连接多个客户端;消息服务器用于,分别与代理接入器和业务服务器进行双向通信,其中,各个代理接入器,分别通过各自的一条WebSocket连接通道,与消息服务器连接,WebSocket连接通道基于websocket Tunnel协议建立,websocket Tunnel协议中,通过特定封装结构,将代理接入器转发的多个客户端数据,集合在一条WebSocket连接通道上进行传输。通过本申请,在不改变服务端硬件配置的情况下,提升了服务端可连接客户端的数量上限。

Description

一种分布式WebSocket接入***及方法
技术领域
本申请涉及网络通信领域,特别是涉及一种分布式WebSocket接入***及方法。
背景技术
WebSocket是一种通信协议,其使得客户端和服务器之间的数据交换变得更加简单高效,且允许服务端主动向客户端推送数据。基于上述优点,WebSocket在实时通信场合应用越来越多,例如:APP或浏览器的消息推送,微信小游戏的实时互动等。
在业务场景下,通常服务端都需连接大量(如100万)的客户端;在相关技术中,针对大规模客户端连接,采用常规的分布式WebSocket接入方法存在如下缺陷:
1:服务端程序需要尽可能的高效(即单个进程算力消耗应尽量小),同时,还需对服务端操作***的网络层进行优化,经优化后,能够支持大量连接的服务端需要较大的内存(例如100万的连接数量,需要至少20G内存空间作为支撑);
2:由于客户端的请求需通过负载均衡设备进行处理及转发,当客户端连接数量较多时,将对负载均衡设备造成很大运行压力,对负载均衡设备的使用寿命和***的整体稳定性均产生不利影响;
3:相比较于传统HTTP协议,服务端针对WebSocket协议进行开发的过程较为复杂,开发难度更大,需要消耗更多的的时间和人力成本。
目前针对现有WebSocket接入***中的上述问题,尚未提出有效的解决方案。
发明内容
本申请实施例提供了一种分布式WebSocket接入方法***、方法、计算机设备和存储介质,以至少解决WebSocket通信方式中服务端可连接客户端数量受限的问题。
第一方面,本申请实施例提供了一种分布式WebSocket接入***,所述***包括:代理接入器和消息服务器,其中;
所述代理接入器用于,分别与所述消息服务器和客户端进行双向通信,其中,***中分布式部署多个代理接入器,且每个代理接入器连接多个客户端;
所述消息服务器用于,分别与所述代理接入器和业务服务器进行双向通信,其中,各个代理接入器,分别通过各自的一条WebSocket连接通道,与所述消息服务器连接,
所述WebSocket连接通道基于websocket Tunnel协议建立,所述websocketTunnel协议中,通过特定封装结构,将代理接入器转发的多个客户端数据,集合在一条WebSocket连接通道上进行传输。
在其中一些实施例中,所述特定封装结构中,将多个客户端发送的消息数据进行聚合,并重新定义所述消息数据的消息体结构,其中,所述消息体结构的文件头添加有消息类型和客户ID。
在其中一些实施例中,所述消息服务器中维护有客户端列表,所述客户端列表中包括多组客户端信息记录,所述客户端信息记录包括:互相匹配的客户ID、客户端地址和代理接入器ID。
在其中一些实施例中,在向所述客户端推送消息数据的情况下:
所述业务服务器用于,向所述消息服务器发送消息数据,其中,所述消息数据中包括客户ID和消息内容;
所述消息服务器用于,根据所述客户ID在所述客户端列表中查找,确定所述消息数据对应的代理接入器ID,以及,
将所述消息数据以所述websocket Tunnel协议的特定封装结构处理后,根据所述代理接入器ID,通过所述WebSocket连接通道,将其转发对应的代理接入器;
所述代理接入器用于,根据所述消息数据中的消息类型,判断所述消息数据的处理方式,并根据所述客户ID确定对应的客户端地址,以及根据所述客户端地址,将所述消息数据转发至对应的客户端。
在其中一些实施例中,所述WebSocket Tunnel协议中传输的消息数据是WebSocket消息,所述WebSocket Tunnel协议中消息数据为JSON格式。
在其中一些实施例中,所述消息服务器还用于:
在接收到所述代理接入器转发的消息数据之后,将所述消息数据由WebSocket协议格式转换成HTTP协议格式,
并将所述HTTP协议格式的消息数据转发至所述业务服务器。
在其中一些实施例中,所述***还包括自定义部署模块,所述自定义部署模块用于,根据业务需求,自定义部署所述消息服务器和所述代理接入器,包括:
根据业务服务器的不同业务事项,针对性部署每个业务服务器的专用消息服务器;
根据资源配置需求,将所述消息服务器部署在不同的机房或云平台;
根据运营商线路,部署所述代理接入器和配置所述代理接入器的数量,以及,在多个所述消息服务器之间,共用所述代理接入器。
第二方面,本申请实施例提供了一种分布式WebSocket接入方法,所述方法包括:
代理接入器,分别与消息服务器和客户端进行双向通信,其中,***中分布式部署多个代理接入器,且每个代理接入器连接多个客户端;
消息服务器,分别与所述代理接入器和业务服务器进行双向通信,其中,各个代理接入器,分别通过各自的一条WebSocket连接通道,与所述消息服务器连接,其中,
所述WebSocket连接通道基于websocket Tunnel协议建立,所述websocketTunnel协议中,通过特定封装结构,将所述代理接入器转发的多个客户端数据,集合在一条WebSocket连接通道上进行传输。
第三方面,本申请实施例提供了一种计算机设备,包括存储器、处理器以及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如上述第一方面所述的方法。
第四方面,本申请实施例提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现如上述第一方面所述的方法。
相比于现有技术,本申请实施例提供的分布式WebSocket接入***至少具备如下有益效果:
1.分布式部署多个代理接入器,可支持水平扩展的特点,首先可允许接入更多数量的客户端;进一步的,基于特定的websocket Tunnel协议,可将多个客户端的数据,通过一条线路发送至消息服务器进而发送至业务服务器,
对于业务服务器而言,其只需处理较小数量的连接线路,即可实现与大量客户端通信,从而在服务端硬件资源不变的情况下,提升了客户端连接上限;
2.由于服务器的连接线路数量降低,负载均衡设备的处理量也随之降低,因此,可降低负载均衡设备的运行压力,提升其使用寿命;
3.通过消息服务器将客户端发送的消息数据,由WebSocket协议转换为HTTP协议,无需在服务端针对WebSocket协议进行独立开发配置,降低了服务端开发难度和时间及人力成本;
4.用户可以根据自身需求,结合业务实际情况灵活部署消息服务器,例如:将配置较高的消息服务器专用于其主营业务,将配置相对较差的消息服务器专用于辅助业务,或者将不同消息服务器部署在不同的机房或者云平台等,从而将负载合理分配、实现资源最大化利用,进而提升服务的稳定性。
附图说明
此处所说明的附图用来提供对本申请的进一步理解,构成本申请的一部分,本申请的示意性实施例及其说明用于解释本申请,并不构成对本申请的不当限定。在附图中:
图1是现有技术中分布式WebSocket通信方式的示意图;
图2是根据本申请实施例的一种分布式WebSocket接入***的架构图;
图3是根据本申请实施例的一种WebSocket Tunnel协议的封装结构的示意图;
图4是根据本申请实施例的部分消息结构的示意图;
图5是根据本申请实施例的代理接入器的工作示意图;
图6是根据本申请实施例的消息服务器的工作示意图;
图7是根据本申请实施例的一种客户端列表的示意图;
图8是根据本申请实施例的一种业务端推送数据到目标客户端的流程示意图;
图9是根据本申请实施例的一种自定义部署消息服务器的示意图;
图10是根据本申请实施例的电子设备的内部结构示意图。
具体实施方式
为了使本申请的目的、技术方案及优点更加清楚明白,以下结合附图及实施例,对本申请进行描述和说明。应当理解,此处所描述的具体实施例仅仅用以解释本申请,并不用于限定本申请。基于本申请提供的实施例,本领域普通技术人员在没有作出创造性劳动的前提下所获得的所有其他实施例,都属于本申请保护的范围。
显而易见地,下面描述中的附图仅仅是本申请的一些示例或实施例,对于本领域的普通技术人员而言,在不付出创造性劳动的前提下,还可以根据这些附图将本申请应用于其他类似情景。此外,还可以理解的是,虽然这种开发过程中所作出的努力可能是复杂并且冗长的,然而对于与本申请公开的内容相关的本领域的普通技术人员而言,在本申请揭露的技术内容的基础上进行的一些设计,制造或者生产等变更只是常规的技术手段,不应当理解为本申请公开的内容不充分。
在本申请中提及“实施例”意味着,结合实施例描述的特定特征、结构或特性可以包含在本申请的至少一个实施例中。在说明书中的各个位置出现该短语并不一定均是指相同的实施例,也不是与其它实施例互斥的独立的或备选的实施例。本领域普通技术人员显式地和隐式地理解的是,本申请所描述的实施例在不冲突的情况下,可以与其它实施例相结合。
除非另作定义,本申请所涉及的技术术语或者科学术语应当为本申请所属技术领域内具有一般技能的人士所理解的通常意义。本申请所涉及的“一”、“一个”、“一种”、“该”等类似词语并不表示数量限制,可表示单数或复数。本申请所涉及的术语“包括”、“包含”、“具有”以及它们任何变形,意图在于覆盖不排他的包含;例如包含了一系列步骤或模块(单元)的过程、方法、***、产品或设备没有限定于已列出的步骤或单元,而是可以还包括没有列出的步骤或单元,或可以还包括对于这些过程、方法、产品或设备固有的其它步骤或单元。本申请所涉及的“连接”、“相连”、“耦接”等类似的词语并非限定于物理的或者机械的连接,而是可以包括电气的连接,不管是直接的还是间接的。本申请所涉及的“多个”是指两个或两个以上。“和/或”描述关联对象的关联关系,表示可以存在三种关系,例如,“A和/或B”可以表示:单独存在A,同时存在A和B,单独存在B这三种情况。字符“/”一般表示前后关联对象是一种“或”的关系。本申请所涉及的术语“第一”、“第二”、“第三”等仅仅是区别类似的对象,不代表针对对象的特定排序。
图1是现有技术中分布式WebSocket通信方式的示意图,如图1所示,无论是云服务还是IDC(机房)的服务部署,一般都会存在一个7层网关/负载均衡设备(可利用专用硬件设备或者nginx、haproxy等软件实现),用于统一接受用户请求,再将请求发送到对应的服务节点。
在服务端内存等配置固定的情况下,由于算力有限,可连接客户端数量是有限的,同时,数量庞大的客户端会对负载均衡设备造成很大的运行压力,以支持100万客户端为例,负载均衡设备需要维护200万的WebSocket连接。
针对上述问题,本案发明人提出了一种改进方案,图2是根据本申请实施例的一种分布式WebSocket接入***的架构图,如图2所示,该***主要包括:代理接入器和消息服务器,其中;
代理接入器(WebSocket Agent)用于,分别与消息服务器(WebSocket MessageServer)和客户端进行双向通信,其中,***中分布式部署多个代理接入器,且每个代理接入器连接多个客户端;
其中,代理接入器负责将客户端发送的消息转发给消息服务器,同时把消息服务器发来的消息转发给客户端。当然,代理接入器同时也负责将把客户端的一些事件(例如客户端连接、客户端断开等状态信息)发送至消息服务器,以及与客户端的连接认证及心跳检测。本申请中,由于代理接入器只用于客户端的维护和数据转发,不参与具体的业务处理,因此,其算力消耗较小,可选择性能要求相对较低的环境进行部署。
另外,代理接入器与客户端之间通过传统WebSocket协议传输数据,且一个代理接入器可以同时连接多个客户端。该代理接入器通常部署在网络的边缘侧,且各个客户端所连接的代理接入器应就近分配。
进一步的,在初始情况下,***中可部署一定数量的代理接入器,随着业务发展,若需进一步提升客户端接入数量,可基于利用其支持水平扩展的特点,随时在***中增加部署新的代理接入器。
还需说明的是,本实施例中,代理接入器的分布式部署还可以带来如下有益效果:
1.可以针对客户所在网络针对性的进行部署,例如:针对电信用户就把代理接入器部署到电信网络,针对联通用户将代理接入器部署到联通网络。从而提高各个客户端的消息传输速度。
2.可以针对客户数量分布调整部署。比如电信用户多,就可以在电信网络部署多个(例如8个)代理接入器,而联通用户少,就可以在联通网络部署较少个(例如1个)代理接入器。
3.因为每个代理接入器只负责一部分客户端的连接,因此,当某个代理接入器出现故障的时候,只会影响到一小部分的客户端,而不会对所有客户端造成影响,从而限制了故障的影响面,提升了***整体的稳定性。
消息服务器(WebSocket Message Server)用于,分别与代理接入器和业务服务器进行双向通信,其中,各个代理接入器,分别通过各自的一条WebSocket连接通道,与消息服务器连接,
WebSocket连接通道基于websocket Tunnel协议建立,websocket Tunnel协议中,通过特定封装结构,将代理接入器转发的多个客户端数据,集合在一条WebSocket连接通道上进行传输。
需强调的是,本实施例中,一个代理接入器与一个消息服务器之间只有一条连接通道(线路),该连接通道基于本案发明人自行设计的websocket Tunnel协议建立。
通过该websocket Tunnel协议,代理接入器可将与其连接的多个客户端的消息数据,聚合在一个线路中发送至消息服务器。具体的:该websocket Tunnel协议中采用特定的封装结构,图3是根据本申请实施例的一种WebSocket Tunnel协议的封装结构的示意图,如图3所示:
各个客户端的消息数据被结合为一个消息文件,各个消息消息数据被重新定义消息结构,具体的,在每个消息数据的数据内容之前,添加消息类型和客户ID,其中,消息类型用于指示该消息数据将被执行何种处理,客户ID为用户的身份识别ID。另外,消息采用使用广泛的JSON格式传输,不需要专门设计消息编码和解码。
如图4所示,图4是根据本申请实施例的部分消息结构的示意图。
进一步的,由于WebSocket Tunnel协议的底层仍然基于WebSocket,在WebSocketTunnel协议中传输的数据也仍然是WebSocket消息;
因此,无需任何特殊设备,使用现有的网络基础设施即可实现通信,通过现有的网关设备,即可在代理接入器和消息服务器之间建立上述WebSocket连接通道。
相比较于传统基于WebSocket协议的通信方式,本***通过分布式部署的代理接入器接入多个客户端,并通过websocket Tunnel协议将多个客户端的消息数据汇集到一条连接线路上转发给消息服务器,进而转发至业务服务器。由于业务服务器连接线路仅为与代理接入器的连接线路,因此服务端所需处理的连接线路大大降低,从而提升客户端的接入量,同时,也并不干扰与客户端的正常通信。
进一步的,消息服务器还用于协议转换,即将代理接入器发送的WebSocketTunnel协议数据转换为HTTP协议数据之后,再将其转发至服务端。
或者,将服务端发送的HTTP协议数据,转换为WebSocket Tunnel协议数据之后,再将其发送至代理接入器。
需要说明的是,相比较于传统HTTP协议,服务端针对WebSocket协议进行开发的过程较为复杂,且开发难度更大,需要消耗更多的的时间和人力成本。本实施例中,由消息服务器中将消息数据转换为传统的HTTP协议,从而在服务端,无需进行额外开发,从而降低时间和人力成本,也可无缝对接现有的基于HTTP协议的服务端。
在其中一些实施例中,图5是根据本申请实施例的代理接入器的工作示意图,如图5所示:
代理接入器用于接入客户端,以及分别与消息服务器和客户端进行双向通信,即将客户端发送的数据转发至消息服务器,以及,将消息服务器发送的数据转发至客户端。
进一步的,代理接入器还负责与客户端和消息服务器的身份认证及心跳检测。由于如何建立连接、如何进行身份认证以及如何心跳检测,均不涉及本申请的核心发明点,且是本领域技术人员的的常规技术手段,故在本实施例不再展开说明。
在其中一些实施例中,图6是根据本申请实施例的消息服务器的工作示意图,如图6所示:
消息服务器,分别与代理接入器和业务服务器进行双向通信。即将代理接入器发送的数据转发至业务服务器,或者,将代理服务器发送的数据转发至代理接入器。除此之外,还负责websocket协议与HTTP协议的相互转换。进一步的,进行身份认证和心跳检测的具体技术细节此处也不再赘述。
在其中一些实施例中,图7是根据本申请实施例的一种客户端列表的示意图,消息服务器中维护有客户端列表,客户端列表中包括多组客户端信息记录,客户端信息记录包括:客户ID、客户端地址和客户端连接的代理接入器的ID。
其中,在上述列表中,客户ID(client_id)需8个字节,代理接入器编号(agent_id)需2个字节,客户端地址(remote_addr)需6个字节,时间(time)需8个字节。因此,一条客户端记录只占24字节的内存,当100万个客户端连接时,只需要24M内存即可。
另外,由图7可以看出,有两条记录的客户ID都为“34567”,是因为该***支持同一个客户在多个设备上同时连接。
在其中一些实施例中,图8是根据本申请实施例的一种业务端推送数据到目标客户端的流程示意图,如图8所示,
首先,业务服务器向消息服务器发送HTTP消息数据,例如:“POST/23456{‘message’.‘你有2条未读消息’}”,其中,消息数据中包括客户ID和消息内容;
其次,消息服务器,根据客户ID,在本地保存的客户端列表中查找客户端信息,进而确定到与该消息数据匹配的代理接入器ID和客户端地址;
进一步的,消息服务器将消息数据以websocket Tunnel协议特定封装结构处理后,根据代理接入器ID,通过上述WebSocket连接通道,将其转发至对应的代理接入器,其中,封装之后的消息数据包括:消息类型、客户ID和消息内容;
最后,代理接入器根据消息数据中封装的的消息类型,判断消息数据的处理方式,(例如:消息类型“type”的指代字符“0×05”,则判断该消息数据需要被发送至客户端)。并根据客户ID“23456”确定对应的客户端地址,以及将消息数据“你有2条未读消息”转发至对应的客户端。
在其中一些实施例中,在客户端向业务服务器发送数据时,数据首先被代理接入器获取,其次代理控制器将多个客户端的消息数据以固定格式封装,并通过基于websocketTunnel协议建立的WebSocket连接通道,将其发送至消息服务器。最后,经由消息服务器将各个客户端的消息数据转换为HTTP协议数据之后,发送至业务服务器。
在其中一些实施例中,本申请方案在实际部署中,还具备具备灵活多变的特点,即可以根据业务情况和自身需求灵活制定多种部署方案。本***通过自定义部署模块,根据人工指令自定义部署消息服务器和代理接入器;
例如:在一个具备多业务线的公司,可以针对不同的业务部署多个专用的消息服务器,同时使多个消息服务器共用代理接入器,具体的,
用户可以结合自身需求,根据业务实际情况灵活部署消息服务器,例如:将硬件配置较高的消息服务器专用于其主营业务,将配置相对较差的消息服务器专用于辅助业务。
图9是根据本申请实施例的一种自定义部署消息服务器的示意图,如图9所示,游戏业务服务器由专用的游戏消息服务器负责通信,社交业务服务器由专用的社交消息服务器负责通信。
由于消息服务器是所有客户信息的中转和协议转换组件,利用上述自定义部署方式,将拥有更高配置的节点用于算力需求更大、场景更为复杂的业务,将配置相对较差的消息服务器节点应用于较为简单的业务。从而针对特定的业务需求,针对性地部署专用的消息服务器,进而合理均衡分配***负载,提升整体稳定性。
进一步的,针对某些场景特别复杂,消息处理压力特别大的业务场景,还可以针对该业务设置多个专用消息服务器以分担运行压力,从而进一步提升整体稳定性。
另外,还需说明的是,代理接入器一般部署在网络边缘,其尽量靠近客户端。例如,针对各个运营商的线路分别部署,从而提高客户连接速度。同时,由于代理接入器要支持大量客户端,且其数量较多,考虑到成本,代理接入器可以设设计为支持各条业务线(即各个业务服务器)共用,而无需针对每条业务线各自部署一遍。
在其中一些实施例中,本申请实施例还提供了一种分布式WebSocket接入方法,该方法包括:
代理接入器,分别与消息服务器和客户端进行双向通信,其中,***中分布式部署多个代理接入器,且每个代理接入器连接多个客户端;
消息服务器,分别与代理接入器和业务服务器,进行双向通信,且各个代理接入器,分别通过各自的一条WebSocket连接通道,与消息服务器连接,其中,
WebSocket连接通道基于websocket Tunnel协议建立,websocket Tunnel协议中,通过特定封装结构,将代理接入器转发的多个客户端数据,集合在一条WebSocket连接通道上进行传输。
在一个实施例中,提供了一种计算机设备,该计算机设备可以是终端。该计算机设备包括通过***总线连接的处理器、存储器、网络接口、显示屏和输入装置。其中,该计算机设备的处理器用于提供计算和控制能力。该计算机设备的存储器包括非易失性存储介质、内存储器。该非易失性存储介质存储有操作***和计算机程序。该内存储器为非易失性存储介质中的操作***和计算机程序的运行提供环境。该计算机设备的网络接口用于与外部的终端通过网络连接通信。该计算机程序被处理器执行时以实现一种分布式WebSocket接入方法。该计算机设备的显示屏可以是液晶显示屏或者电子墨水显示屏,该计算机设备的输入装置可以是显示屏上覆盖的触摸层,也可以是计算机设备外壳上设置的按键、轨迹球或触控板,还可以是外接的键盘、触控板或鼠标等。
在一个实施例中,图10是根据本申请实施例的电子设备的内部结构示意图,如图10所示,提供了一种电子设备,该电子设备可以是服务器,其内部结构图可以如图10所示。该电子设备包括通过内部总线连接的处理器、网络接口、内存储器和非易失性存储器,其中,该非易失性存储器存储有操作***、计算机程序和数据库。处理器用于提供计算和控制能力,网络接口用于与外部的终端通过网络连接通信,内存储器用于为操作***和计算机程序的运行提供环境,计算机程序被处理器执行时以实现一种分布式WebSocket接入方法,数据库用于存储数据。
本领域技术人员可以理解,图10中示出的结构,仅仅是与本申请方案相关的部分结构的框图,并不构成对本申请方案所应用于其上的电子设备的限定,具体的电子设备可以包括比图中所示更多或更少的部件,或者组合某些部件,或者具有不同的部件布置。
本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成,该计算机程序可存储于一非易失性计算机可读取存储介质中,该计算机程序在执行时,可包括如上述各方法的实施例的流程。其中,本申请所提供的各实施例中所使用的对存储器、存储、数据库或其它介质的任何引用,均可包括非易失性和/或易失性存储器。非易失性存储器可包括只读存储器(ROM)、可编程ROM(PROM)、电可编程ROM(EPROM)、电可擦除可编程ROM(EEPROM)或闪存。易失性存储器可包括随机存取存储器(RAM)或者外部高速缓冲存储器。作为说明而非局限,RAM以多种形式可得,诸如静态RAM(SRAM)、动态RAM(DRAM)、同步DRAM(SDRAM)、双数据率SDRAM(DDRSDRAM)、增强型SDRAM(ESDRAM)、同步链路(Synchlink) DRAM(SLDRAM)、存储器总线(Rambus)直接RAM(RDRAM)、直接存储器总线动态RAM(DRDRAM)、以及存储器总线动态RAM(RDRAM)等。
以上实施例仅表达了本申请的几种实施方式,其描述较为具体和详细,但并不能因此而理解为对发明专利范围的限制。应当指出的是,对于本领域的普通技术人员来说,在不脱离本申请构思的前提下,还可以做出若干变形和改进,这些都属于本申请的保护范围。因此,本申请专利的保护范围应以所附权利要求为准。

Claims (9)

1.一种分布式WebSocket接入***,其特征在于,所述***包括:代理接入器和消息服务器,其中;
所述代理接入器用于,分别与所述消息服务器和客户端进行双向通信,其中,***中分布式部署多个代理接入器,且每个代理接入器连接多个客户端;
所述消息服务器用于,分别与所述代理接入器和业务服务器进行双向通信,其中,各个代理接入器,分别通过各自的一条WebSocket连接通道,与所述消息服务器连接,
所述WebSocket连接通道基于WebSocket Tunnel协议建立,所述WebSocket Tunnel协议中,通过特定封装结构,将代理接入器转发的多个客户端数据,集合在一条WebSocket连接通道上进行传输,
所述特定封装结构中,将多个客户端发送的消息数据进行聚合,并重新定义所述消息数据的消息体结构,其中,各个消息体结构的文件头添加有消息类型和客户ID,所述消息类型用于指示该消息数据将被执行何种处理,所述客户ID为用户的身份识别ID。
2.根据权利要求1所述的***,其特征在于,所述消息服务器中维护有客户端列表,所述客户端列表中包括多组客户端信息记录,所述客户端信息记录包括:互相匹配的客户ID、客户端地址和代理接入器ID。
3.根据权利要求2所述的***,其特征在于,在向所述客户端推送消息数据的情况下:
所述业务服务器用于,向所述消息服务器发送消息数据,其中,所述消息数据中包括客户ID和消息内容;
所述消息服务器用于,根据所述客户ID在所述客户端列表中查找,确定所述消息数据对应的代理接入器ID,以及,
将所述消息数据以所述WebSocket Tunnel协议的特定封装结构处理后,根据所述代理接入器ID,通过所述WebSocket连接通道,将其转发对应的代理接入器;
所述代理接入器用于,根据所述消息数据中的消息类型,判断所述消息数据的处理方式,并根据所述客户ID确定对应的客户端地址,以及根据所述客户端地址,将所述消息数据转发至对应的客户端。
4.根据权利要求1所述的***,其特征在于,所述WebSocket Tunnel协议中传输的消息数据是WebSocket消息,所述WebSocket Tunnel协议中消息数据为JSON格式。
5.根据权利要求4所述的***,其特征在于,所述消息服务器还用于:
在接收到所述代理接入器转发的消息数据之后,将所述消息数据由WebSocket协议格式转换成HTTP协议格式,
并将所述HTTP协议格式的消息数据转发至所述业务服务器。
6.根据权利要求1所述的***,其特征在于,所述***还包括自定义部署模块,所述自定义部署模块用于,根据业务需求,自定义部署所述消息服务器和所述代理接入器,包括:
根据业务服务器的不同业务事项,针对性部署每个业务服务器的专用消息服务器;
根据资源配置需求,将所述消息服务器部署在不同的机房或云平台;
根据运营商线路,部署所述代理接入器和配置所述代理接入器的数量,以及,在多个所述消息服务器之间,共用所述代理接入器。
7.一种分布式WebSocket接入方法,其特征在于,所述方法包括:
代理接入器,分别与消息服务器和客户端进行双向通信,其中,***中分布式部署多个代理接入器,且每个代理接入器连接多个客户端;
消息服务器,分别与所述代理接入器和业务服务器进行双向通信,其中,各个代理接入器,分别通过各自的一条WebSocket连接通道,与所述消息服务器连接,其中,
所述WebSocket连接通道基于WebSocket Tunnel协议建立,所述WebSocket Tunnel协议中,通过特定封装结构,将所述代理接入器转发的多个客户端数据,集合在一条WebSocket连接通道上进行传输,
所述特定封装结构中,将多个客户端发送的消息数据进行聚合,并重新定义所述消息数据的消息体结构,其中,各个消息体结构的文件头添加有消息类型和客户ID,所述消息类型用于指示该消息数据将被执行何种处理,所述客户ID为用户的身份识别ID。
8.一种计算机设备,包括存储器、处理器以及存储在所述存储器上并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求7所述的方法。
9.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求7所述的方法。
CN202210884320.2A 2022-07-26 2022-07-26 一种分布式WebSocket接入***及方法 Active CN114979240B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202210884320.2A CN114979240B (zh) 2022-07-26 2022-07-26 一种分布式WebSocket接入***及方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202210884320.2A CN114979240B (zh) 2022-07-26 2022-07-26 一种分布式WebSocket接入***及方法

Publications (2)

Publication Number Publication Date
CN114979240A CN114979240A (zh) 2022-08-30
CN114979240B true CN114979240B (zh) 2022-10-25

Family

ID=82970207

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202210884320.2A Active CN114979240B (zh) 2022-07-26 2022-07-26 一种分布式WebSocket接入***及方法

Country Status (1)

Country Link
CN (1) CN114979240B (zh)

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2014207305A1 (en) * 2013-06-24 2014-12-31 Cassidian Finland Oy Mobile device management using websocket
US10003674B1 (en) * 2017-07-07 2018-06-19 Tmaxsoft.Co., Ltd. Method for supporting websocket and web server and web application server using the same
CN113204730A (zh) * 2021-05-19 2021-08-03 网宿科技股份有限公司 资源获取方法、webvpn代理服务器、***及服务器
CN114363204A (zh) * 2021-12-09 2022-04-15 网宿科技股份有限公司 请求监控方法、网络设备及存储介质

Family Cites Families (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2012063282A1 (ja) * 2010-11-10 2012-05-18 株式会社日立製作所 マッシュアップ・アプリケーションの動作方法およびシステム
US9350763B1 (en) * 2012-04-17 2016-05-24 Amazon Technologies, Inc. HTTP tunnelling over websockets
US9747388B2 (en) * 2012-08-31 2017-08-29 Salesforce.Com, Inc. Systems and methods for providing access to external content objects
CN103685363A (zh) * 2012-09-07 2014-03-26 中国科学院计算机网络信息中心 一种高效可靠的多任务处理方法及***
CN103458034B (zh) * 2013-09-04 2017-10-10 国云科技股份有限公司 一种通过web页面访问spice协议远程桌面的方法
US20170149915A1 (en) * 2015-11-25 2017-05-25 Sap Se System and method of feed data transmission
CN107342934A (zh) * 2017-06-19 2017-11-10 浪潮金融信息技术有限公司 一种基于WebSocket的混合模式移动应用实时消息推送方法及***
CN108600204A (zh) * 2018-04-11 2018-09-28 浙江大学 一种基于反向连接和应用层隧道的企业内网访问方法
CN109660617A (zh) * 2018-12-18 2019-04-19 中电科华云信息技术有限公司 一种基于服务器集群的消息推送方法
CN109922053A (zh) * 2019-02-22 2019-06-21 北京三快在线科技有限公司 数据传输方法、装置、电子设备及可读存储介质
CN112202872A (zh) * 2020-09-28 2021-01-08 华云数据控股集团有限公司 一种数据转发方法、api网关及消息服务***

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2014207305A1 (en) * 2013-06-24 2014-12-31 Cassidian Finland Oy Mobile device management using websocket
US10003674B1 (en) * 2017-07-07 2018-06-19 Tmaxsoft.Co., Ltd. Method for supporting websocket and web server and web application server using the same
CN113204730A (zh) * 2021-05-19 2021-08-03 网宿科技股份有限公司 资源获取方法、webvpn代理服务器、***及服务器
CN114363204A (zh) * 2021-12-09 2022-04-15 网宿科技股份有限公司 请求监控方法、网络设备及存储介质

Also Published As

Publication number Publication date
CN114979240A (zh) 2022-08-30

Similar Documents

Publication Publication Date Title
US11522734B2 (en) Method for controlling a remote service access path and relevant device
CN107948324B (zh) 请求传输***、方法、装置及存储介质
CN108200165B (zh) 请求传输***、方法、装置及存储介质
CN113596191B (zh) 一种数据处理方法、网元设备以及可读存储介质
WO2020057469A1 (zh) 数据处理方法、相关设备及计算机存储介质
CN112104754A (zh) 网络代理方法、***、装置、设备及存储介质
CN108200158B (zh) 请求传输***、方法、装置及存储介质
US20060209830A1 (en) Packet processing system including control device and packet forwarding device
CN111327668B (zh) 网络管理方法、装置、设备和存储介质
CN113242293A (zh) 一种upf设备、数据处理、扩容方法及装置
CN110012118B (zh) 一种提供网络地址转换nat服务的方法及控制器
CN112398845B (zh) 数据传输方法、数据传输装置、***及电子设备
CN112583655B (zh) 数据传输方法、装置、电子设备及可读存储介质
CN113037737A (zh) 一种用于各类用户终端设备的外置网卡技术
JP2024514643A (ja) パケット転送方法、装置、およびシステム、並びにコンピュータ可読記憶媒体
CN112968965B (zh) Nfv网络节点的元数据服务方法、服务器及存储介质
CN112333690B (zh) 数据传输方法、装置、存储介质、终端及网络接入点设备
CN116800616B (zh) 虚拟化网络设备的管理方法及相关装置
CN114979240B (zh) 一种分布式WebSocket接入***及方法
CN107094175A (zh) 一种实现网间互通的服务器部署结构及互通方法
CN114025010B (zh) 建立连接的方法和网络设备
KR101251630B1 (ko) 푸쉬 서비스 제공 시스템 및 방법
CN111818147B (zh) 一种实现openstack swift服务自动负载均衡的***及方法
CN108848156B (zh) 接入网关处理方法、装置及存储介质
CN111083182B (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