CN111988386A - 一种云管理平台实时消息推送方法、装置及计算机可读介质 - Google Patents

一种云管理平台实时消息推送方法、装置及计算机可读介质 Download PDF

Info

Publication number
CN111988386A
CN111988386A CN202010800227.XA CN202010800227A CN111988386A CN 111988386 A CN111988386 A CN 111988386A CN 202010800227 A CN202010800227 A CN 202010800227A CN 111988386 A CN111988386 A CN 111988386A
Authority
CN
China
Prior art keywords
message
cloud management
management platform
queue
real
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.)
Withdrawn
Application number
CN202010800227.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.)
Suzhou Inspur Intelligent Technology Co Ltd
Original Assignee
Suzhou Inspur Intelligent 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 Suzhou Inspur Intelligent Technology Co Ltd filed Critical Suzhou Inspur Intelligent Technology Co Ltd
Priority to CN202010800227.XA priority Critical patent/CN111988386A/zh
Publication of CN111988386A publication Critical patent/CN111988386A/zh
Withdrawn legal-status Critical Current

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/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/08Network architectures or network communication protocols for network security for authentication of entities
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/55Push-based network services

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Hardware Design (AREA)
  • Computer Security & Cryptography (AREA)
  • Computing Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Information Transfer Between Computers (AREA)

Abstract

本发明公开了一种云管理平台实时消息推送方法、装置及计算机可读介质,包括以下步骤:用户在登陆云管理平台时,平台为当前用户生成一个Session信息,包括ID、IP、角色;当需要发送消息时,根据发起该任务的Session获取SessionId,并将消息封装后发送给消息队列;当前端订阅程序监听到消息队列时,将后台异步任务中的消息主动推送到前端并在界面进行展示,实现后台消息向用户的实时推送。本发明在云管理平台安全要求的环境中,通过订阅发布机制,实现后台消息向用户的实时推送。

Description

一种云管理平台实时消息推送方法、装置及计算机可读介质
技术领域
本发明涉及消息推送技术领域,具体为一种云管理平台实时消息推送方法、装置及计算机可读介质。
背景技术
各种云平台(cloud platforms)的出现是该转变的最重要环节之一。顾名思义,这种平台允许开发者们或是将写好的程序放在"云"里运行,或是使用"云"里提供的服务,或二者皆是。至于这种平台的名称,现在我们可以听到不止一种称呼,比如按需平台(on-demand platform)、平台即服务(platform as a service,PaaS)等等。但无论称呼它什么,这种新的支持应用的方式有着巨大的潜力;应用平台(application platforms)是如何被使用的。开发团队在创建一个户内应用(on-premises application,即在机构内运行的应用)时,该应用所需的许多基础都已经事先存在了:操作系统为执行应用和访问存储等提供了基础支持;机构里的其他计算机提供了诸如远程存储之类的服务。倘若每创建一个户内应用都得首先构建所有这些基础的话,那么恐怕我们今天看到的应用会少很多。
在云管理平台中,通过Web界面实现云管理平台与管理员和租户的消息交互。这种交互包含两类,实时交互和异步交互。实时交互时云管平台将操作处理结果实时通过交互界面反馈给用户。异步交互时在用户操作下发到云管平台后,云管平台仅仅提示用户消息下发成功,而具体的执行信息是云管平台后台处理,而不能实时提示给用户。本文通过使用消息订阅发布机制,在避免WebSocket安全问题的前提下,实现将云管理平台异步操作过程中的信息实时发送给前端用户。
云管理平台基于容器化平台K8S进行运行维护,其特点是云管理平台内部各模块之间构建成为局域网络,并且外部无法直接访问云管理平台中的具体模块,而必须通过云管理平台的网关进行安全验证后转发到各个模块。虽然WebSocket实现了后台消息主动推送到前端,但是其技术实现需要暴露具体模块API以及端口,从而导致了API请求绕过网关直接与云管理平台业务模块进行交互的安全问题。
发明内容
本发明的目的在于提供一种云管理平台实时消息推送方法、装置及计算机可读介质,以解决上述背景技术中提出的问题。
为实现上述目的,本发明提供如下技术方案:一种云管理平台实时消息推送方法,包括以下步骤:
用户在登陆云管理平台时,平台为当前用户生成一个Session信息,包括ID、IP、角色;
当需要发送消息时,根据发起该任务的Session获取SessionId,并将消息封装后发送给消息队列;
当前端订阅程序监听到消息队列时,将后台异步任务中的消息主动推送到前端并在界面进行展示,实现后台消息向用户的实时推送。
优选的,其中,平台的前端使用SessionId订阅一个队列,并创建一个监听器来监听队列信息;平台中的缓存根据订阅的SessionId构建消息订阅发布队列。
优选的,其中,前端订阅程序向后端发送监听指令,监听当前SessionId订阅的队列是否有消息产生。
优选的,后台服务器判断系统是否有推送权限,若有推送权限,则安装缓存节点Redis,Redis暴露端口5678,并显示消息推送数量;若无推送权限,则不推送消息。
优选的,所述云管理平台检测到推送请求中包含延时推送请求,在确定开启消息延时推送功能时,根据接收到的来自用户的设置命令设置预设推送时间。
优选的,当用户在登陆云管理平台时,平台为当前用户生成一个Session信息,前端使用SessionId订阅一个队列,并创建一个监听器来监听队列信息。
优选的,发送消息格式为
{resourceId:xxxxx,resourceName:xxxx,taskId:task_id,taskName:xx xx,message{code:xxxx,zh_CH:xxxxx,en_US:xxxxx}},其中resourceId是任务当前产生消息的资源Id,resourceName是当前资源的名称,taskId是当前执行任务的Id,taskName当前执行任务的名称,message是推送到前端的消息信息,message中的code是信息的编码,zh_CN是信息的中文提示,en_US是信息的英文提示。
一种云管理平台实时消息推送装置,包括
生成模块,用于用户在登陆云管理平台时,平台为当前用户生成一个Session信息,包括ID、IP、角色;
发送模块,用于当需要发送消息时,根据发起该任务的Session获取SessionId,并将消息封装后发送给消息队列;
推送模块,用于当前端订阅程序监听到消息队列时,将后台异步任务中的消息主动推送到前端并在界面进行展示,实现后台消息向用户的实时推送。
一种计算机可读介质,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现上述的方法的步骤。
与现有技术相比,本发明的有益效果是:本发明在云管理平台安全要求的环境中,通过订阅发布机制,实现后台消息向用户的实时推送。后台将消息发布到订阅发布队列中,前端在监听到队列存在消息时,将消息推送到前端并在界面进行展示,实现了后台消息向用户的实时推送。同时,通过端口功能的限制,来确保暴露端口的安全性,从而在保证安全的前提下实现异步任务中信息的实时推送和展示,增加了前端与后端的互动性和信息同步的即时性。
附图说明
图1为本发明流程图;
图2为本发明实施例的业务流程图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
实施例:
如图1所示,本发明提供如下技术方案:一种云管理平台实时消息推送方法,包括以下步骤:
用户在登陆云管理平台时,平台为当前用户生成一个Session信息,包括ID、IP、角色;
当需要发送消息时,根据发起该任务的Session获取SessionId,并将消息封装后发送给消息队列;
当前端订阅程序监听到消息队列时,将后台异步任务中的消息主动推送到前端并在界面进行展示,实现后台消息向用户的实时推送。
本发明在云管理平台安全要求的环境中,通过订阅发布机制,实现后台消息向用户的实时推送。后台将消息发布到订阅发布队列中,前端在监听到队列存在消息时,将消息推送到前端并在界面进行展示,实现了后台消息向用户的实时推送。同时,通过端口功能的限制,来确保暴露端口的安全性,从而在保证安全的前提下实现异步任务中信息的实时推送和展示,增加了前端与后端的互动性和信息同步的即时性。
平台的前端使用SessionId订阅一个队列,并创建一个监听器来监听队列信息;平台中的缓存根据订阅的SessionId构建消息订阅发布队列。前端订阅程序向后端发送监听指令,监听当前SessionId订阅的队列是否有消息产生。
本发明中,后台服务器判断系统是否有推送权限,若有推送权限,则安装缓存节点Redis,Redis暴露端口5678,并显示消息推送数量;若无推送权限,则不推送消息。
本发明中,所述云管理平台检测到推送请求中包含延时推送请求,在确定开启消息延时推送功能时,根据接收到的来自用户的设置命令设置预设推送时间,推送时间可以设定为10s-20s,30s-40s,也可以分段推送,确保推送效率。
本发明中,当用户在登陆云管理平台时,平台为当前用户生成一个Session信息,前端使用SessionId订阅一个队列,并创建一个监听器来监听队列信息,采用监听器监听队列信息,确保接收信息的及时性,进一步提高消息实时推送效率。
本发明中,发送消息格式为
{resourceId:xxxxx,resourceName:xxxx,taskId:task_id,taskName:xxx x,message{code:xxxx,zh_CH:xxxxx,en_US:xxxxx}},其中resourceId是任务当前产生消息的资源Id,resourceName是当前资源的名称,taskId是当前执行任务的Id,taskName当前执行任务的名称,message是推送到前端的消息信息,message中的code是信息的编码,zh_CN是信息的中文提示,en_US是信息的英文提示。
如图2所示,首先前端安装Redis缓存节点(Redis),Redis暴露端口5678。用户在登陆云管理平台时,平台为当前用户生成一个Session信息{ID、IP、角色}等,前端使用SessionId订阅一个消息队列,并创建一个监听器来监听队列信息。
用户发起操作时,前端通过调用API,在后台构建异步任务。然后由监控器对消息队列进行实时监控。
在业务逻辑的异步任务中,当需要发送消息时,后端业务逻辑根据发起该任务的Session获取SessionId,并将消息封装后发送给消息队列;发送消息格式为{resourceId:xxxxx,resourceName:xxxx,taskId:task_id,taskName:xxxx,message{code:xxxx,zh_CH:xxxxx,en_US:xxxxx}}。其中resourceId是任务当前产生消息的资源Id,resourceName是当前资源的名称,taskId是当前执行任务的Id,taskName当前执行任务的名称,message是推送到前端的消息信息,message中的code是信息的编码,zh_CN是信息的中文提示,en_US是信息的英文提示。
前端订阅程序在获取到当前SessionId订阅的队列有消息产生式时,将消息从消息队列中取出,并且根据当前界面展示的语言参数确定将中文还是英文展示。展示信息包含任务名称、操作资源名称、信息编码、信息中文或英文提示。
使用SessionId进行订阅时,缓存根据订阅的SessionId构建一个全局唯一的消息订阅发布队列。每个消息队列之间数据是隔离的。使用SessionId作为消息队列是避免同一个用户在多个客户端登陆,或者一个客户端登陆多个用户而产生的信息混乱。另外,当Session失效后,消息队列会被删除。
通过订阅机制,平台面向前端暴露一个订阅端口,并且该端口只接受监控器的访问而拒绝其他的任何请求,以此来保证平台的安全性。
此外,本发明还公开了一种云管理平台实时消息推送装置,包括生成模块,用于用户在登陆云管理平台时,平台为当前用户生成一个Session信息,包括ID、IP、角色;
发送模块,用于当需要发送消息时,根据发起该任务的Session获取SessionId,并将消息封装后发送给消息队列;
推送模块,用于当前端订阅程序监听到消息队列时,将后台异步任务中的消息主动推送到前端并在界面进行展示,实现后台消息向用户的实时推送。
另外,本发明还公开一种计算机可读介质,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现上述任意一项所述的方法的步骤。
综上所述,本发明在云管理平台安全要求的环境中,通过订阅发布机制,实现后台消息向用户的实时推送。后台将消息发布到订阅发布队列中,前端在监听到队列存在消息时,将消息在屏幕右小角展示。
对于本领域技术人员而言,显然本发明不限于上述示范性实施例的细节,而且在不背离本发明的精神或基本特征的情况下,能够以其他的具体形式实现本发明。因此,无论从哪一点来看,均应将实施例看作是示范性的,而且是非限制性的,本发明的范围由所附权利要求而不是上述说明限定,因此旨在将落在权利要求的等同要件的含义和范围内的所有变化囊括在本发明内。不应将权利要求中的任何附图标记视为限制所涉及的权利要求。

Claims (9)

1.一种云管理平台实时消息推送方法,其特征在于:包括以下步骤:
用户在登陆云管理平台时,平台为当前用户生成一个Session信息,包括ID、IP、角色;
当需要发送消息时,根据发起该任务的Session获取SessionId,并将消息封装后发送给消息队列;
当前端订阅程序监听到消息队列时,将后台异步任务中的消息主动推送到前端并在界面进行展示,实现后台消息向用户的实时推送。
2.根据权利要求1所述的一种云管理平台实时消息推送方法,其特征在于:其中,平台的前端使用SessionId订阅一个队列,并创建一个监听器来监听队列信息;平台中的缓存根据订阅的SessionId构建消息订阅发布队列。
3.根据权利要求1所述的一种云管理平台实时消息推送方法,其特征在于:其中,前端订阅程序向后端发送监听指令,监听当前SessionId订阅的队列是否有消息产生。
4.根据权利要求1所述的一种云管理平台实时消息推送方法,其特征在于:后台服务器判断系统是否有推送权限,若有推送权限,则安装缓存节点Redis,Redis暴露端口5678,并显示消息推送数量;若无推送权限,则不推送消息。
5.根据权利要求1所述的一种云管理平台实时消息推送方法,其特征在于:所述云管理平台检测到推送请求中包含延时推送请求,在确定开启消息延时推送功能时,根据接收到的来自用户的设置命令设置预设推送时间。
6.根据权利要求1所述的一种云管理平台实时消息推送方法,其特征在于:当用户在登陆云管理平台时,平台为当前用户生成一个Session信息,前端使用SessionId订阅一个队列,并创建一个监听器来监听队列信息。
7.根据权利要求1所述的一种云管理平台实时消息推送方法,其特征在于:发送消息格式为{resourceId:xxxxx,resourceName:xxxx,taskId:task_id,taskName:xxxx,message{code:xxxx,zh_CH:xxxxx,en_US:xxxxx}},其中resourceId是任务当前产生消息的资源Id,resourceName是当前资源的名称,taskId是当前执行任务的Id,taskName当前执行任务的名称,message是推送到前端的消息信息,message中的code是信息的编码,zh_CN是信息的中文提示,en_US是信息的英文提示。
8.一种云管理平台实时消息推送装置,其特征在于:包括
生成模块,用于用户在登陆云管理平台时,平台为当前用户生成一个Session信息,包括ID、IP、角色;
发送模块,用于当需要发送消息时,根据发起该任务的Session获取SessionId,并将消息封装后发送给消息队列;
推送模块,用于当前端订阅程序监听到消息队列时,将后台异步任务中的消息主动推送到前端并在界面进行展示,实现后台消息向用户的实时推送。
9.一种计算机可读介质,其特征在于:所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现如权利要求1-7任意一项所述的方法的步骤。
CN202010800227.XA 2020-08-11 2020-08-11 一种云管理平台实时消息推送方法、装置及计算机可读介质 Withdrawn CN111988386A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202010800227.XA CN111988386A (zh) 2020-08-11 2020-08-11 一种云管理平台实时消息推送方法、装置及计算机可读介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202010800227.XA CN111988386A (zh) 2020-08-11 2020-08-11 一种云管理平台实时消息推送方法、装置及计算机可读介质

Publications (1)

Publication Number Publication Date
CN111988386A true CN111988386A (zh) 2020-11-24

Family

ID=73445924

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202010800227.XA Withdrawn CN111988386A (zh) 2020-08-11 2020-08-11 一种云管理平台实时消息推送方法、装置及计算机可读介质

Country Status (1)

Country Link
CN (1) CN111988386A (zh)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113360774A (zh) * 2021-07-08 2021-09-07 海尔数字科技(青岛)有限公司 一种消息推送方法、装置、服务器和存储介质
CN113382048A (zh) * 2021-05-28 2021-09-10 广东好太太智能家居有限公司 一种消息推送方法、系统、设备及存储介质
CN113590253A (zh) * 2021-10-08 2021-11-02 深圳市信润富联数字科技有限公司 基于服务器端的通信交互方法、设备及存储介质

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113382048A (zh) * 2021-05-28 2021-09-10 广东好太太智能家居有限公司 一种消息推送方法、系统、设备及存储介质
CN113360774A (zh) * 2021-07-08 2021-09-07 海尔数字科技(青岛)有限公司 一种消息推送方法、装置、服务器和存储介质
CN113590253A (zh) * 2021-10-08 2021-11-02 深圳市信润富联数字科技有限公司 基于服务器端的通信交互方法、设备及存储介质
CN113590253B (zh) * 2021-10-08 2022-02-15 深圳市信润富联数字科技有限公司 基于服务器端的通信交互方法、设备及存储介质

Similar Documents

Publication Publication Date Title
CN111988386A (zh) 一种云管理平台实时消息推送方法、装置及计算机可读介质
US10523612B2 (en) Message history display system and method
CN102255935B (zh) 云服务消费方法、云服务中介及云系统
CN107766509B (zh) 一种网页静态备份的方法和装置
CN104536890A (zh) 测试系统、方法和装置
TW202038581A (zh) 管理用戶端、設備監控系統及方法
CN111277432A (zh) 配置信息更新方法、装置、电子设备及存储介质
CN109151056B (zh) 基于Canal的消息推送方法和系统
WO2023087766A1 (zh) 双系统通信方法、装置、电子设备及计算机可读存储介质
CN110309231A (zh) 一种跨机房的数据同步方法及系统
CN112328362A (zh) 一种基于容器技术实现函数计算服务的方法
CN113703997A (zh) 集成多种消息代理的双向异步通信中间件系统及实现方法
CN105897884B (zh) 基于XMPP协议的Android手机推送平台
CN102420861A (zh) 服务器的消息监听方法、装置及系统
WO2016197851A1 (zh) 一种通知信息的管理方法和设备
CN116233209A (zh) 一种gpu云渲染服务远程管理调度方法
CN114301929B (zh) 云端剪贴板数据同步方法、装置、云服务器和系统
CN116032867A (zh) 会话处理方法、装置、电子设备及存储介质
Wang et al. HTML5 web worker transparent offloading method for web applications
CN113434384B (zh) 一种压力测试方法和装置
CN103532829A (zh) 一种基于xmpp协议的即时通信系统电子白板接入方法
CN107911642A (zh) 一种有线电视网络管理系统
CN112306791B (zh) 一种性能监控的方法和装置
CN106020985B (zh) 数据处理方法、装置及服务器
CN108471375B (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
WW01 Invention patent application withdrawn after publication

Application publication date: 20201124

WW01 Invention patent application withdrawn after publication