CN114885024A - 应用实例的路由方法、装置、设备及介质 - Google Patents

应用实例的路由方法、装置、设备及介质 Download PDF

Info

Publication number
CN114885024A
CN114885024A CN202210470221.XA CN202210470221A CN114885024A CN 114885024 A CN114885024 A CN 114885024A CN 202210470221 A CN202210470221 A CN 202210470221A CN 114885024 A CN114885024 A CN 114885024A
Authority
CN
China
Prior art keywords
target
tenant
application instance
request
access address
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
Application number
CN202210470221.XA
Other languages
English (en)
Other versions
CN114885024B (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.)
Shanghai Envision Innovation Intelligent Technology Co Ltd
Envision Digital International Pte Ltd
Original Assignee
Shanghai Envision Innovation Intelligent Technology Co Ltd
Envision Digital International Pte 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 Envision Innovation Intelligent Technology Co Ltd, Envision Digital International Pte Ltd filed Critical Shanghai Envision Innovation Intelligent Technology Co Ltd
Priority to CN202210470221.XA priority Critical patent/CN114885024B/zh
Publication of CN114885024A publication Critical patent/CN114885024A/zh
Application granted granted Critical
Publication of CN114885024B publication Critical patent/CN114885024B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Abstract

本申请公开了一种应用实例的路由方法、装置、设备及介质,涉及计算机技术领域。该方法包括:接收目标租户的部署请求,部署请求用于请求为目标租户的调用方部署目标应用实例;基于部署请求确定目标应用实例对应的组件组合,组件组合用于提供目标应用实例的功能服务;根据组件组合完成目标应用实例的安装,并生成目标应用实例的访问地址;响应于接收到目标租户的调用方的调用请求,将访问地址返回至目标租户的调用方,目标租户的调用方通过调用访问地址运行目标应用实例。能够实现按需部署应用实例,降低应用实例的路由的局限性。

Description

应用实例的路由方法、装置、设备及介质
技术领域
本申请涉及计算机技术领域,特别涉及一种应用实例的路由方法、装置、设备及介质。
背景技术
多租户技术(Multi-tenancy Technology)是一种基于云技术的软件架构技术,即,云平台通过多租户技术将平台能力提供给外部租户,不同的租户通过网关可以实现租户隔离。
在相关技术中,每个租户在API(Application Programming Interface,应用程序编程接口)网关(Gateway)中对应有应用实例,每个应用实例对应有该租户独占的物理资源,能够为租户提供对应的功能服务。当调用方需要调用对应的功能服务时,API网关将调用方的请求根据租户ID路由至对应的应用实例中。
然而,以上述方式实现的应用实例的路由仅适用于租户均已部署了对应的物理实例场景,其方法对应的实现条件较为苛刻,存在较大的局限性。
发明内容
本申请实施例提供了一种应用实例的路由方法、装置、设备及介质,能够实现按需部署应用实例,降低应用实例的路由的局限性。所述技术方案如下:
一方面,提供了一种应用实例的路由方法,所述方法包括:
接收目标租户的部署请求,所述部署请求用于请求为所述目标租户的调用方部署目标应用实例;
基于所述部署请求确定所述目标应用实例对应的组件组合,所述组件组合用于提供所述目标应用实例的功能服务;
根据所述组件组合完成所述目标应用实例的安装,并生成所述目标应用实例的访问地址;
响应于接收到所述目标租户的调用方的调用请求,将所述访问地址返回至所述目标租户的调用方,所述目标租户的调用方通过调用所述访问地址运行所述目标应用实例。
另一方面,提供了一种应用实例的路由装置,所述装置包括:
接收模块,用于接收目标租户的部署请求,所述部署请求用于请求为所述目标租户的调用方部署目标应用实例;
确定模块,用于基于所述部署请求确定所述目标应用实例对应的组件组合,所述组件组合用于提供所述目标应用实例的功能服务;
部署模块,用于根据所述组件组合完成所述目标应用实例的安装,并生成所述目标应用实例的访问地址;
发送模块,用于响应于接收到所述目标租户的调用方的调用请求,将所述访问地址返回至所述目标租户的调用方,所述目标租户的调用方通过调用所述访问地址运行所述目标应用实例。
另一方面,提供了一种计算机设备,所述设备包括处理器和存储器,所述存储器中存储有至少一条指令、至少一段程序、代码集或指令集,所述至少一条指令、所述至少一段程序、所述代码集或指令集由所述处理器加载并执行以实现本申请实施例中任一所述的应用实例的路由方法。
另一方面,提供了一种计算机可读存储介质,所述计算机可读存储介质中存储有至少一条程序代码,所述程序代码由处理器加载并执行以实现本申请实施例中任一所述的终端设备的应用实例的路由方法。
另一方面,提供了一种计算机程序产品或计算机程序,该计算机程序产品或计算机程序包括计算机指令,该计算机指令存储在计算机可读存储介质中。计算机设备的处理器从计算机可读存储介质读取该计算机指令,处理器执行该计算机指令,使得该计算机设备执行上述实施例中任一所述的应用实例的路由方法。
本申请的提供的技术方案至少包括以下有益效果:
为实现按需部署的应用实例的路由过程,服务器在接收到目标租户的部署请求后,基于部署请求确定目标租户需求的目标应用实例对应的组件组合,根据组件组合完成目标应用实例的安装,并生成目标应用实例对应的访问地址,当接收到目标租户的调用方的调用请求时,将该访问地址提供至目标租户的调用方,目标租户的调用方即可通过调用该访问地址以实现云端运行目标实例。即,通过目标租户指示的部署请求来按需完成实例的部署,降低了租户物理资源的开销,降低应用实例的路由的局限性。
附图说明
为了更清楚地说明本申请实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本申请一个示例性实施例提供的实施环境示意图;
图2是本申请一个示例性实施例提供的应用实例的路由方法流程图;
图3是本申请另一个示例性实施例提供的应用实例的路由方法流程图;
图4是本申请一个示例性实施例提供的路由系统的架构图;
图5是本申请另一个示例性实施例提供的应用实例的路由方法流程图;
图6是本申请一个示例性实施例提供的应用实例的路由装置的结构框图;
图7是本申请另一个示例性实施例提供的应用实例的路由装置的结构框图;
图8是本申请一个示例性实施例提供的服务器的结构示意图。
具体实施方式
为使本申请的目的、技术方案和优点更加清楚,下面将结合附图对本申请实施方式作进一步地详细描述。
首先,对本申请实施例中涉及的名词进行简要介绍:
云计算(Cloud Computing)指IT(Internet Technology,互联网技术)基础设施的交付和使用模式,指通过网络以按需、易扩展的方式获得所需资源;广义云计算指服务的交付和使用模式,指通过网络以按需、易扩展的方式获得所需服务。这种服务可以是IT和软件、互联网相关,也可是其他服务。云计算是网格计算(Grid Computing)、分布式计算(Distributed Computing)、并行计算(Parallel Computing)、效用计算(UtilityComputing)、网络存储(Network Storage Technologies)、虚拟化(Virtualization)、负载均衡(Load Balance)等传统计算机和网络技术发展融合的产物。
随着互联网、实时数据流、连接设备多样化的发展,以及搜索服务、社会网络、移动商务和开放协作等需求的推动,云计算迅速发展起来。不同于以往的并行分布式计算,云计算的产生从理念上将推动整个互联网模式、企业管理模式发生革命性的变革。
软件即服务(Software-as-a-Service,SaaS)即通过网络提供软件服务,SaaS平台供应商将应用软件统一部署在自己的服务器上,客户可以根据工作实际需求,通过互联网向厂商定购所需的应用软件服务,按定购的服务多少和时间长短向厂商支付费用,并通过互联网获得SaaS平台供应商提供的服务。即第三方租户可以通过API网关获取SaaS平台内部的数据或者程序,其中,上述数据或程序通过Restful(Representational StateTransfer,表述性状态传递)API的方式提供至第三方租户,第三方租户能够将不同API服务整合至自己的应用中,以得到新的服务。
其次,对本申请实施例的实施环境进行说明。示意性的,请参考图1,该实施环境中包括终端110、服务器120和通信网络130,其中,终端110包括租户端111和调用方112。
终端110可以是手机、平板电脑、电子书阅读器、多媒体播放设备、可穿戴设备、膝上型便携计算机、台式计算机等电子设备。其中,终端110包括租户端111和调用方112,租户端111是向服务器120租用应用资源的一方,调用方112是使用应用资源的一方,调用方112从服务器120调用租户端111所租用的应用资源。示意性的,租户端111和调用方112可以是同一个终端设备,也可以是不同的终端设备,在此不进行限定。
服务器120是应用资源的提供方。示意性的,服务器120包括网关模块和资源模块,网关模块负责对接收到的请求进行鉴权工作和路由工作,资源模块用于根据租户端111的请求进行应用实例的安装,资源模块还用于向调用方112提供应用实例对应的功能服务。
值得注意的是,上述服务器120可以是独立的物理服务器,也可以是多个物理服务器构成的服务器集群或者分布式系统,还可以是提供云服务、云数据库、云计算、云函数、云存储、网络服务、云通信、中间件服务、域名服务、安全服务、内容分发网络(ContentDelivery Network,CDN)、以及大数据和人工智能平台等基础云计算服务的云服务器。
其中,云技术(Cloud Technology)是指在广域网或局域网内将硬件、软件、网络等系列资源统一起来,实现数据的计算、储存、处理和共享的一种托管技术。云技术基于云计算商业模式应用的网络技术、信息技术、整合技术、管理平台技术、应用技术等的总称,可以组成资源池,按需所用,灵活便利。云计算技术将变成重要支撑。技术网络系统的后台服务需要大量的计算、存储资源,如视频网站、图片类网站和更多的门户网站。伴随着互联网行业的高度发展和应用,将来每个物品都有可能存在自己的识别标志,都需要传输到后台系统进行逻辑处理,不同程度级别的数据将会分开处理,各类行业数据皆需要强大的系统后盾支撑,只能通过云计算来实现。
在本申请实施例中,服务器120接收来自租户端111的部署请求,对部署请求进行鉴权,当该部署请求合法时,根据部署请求确定目标租户所要部署的应用实例的组件组合,并根据组件组合进行应用实例的安装,生成对应的访问地址,服务器120将生成的访问地址返回至租户端111和/或调用方112,后续调用方112即可通过上述访问地址对服务器120中安装的应用实例进行访问并获取对应的功能服务。
示意性的,终端110和服务器120之间通过通信网络130连接。
请参考图2,其示出了本申请一个实施例示出的应用实例的路由方法,在本申请实施例中,以该方法应用于如图1所示的服务器中,所述方法包括:
步骤201,接收目标租户的部署请求。
目标租户是具备部署权限的租户。在一些实施例中,当前服务器对应有目标平台,目标平台是应用资源的供应商,目标租户是通过预设方式从目标平台获取部署权限,上述预设方式可以是购买方式,也可以是其他方式,在此不进行限定。
在一些实施例中,目标租户可以向服务器发送注册请求,以获取部署权限。服务器接收目标租户的注册请求,基于注册请求生成目标租户的租户标识,该租户标识用于唯一标识目标租户,租户标识被持久化存储。
在一些实施例中,服务器为租户提供有租户应用,即目标租户的终端中安装有租户应用,目标租户通过租户应用登录服务器为租户提供的目标系统,目标租户可以通过目标系统实现目标应用实例的部署。
示意性的,目标租户可以是物理租户,也可以是逻辑租户。当目标租户是物理租户时,服务器为目标租户提供的目标应用实例对应的物理资源为独占资源;当目标租户为逻辑租户时,目标租户的目标应用实例对应的物理资源为与其他租户是共享的,每个应用实例内部利用多线程、协程或者消息队列隔离的方式,实现不同租户之间的数据隔离。
部署请求用于请求为目标租户的调用方部署目标应用实例。示意性的,目标租户对应有调用方,该调用方可以是目标租户开发的应用程序、终端设备等。
在一些实施例中,目标应用实例与调用方之间存在关联关系,即,目标租户可以设置哪些调用方具备对目标应用实例进行调用的权限,以调用方为目标租户开发的应用程序为例,目标租户可以指示该部署请求所部署的目标应用实例可以被目标租户所对应的哪些应用程序调用。
示意性的,部署请求中携带有目标租户的租户标识,该租户标识用于唯一标识目标租户。当部署请求所请求部署的目标应用实例对应有指定调用方时,该部署请求中还包括调用方标识,该调用方标识用于唯一标识目标租户对应的调用方。
步骤202,基于部署请求确定目标应用实例对应的组件组合。
在一些实施例中,部署请求提供有目标应用实例的服务需求信息,该服务需求信息用于指示目标应用实例能够实现的功能服务。服务器在接收到部署请求后,对部署请求进行解析得到上述服务需求信息,并对服务需求信息进行分析,确定能够实现服务需求信息所指示的功能服务的至少一个组件组合。
示意性的,当根据服务需求信息确定出的组件组合数量大于等于2时,服务器可以根据预设条件对组件组合进行筛选。在一个示例中,上述预设条件可以是根据组件组合的组件数量来确定目标应用实例的目标组件组合,例如,根据服务需求信息确定出组件组合A、组件组合B和组件组合C,上述三种组件组合均能实现目标应用实例的功能服务,其中,组件组合A由5个组件组成,组件组合B由6个组件组成,组件组合C由6个组件组成,则优选组件组合A来实现服务需求信息指示的功能服务。
示意性的,服务器也可以将确定的多个组件组合返回至租户端,由租户对目标组件组合进行选择。
示意性的,服务器中包括多个功能组件,不同组件之间的组合能够实现不同的功能服务,服务器根据部署请求确定的组件组合用于提供目标应用实例的功能服务。
步骤203,根据组件组合完成目标应用实例的安装,并生成目标应用实例的访问地址。
在本申请实施例中,服务器根据确定的组件组合为租户端完成目标应用实例的安装。在一些实施例中,服务器在云端为目标租户完成组件组合的安装,得到目标应用实例。
服务器在完成目标应用实例的安装之后,对应生成目标应用实例的访问地址(URL),目标租户的调用方可以通过访问地址访问服务器中的目标应用实例。
示意性的,当目标租户为逻辑租户时,服务器还可以获取当前已安装的应用实例列表,响应于应用实例列表中包括目标应用实例,则直接获取目标应用实例的访问地址。响应于应用实例列表中不包括目标应用实例,获取目标应用实例对应的组件组合,根据组件组合完成目标应用实例的安装,并上述目标应用实例的访问地址,将目标应用实例添加至应用实例列表中。
在一些实施例中,服务器根据组件组合确定组件标识,将组件标识与租户标识进行关联存储,将访问地址与组件标识进行关联存储。在后续目标租户的调用方对目标应用实例进行访问时,通过上述关联存储的组件标识、租户标识以及访问地址来实现应用实例的路由查找。即,通过在安装时完成租户标识、组件标识和访问地址之间的动态部署,保证后续目标租户的调用方可以正确访问目标应用实例。
步骤204,响应于接收到目标租户的调用方的调用请求,将访问地址返回至目标租户的调用方。
目标租户的调用方通过调用访问地址运行目标应用实例。在一些实施例中,上述调用请求中包括目标租户的租户标识,服务器根据租户标识查询得到目标应用实例对应的访问地址,服务器向调用方发送该访问地址,后续调用方可通过该访问地址对服务器中目标应用实例进行访问,并获取目标应用实例所提供的功能服务。
示意性的,目标租户的调用方在接收到服务器返回的访问地址后,对该访问地址进行本地存储。
在一些实施例中,目标租户在向服务器发送注册请求完成租户注册之后,服务器会为目标租户部署默认应用实例,即,无论目标租户是否向服务器发送部署请求,服务器均会在目标租户注册后分配默认应用实例,该默认应用实例对应有预设访问地址。在一个示例中,服务器仅在租户未部署目标应用实例的情况下提供默认应用实例,即,响应于接收到注册请求,获取预设访问地址,预设访问地址用于向未部署目标应用实例的租户提供默认应用实例;将预设访问地址返回至目标租户的调用方。
综上所述,本申请实施例提供的应用实例的路由方法,为实现按需部署的应用实例的路由过程,服务器在接收到目标租户的部署请求后,基于部署请求确定目标租户需求的目标应用实例对应的组件组合,根据组件组合完成目标应用实例的安装,并生成目标应用实例对应的访问地址,当接收到目标租户的调用方的调用请求时,将该访问地址提供至目标租户的调用方,目标租户的调用方即可通过调用该访问地址以实现云端运行目标实例。即,通过目标租户指示的部署请求来按需完成实例的部署,降低了租户物理资源的开销,降低应用实例的路由的局限性。
请参考图3,其示出了本申请一个实施例示出的应用实例的路由方法,在本申请实施例中,对调用方对目标应用实例进行调用和访问进行说明,所述方法包括:
步骤301,响应于接收到目标租户的调用方的调用请求,将访问地址返回至目标租户的调用方。
目标租户的调用方通过调用访问地址运行目标应用实例。在一些实施例中,上述调用请求中包括目标租户的租户标识,服务器根据租户标识查询得到目标应用实例对应的访问地址,服务器向调用方发送该访问地址,后续调用方可通过该访问地址对服务器中目标应用实例进行访问,并获取目标应用实例所提供的功能服务。
示意性的,目标租户的调用方在接收到服务器返回的访问地址后,对该访问地址进行本地存储。
步骤302,根据租户标识生成目标授权凭证。
目标授权凭证(token)用于标识目标租户的调用方的请求,目标租户的调用方在后续对目标应用实例的访问过程中所使用到的请求均包含该目标授权凭证,服务器根据该目标授权凭证来进行请求鉴权。
步骤303,将目标授权凭证下发至目标租户的调用方。
目标租户的调用方在接收到服务器发送的目标授权凭证后,对该目标授权凭证进行本地存储。示意性的,目标租户的调用方将目标授权凭证和目标应用实例的访问地址进行对应存储。
步骤304,接收目标租户的调用方的访问请求。
访问请求中包括目标授权凭证和访问地址。示意性的,目标租户的调用方确定访问操作对应的访问地址,根据该访问地址读取对应存储的目标授权凭证,根据访问地址、目标授权凭证以及服务需求生成访问请求,其中,该服务需求用于指示当前访问请求所指示的目标应用实例所需要提供的服务。
步骤305,基于目标授权凭证确定租户标识。
示意性的,服务器在接收到访问请求后,对访问请求进行解析,得到目标授权凭证,根据目标凭证确定当前调用方的目标租户的租户标识。
步骤306,对访问地址进行解析,得到组件标识。
示意性的,服务器解析访问请求中的访问地址获取目标应用实例对应的组件标识。该组件标识是服务器在目标租户对目标应用实例进行部署时,为根据目标租户的部署请求确定的组件组合设置的标识。服务器中对应存储有组角标识与租户标识的对应关系以及访问地址与组件标识之间的对应关系。
在一个示例中,服务器根据访问请求中的访问地址,获取访问地址和组件标识之间的第一映射表,从第一映射表中获取访问地址对应的组件标识。
步骤307,基于租户标识和组件标识确定目标租户的应用安装情况。
在一些实施例中,服务器获取用于存储租户标识与组件标识之间映射关系的第二映射表,从第二映射表中确定目标租户的调用方是否具备访问当前访问地址指示的目标应用实例的权限,即确定调用方的目标租户是否安装有上述目标应用实例。若第二映射表中存在上述目标租户的租户标识与通过访问地址解析得到的组件标识的对应关系,则说明服务器中已安装目标租户的目标应用实例,若不存在上述对应关系,则说明服务器中未安装目标租户的目标应用实例。
步骤308,基于应用安装情况为目标租户的调用方提供应用服务。
在一些实施例中,响应于应用安装情况指示目标租户已安装目标应用实例,则将访问请求路由至访问地址对应的服务模块;响应于应用安装情况指示目标租户未安装目标应用实例,则将访问请求路由至安装服务模块,安装服务模块用于提供目标租户完成目标应用实例的安装服务。即,若服务器确定当前调用方具备对目标应用实例的访问权限,则将目标租户的调用方的访问请求路由至访问地址对应的服务模块,若服务器确定当前调用方不具备对目标应用实例的访问权限,则调用方会跳转至默认页面,目标租户可以通过该默认页面的提示内容完成对该访问地址对应的目标应用实例的安装过程。
示意性的,当调用方不具备对目标应用实例的访问权限时,服务器也可以根据访问请求确定出的租户标识读取目标租户具备访问权限的已安装应用实例,将上述已安装应用实例对应的访问地址返回至调用方,提示调用方对这些地址进行访问。当调用方即不具备对目标应用实例的访问权限,服务器也无法查询到目标租户对应的已安装应用实例时,服务器可以向调用方返回预设访问地址,即默认应用实例对应的访问地址。
综上所述,本申请实施例提供的应用实例的路由方法,为实现按需部署的应用实例的路由过程,服务器在接收到目标租户的部署请求后,基于部署请求确定目标租户需求的目标应用实例对应的组件组合,根据组件组合完成目标应用实例的安装,并生成目标应用实例对应的访问地址,当接收到目标租户的调用方的调用请求时,将该访问地址提供至目标租户的调用方,目标租户的调用方即可通过调用该访问地址以实现云端运行目标实例。即,通过目标租户指示的部署请求来按需完成实例的部署,降低了租户物理资源的开销,降低应用实例的路由的局限性。
本申请实施例提供的应用实例的路由方法,服务器根据接收到的目标租户的调用方的访问请求,来确定目标租户是否已安装调用方所请求的目标应用实例,若已安装,则服务器为目标租户的调用方提供对应的应用服务,若未安装,则服务器会返回默认页面,目标租户可以通过该默认页面的提示内容完成对该访问地址对应的目标应用实例的安装过程。即在应用实例的访问过程中,路由查找的过程考虑到未部署应用实例的情况。
请参考图4,其示出了本申请一个例示性出的路由系统400的架构图,该路由系统中包括IAM(Identity and Access Management,身份识别与访问管理)模块410、应用实例模块420、安装服务模块430、网关模块440、重定向模块450。
IAM模块410用于存储租户相关的信息。在租户的注册阶段,IAM模块410为目标租户生成租户标识,该租户标识用于唯一标识目标租户,并对该租户标识持久化存储。
应用实例模块420为服务器中为租户提供应用实例的模块,应用实例模块420中包括现阶段服务器中已安装的所有应用实例,单个应用实例可以是被单个租户占有的,也可以是被多个租户共享的,在此不进行限定。
安装服务模块430中包括服务器为租户提供的组件,目标租户可以通过安装服务模块430提供的组件按需进行组合,得到目标应用实例,安装服务模块430可以根据接收到的目标租户的部署请求,将部署请求对应的组件组合进行安装,完成安装的目标应用实例被设置于应用实例模块420中。
网关模块440用于对接收到的请求进行鉴权,并对请求进行路由,该请求包括但不限于注册请求、部署请求、调用请求、访问请求等请求中的至少一种。网关模块440通过访问IAM模块410来获取租户信息。
示意性的,网关模块440接收到目标租户的部署请求,对该部署请求进行鉴权操作,响应于部署请求合法,网关模块440将该部署请求路由至安装服务模块430。在一个示例中,网关模块440对部署请求进行解析,得到目标租户的租户标识,网关模块440从IAM模块410中获取租户列表,若租户列表中包括该租户标识,则确定该部署请求合法。在一个示例中,安装服务模块430在完成目标应用实例的安装之后,会将目标租户的租户标识、组件标识以及对应的访问地址注册至网关模块440中。
示意性的,网关模块440接收到目标租户的调用方的调用请求时,对该调用请求进行鉴权,响应于该调用请求合法,根据调用请求中包括的租户标识,将对应的目标应用实例的访问地址返回至目标租户的调用方。
示意性的,网关模块440接收到目标租户的注册请求时,对该注册请求进行鉴权,响应于注册请求合法,将该注册请求路由至IAM模块410,由IAM模块410根据注册请求为目标租户生成租户标识,并对租户标识持久化存储。
示意性的,网关模块440接收到目标租户的调用方的访问请求时,对该访问请求进行鉴权,响应于该访问请求合法,确定该访问请求对应的目标租户针对访问地址对应的应用安装情况。在一个示例中,网关模块440对访问请求进行解析,得到目标授权凭证,从IAM模块410中查询得到该目标授权凭证对应的租户标识,对访问请求对应的访问地址进行解析,访问地址对应的组件标识,根据租户标识与组件标识的对应关系确定目标租户的应用安装情况,若应用安装情况指示目标租户已安装目标应用实例,则网关模块440将该访问请求路由至应用实例模块420,若应用安装情况指示目标租户未安装目标应用实例,则网关模块440将该访问请求路由至重定向模块450,由重定向模块450将该访问请求转发至安装服务模块430。
请参考图5,其示出了本申请一个示例性实施例提供的应用实例的路由方法,在本申请实施例中,租户端和调用方为同一终端,以目标平台为社交平台为例进行说明。所述方法包括:
步骤501,部署端接收租户端中的目标租户发送的注册请求。
目标租户通过注册请求以获取部署权限。在本申请实施例中,部署端对应的目标平台为社交平台,即能够提供社交相关应用实例平台,租户端为目标平台对应的目标应用的用户,即,上述用户向目标平台对应的部署端发送注册请求,以注册对应的租户权限。
步骤502,部署端基于注册请求生成目标租户的租户标识。
部署端在接收到注册请求后,为目标租户生成租户标识,该租户标识用于唯一标识目标租户,租户标识被持久化存储。在本申请实施例中,租户标识为目标租户在社交平台中的账号标识。
步骤503,部署端接收租户端中的目标租户发送的部署请求。
该部署请求用于请求为目标租户部署目标应用实例。
在本申请实施例中,该社交平台提供的应用实例包括普通博客社交应用、微型博客社交应用、邮箱社交应用、群组社交应用等。在一些实施例中,每个应用实例对应有应用实例标识。
上述部署请求中包括目标租户需求的目标应用实例对应的应用实例标识。
步骤504,部署端基于部署请求确定目标应用实例对应的组件组合。
在本申请实施例中,每个应用实例对应有完成应用实例所需要的组件组合。示意性的,应用实例标识与组件标识之间以映射表形式存储。部署端根据目标应用实例的应用实例标识,从上述映射表中读取到对应的至少一个组件标识。
步骤505,部署端根据组件组合完成目标应用实例的安装,并生成目标应用实例的访问地址。
部署端根据确定的组件标识在应用实例模块完成目标应用实例的安装。在一个示例中,目标租户发送的部署请求指示为目标租户部署邮箱社交应用,邮箱社交应用对应的组件组合包括组件A、组件C、组件M,部署端根据映射表确定出邮箱社交应用对应的组件标识后,为上述邮箱社交应用创建对应的访问地址,将组件A、组件C、组件M的组件标识与租户标识进行关联存储,将访问地址与组件标识进行关联存储。
步骤506,部署端将目标应用实例的访问地址发送至租户端。
在一些实施例中,响应于接收到目标租户的调用请求,则将访问地址返回至目标租户的终端。
终端将该访问地址进行存储。在一个示例中,终端将目标应用中的目标控件与上述访问地址建立链接关系,例如,目标应用中显示有邮箱图标控件,终端将该邮箱图标控件和访问地址建立链接关系。
步骤507,部署端接收租户端的访问请求。
上述访问请求中包括目标授权凭证和访问地址,其中,目标授权凭证用于表示目标租户的调用方的请求。
在本申请实施例中,目标授权凭证包括目标租户在目标应用的账号和密码。
在一个示例中,终端中的目标应用上的邮箱图标控件接收到点击操作时,终端获取当前目标应用登录的账号和密码,以及邮箱图标控件对应的访问地址,将账号、密码以及访问地址携带在访问请求中,将访问请求发送至部署端对应的服务器中。
步骤508,部署端对访问请求进行解析,确定目标应用实例的应用安装情况。
部署端在接收到访问请求后,根据账号、密码以及访问地址进行鉴权,当确定该请求合法之后,根据访问地址得到组件标识,根据账号、密码确定租户标识。根据租户标识和组件标识在租户标识和组件标识的映射表中的情况,确定目标租户是否安装有此时请求的目标应用实例。
步骤509,响应于应用安装情况指示目标租户已安装目标应用实例,部署端将访问请求路由至访问地址对应的服务模块。
当确定目标租户已安装目标应用实例之后,即可将访问请求录制至目标应用实例对应的服务模块了。例如,当访问请求为访问目标租户的邮箱时,则服务模块获取目标租户当前的邮箱状态,并将邮箱状态返回至租户端的终端,终端根据该邮箱状态显示对应的邮箱界面,其中,上述邮箱状态包括邮箱中的邮件数量、未读邮件数量、已发送邮件数量等信息。
本申请实施例提供的应用实例的路由方法,服务器根据接收到的目标租户的调用方的访问请求,来确定目标租户是否已安装调用方所请求的目标应用实例,若已安装,则服务器为目标租户的调用方提供对应的应用服务,若未安装,则服务器会返回默认页面,目标租户可以通过该默认页面的提示内容完成对该访问地址对应的目标应用实例的安装过程。即在应用实例的访问过程中,路由查找的过程考虑到未部署应用实例的情况。
下述为本申请装置实施例,可以用于执行本申请方法实施例。对于本申请装置实施例中未披露的细节,请参照本申请方法实施例。
图6示出了本申请一个实施例提供的应用实例的路由装置的框图。该装置具有实现上述方法示例的功能,所述功能可以由硬件实现,也可以由硬件执行相应的软件实现。该装置可以包括:
接收模块610,用于接收目标租户的部署请求,所述部署请求用于请求为所述目标租户的调用方部署目标应用实例;
确定模块620,用于基于所述部署请求确定所述目标应用实例对应的组件组合,所述组件组合用于提供所述目标应用实例的功能服务;
部署模块630,用于根据所述组件组合完成所述目标应用实例的安装,并生成所述目标应用实例的访问地址;
发送模块640,用于响应于接收到所述目标租户的调用方的调用请求,将所述访问地址返回至所述目标租户的调用方,所述目标租户的调用方通过调用所述访问地址运行所述目标应用实例。
在一个可选的实施例中,所述接收模块610,还用于接收所述目标租户的注册请求;
如图7所示,所述装置还包括:
生成模块650,用于基于所述注册请求生成所述目标租户的租户标识,所述租户标识用于唯一标识所述目标租户,所述租户标识被持久化存储。
在一个可选的实施例中,所述装置还包括:
获取模块660,用于响应于接收到所述注册请求,获取预设访问地址,所述预设访问地址用于向未部署所述目标应用实例的租户提供默认应用实例;
所述发送模块640,还用于将所述预设访问地址返回至所述目标租户的调用方。
在一个可选的实施例中,所述确定模块620,还用于根据所述组件组合确定组件标识,所述组件标识用于唯一标识所述组件组合;
所述装置还包括:
存储模块670,用于将所述组件标识与所述租户标识进行关联存储;
所述存储模块670,还用于将所述访问地址与所述组件标识进行关联存储。
在一个可选的实施例中,所述生成模块650,还用于根据所述租户标识生成目标授权凭证,所述目标授权凭证用于标识所述目标租户的调用方的请求;
所述发送模块640,还用于将所述目标授权凭证发送至所述目标租户的调用方。
在一个可选的实施例中,所述接收模块610,还用于接收所述目标租户的调用方的访问请求,所述访问请求中包括所述目标授权凭证和所述访问地址;
所述确定模块620,还用于基于所述目标授权凭证确定所述租户标识;
所述确定模块620,还用于对所述访问地址进行解析,得到所述组件标识;
所述确定模块620,还用于基于所述租户标识和所述组件标识确定所述目标租户的应用安装情况。
所述装置还包括:
服务模块680,用于基于所述应用安装情况为所述目标租户的调用方提供应用服务。
综上所述,本申请实施例提供的应用实例的路由装置,为实现按需部署的应用实例的路由过程,服务器在接收到目标租户的部署请求后,基于部署请求确定目标租户需求的目标应用实例对应的组件组合,根据组件组合完成目标应用实例的安装,并生成目标应用实例对应的访问地址,当接收到目标租户的调用方的调用请求时,将该访问地址提供至目标租户的调用方,目标租户的调用方即可通过调用该访问地址以实现云端运行目标实例。即,通过目标租户指示的部署请求来按需完成实例的部署,降低了租户物理资源的开销,降低应用实例的路由的局限性。
需要说明的是:上述实施例提供的应用实例的路由装置仅以上述各功能模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能模块完成,即将设备的内部结构划分成不同的功能模块,以完成以上描述的全部或者部分功能。另外,上述实施例提供的应用实例的路由装置与应用实例的路由方法实施例属于同一构思,其具体实现过程详见方法实施例,这里不再赘述。
图8示出了本申请一个示例性实施例提供的服务器的结构示意图。具体来讲包括如下结构。
服务器800包括中央处理单元(Central Processing Unit,CPU)801、包括随机存取存储器(Random Access Memory,RAM)1002和只读存储器(Read Only Memory,ROM)803的系统存储器804,以及连接系统存储器804和中央处理单元801的系统总线805。服务器800还包括用于存储操作系统813、应用程序814和其他程序模块815的大容量存储设备806。
大容量存储设备806通过连接到系统总线805的大容量存储控制器(未示出)连接到中央处理单元801。大容量存储设备806及其相关联的计算机可读介质为服务器800提供非易失性存储。也就是说,大容量存储设备806可以包括诸如硬盘或者紧凑型光盘只读存储器(Compact Disc Read Only Memory,CD-ROM)驱动器之类的计算机可读介质(未示出)。
不失一般性,计算机可读介质可以包括计算机存储介质和通信介质。计算机存储介质包括以用于存储诸如计算机可读指令、数据结构、程序模块或其他数据等信息的任何方法或技术实现的易失性和非易失性、可移动和不可移动介质。计算机存储介质包括RAM、ROM、可擦除可编程只读存储器(Erasable Programmable Read Only Memory,EPROM)、带电可擦可编程只读存储器(Electrically Erasable Programmable Read Only Memory,EEPROM)、闪存或其他固态存储其技术,CD-ROM、数字通用光盘(Digital Versatile Disc,DVD)或其他光学存储、磁带盒、磁带、磁盘存储或其他磁性存储设备。当然,本领域技术人员可知计算机存储介质不局限于上述几种。上述的系统存储器804和大容量存储设备806可以统称为存储器。
根据本申请的各种实施例,服务器800还可以通过诸如因特网等网络连接到网络上的远程计算机运行。也即服务器800可以通过连接在系统总线805上的网络接口单元811连接到网络812,或者说,也可以使用网络接口单元811来连接到其他类型的网络或远程计算机系统(未示出)。
上述存储器还包括一个或者一个以上的程序,一个或者一个以上程序存储于存储器中,被配置由CPU执行。
本申请的实施例还提供了一种计算机设备,该计算机设备包括处理器和存储器,该存储器中存储有至少一条指令、至少一段程序、代码集或指令集,至少一条指令、至少一段程序、代码集或指令集由处理器加载并执行以实现上述各方法实施例提供的目标对象预测方法。可选地,该计算机设备可以是终端,也可以是服务器。
本申请的实施例还提供了一种计算机可读存储介质,该计算机可读存储介质上存储有至少一条指令、至少一段程序、代码集或指令集,至少一条指令、至少一段程序、代码集或指令集由处理器加载并执行,以实现上述各方法实施例提供的目标对象预测方法。
本申请的实施例还提供了一种计算机程序产品或计算机程序,该计算机程序产品或计算机程序包括计算机指令,该计算机指令存储在计算机可读存储介质中。计算机设备的处理器从计算机可读存储介质读取该计算机指令,处理器执行该计算机指令,使得该计算机设备执行上述实施例中任一所述的目标对象预测方法。
可选地,该计算机可读存储介质可以包括:只读存储器(ROM,Read Only Memory)、随机存取记忆体(RAM,Random Access Memory)、固态硬盘(SSD,Solid State Drives)或光盘等。其中,随机存取记忆体可以包括电阻式随机存取记忆体(ReRAM,Resistance RandomAccess Memory)和动态随机存取存储器(DRAM,Dynamic Random Access Memory)。上述本申请实施例序号仅仅为了描述,不代表实施例的优劣。
本领域普通技术人员可以理解实现上述实施例的全部或部分步骤可以通过硬件来完成,也可以通过程序来指令相关的硬件完成,所述的程序可以存储于一种计算机可读存储介质中,上述提到的存储介质可以是只读存储器,磁盘或光盘等。
以上所述仅为本申请的可选实施例,并不用以限制本申请,凡在本申请的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本申请的保护范围之内。

Claims (10)

1.一种应用实例的路由方法,其特征在于,所述方法包括:
接收目标租户的部署请求,所述部署请求用于请求为所述目标租户的调用方部署目标应用实例;
基于所述部署请求确定所述目标应用实例对应的组件组合,所述组件组合用于提供所述目标应用实例的功能服务;
根据所述组件组合完成所述目标应用实例的安装,并生成所述目标应用实例的访问地址;
响应于接收到所述目标租户的调用方的调用请求,将所述访问地址返回至所述目标租户的调用方,所述目标租户的调用方通过调用所述访问地址运行所述目标应用实例。
2.根据权利要求1所述的方法,其特征在于,所述接收目标租户的部署请求之前,还包括:
接收所述目标租户的注册请求;
基于所述注册请求生成所述目标租户的租户标识,所述租户标识用于唯一标识所述目标租户,所述租户标识被持久化存储。
3.根据权利要求2所述的方法,其特征在于,所述方法还包括:
响应于接收到所述注册请求,获取预设访问地址,所述预设访问地址用于向未部署所述目标应用实例的租户提供默认应用实例;
将所述预设访问地址返回至所述目标租户的调用方。
4.根据权利要求2所述的方法,其特征在于,所述根据所述组件组合完成所述目标应用实例的安装,并生成所述目标应用实例的访问地址之后,还包括:
根据所述组件组合确定组件标识,所述组件标识用于唯一标识所述组件组合;
将所述组件标识与所述租户标识进行关联存储;
将所述访问地址与所述组件标识进行关联存储。
5.根据权利要求2至4任一所述的方法,其特征在于,所述方法还包括:
根据所述租户标识生成目标授权凭证,所述目标授权凭证用于标识所述目标租户的调用方的请求;
将所述目标授权凭证发送至所述目标租户的调用方。
6.根据权利要求5所述的方法,其特征在于,所述响应于接收到所述目标租户的调用方的调用请求,将所述访问地址返回至所述目标租户的调用方之后,还包括:
接收所述目标租户的调用方的访问请求,所述访问请求中包括所述目标授权凭证和所述访问地址;
基于所述目标授权凭证确定所述租户标识;
对所述访问地址进行解析,得到所述组件标识;
基于所述租户标识和所述组件标识确定所述目标租户的应用安装情况;
基于所述应用安装情况为所述目标租户的调用方提供应用服务。
7.根据权利要求6所述的方法,其特征在于,所述基于所述应用安装情况为所述目标租户的调用方提供应用服务,包括:
响应于所述应用安装情况指示所述目标租户已安装所述目标应用实例,则将所述访问请求路由至所述访问地址对应的服务模块;
响应于所述应用安装情况指示所述目标租户未安装所述目标应用实例,则将所述访问请求路由至安装服务模块,所述安装服务模块用于提供所述目标租户完成所述目标应用实例的安装服务。
8.一种应用实例的路由装置,其特征在于,所述装置包括:
接收模块,用于接收目标租户的部署请求,所述部署请求用于请求为所述目标租户的调用方部署目标应用实例;
确定模块,用于基于所述部署请求确定所述目标应用实例对应的组件组合,所述组件组合用于提供所述目标应用实例的功能服务;
部署模块,用于根据所述组件组合完成所述目标应用实例的安装,并生成所述目标应用实例的访问地址;
发送模块,用于响应于接收到所述目标租户的调用方的调用请求,将所述访问地址返回至所述目标租户的调用方,所述目标租户的调用方通过调用所述访问地址运行所述目标应用实例。
9.一种计算机设备,其特征在于,所述计算机设备包括处理器和存储器,所述存储器中存储有至少一条指令、至少一段程序、代码集或指令集,所述至少一条指令、所述至少一段程序、所述代码集或指令集由所述处理器加载并执行以实现如权利要求1至7任一所述的应用实例的路由方法。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质中存储有至少一条程序代码,所述程序代码由处理器加载并执行以实现如权利要求1至7任一所述的应用实例的路由方法。
CN202210470221.XA 2022-04-28 2022-04-28 应用实例的路由方法、装置、设备及介质 Active CN114885024B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202210470221.XA CN114885024B (zh) 2022-04-28 2022-04-28 应用实例的路由方法、装置、设备及介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202210470221.XA CN114885024B (zh) 2022-04-28 2022-04-28 应用实例的路由方法、装置、设备及介质

Publications (2)

Publication Number Publication Date
CN114885024A true CN114885024A (zh) 2022-08-09
CN114885024B CN114885024B (zh) 2023-09-12

Family

ID=82673584

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202210470221.XA Active CN114885024B (zh) 2022-04-28 2022-04-28 应用实例的路由方法、装置、设备及介质

Country Status (1)

Country Link
CN (1) CN114885024B (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN116389561A (zh) * 2023-06-05 2023-07-04 北京孔皆数智科技有限公司 一种基于算力网络的应用部署方法、装置及系统

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20110213870A1 (en) * 2010-02-26 2011-09-01 International Business Machines Corporation Providing services to multiple tenants of an application
CN103036856A (zh) * 2011-10-09 2013-04-10 镇江金软计算机科技有限责任公司 基于saas应用的多租户系统实现
US20160241438A1 (en) * 2015-02-13 2016-08-18 Amazon Technologies, Inc. Configuration service for configuring instances
CN109032760A (zh) * 2018-08-01 2018-12-18 北京百度网讯科技有限公司 用于部署应用的方法和装置
US20190065177A1 (en) * 2017-08-24 2019-02-28 General Electric Company Cross application behavior customization
CN110709819A (zh) * 2017-10-27 2020-01-17 谷歌有限责任公司 管理多单租户SaaS服务
CN111641675A (zh) * 2020-04-28 2020-09-08 深圳壹账通智能科技有限公司 多租户访问服务实现方法、装置、设备及存储介质
CN111935110A (zh) * 2020-07-24 2020-11-13 北京金山云网络技术有限公司 一种对租户访问容器实例的权限的控制方法和装置

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20110213870A1 (en) * 2010-02-26 2011-09-01 International Business Machines Corporation Providing services to multiple tenants of an application
CN103036856A (zh) * 2011-10-09 2013-04-10 镇江金软计算机科技有限责任公司 基于saas应用的多租户系统实现
US20160241438A1 (en) * 2015-02-13 2016-08-18 Amazon Technologies, Inc. Configuration service for configuring instances
US20190065177A1 (en) * 2017-08-24 2019-02-28 General Electric Company Cross application behavior customization
CN110709819A (zh) * 2017-10-27 2020-01-17 谷歌有限责任公司 管理多单租户SaaS服务
CN109032760A (zh) * 2018-08-01 2018-12-18 北京百度网讯科技有限公司 用于部署应用的方法和装置
CN111641675A (zh) * 2020-04-28 2020-09-08 深圳壹账通智能科技有限公司 多租户访问服务实现方法、装置、设备及存储介质
CN111935110A (zh) * 2020-07-24 2020-11-13 北京金山云网络技术有限公司 一种对租户访问容器实例的权限的控制方法和装置

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
胡彦婷;杜江;: "云服务中的租户数据安全策略研究", no. 21 *

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN116389561A (zh) * 2023-06-05 2023-07-04 北京孔皆数智科技有限公司 一种基于算力网络的应用部署方法、装置及系统
CN116389561B (zh) * 2023-06-05 2023-08-08 北京孔皆数智科技有限公司 一种基于算力网络的应用部署方法、装置及系统

Also Published As

Publication number Publication date
CN114885024B (zh) 2023-09-12

Similar Documents

Publication Publication Date Title
US9614875B2 (en) Scaling a trusted computing model in a globally distributed cloud environment
US20210072966A1 (en) Method and system for service rolling-updating in a container orchestrator system
US11102196B2 (en) Authenticating API service invocations
US9628491B1 (en) Secure assertion attribute for a federated log in
US20190199687A1 (en) Dynamically opening ports for trusted application processes hosted in containers
US20120246740A1 (en) Strong rights management for computing application functionality
US10762193B2 (en) Dynamically generating and injecting trusted root certificates
US10021111B2 (en) Location based authentication of users to a virtual machine in a computer system
CN110289983B (zh) 负载均衡应用创建方法、装置、计算机设备及存储介质
US10542048B2 (en) Security compliance framework usage
CN104866976A (zh) 面向多租户的管理信息系统
US10547612B2 (en) System to resolve multiple identity crisis in indentity-as-a-service application environment
CN114281263B (zh) 容器集群管理系统的存储资源处理方法、系统和设备
CN108289080B (zh) 一种访问文件系统的方法、装置和系统
CN114885024B (zh) 应用实例的路由方法、装置、设备及介质
CN108881460B (zh) 一种云平台统一监控的实现方法和实现装置
CN113923023A (zh) 权限配置和数据处理的方法、装置、电子设备及介质
WO2023092316A1 (zh) 一种第三方服务登录方法、装置、终端设备及存储介质
CN115604103A (zh) 云计算系统的配置方法、装置、存储介质以及电子设备
CN114500221A (zh) 云系统、公有云的管控方法、设备及存储介质
CN112738181A (zh) 集群外部ip接入的方法、装置及服务器
CN115484149B (zh) 网络切换方法、网络切换装置、电子设备及存储介质
CN114745164B (zh) 一种业务处理方法、装置、电子设备及计算机可读介质
US20200089544A1 (en) Managing computer resources
CN117201133A (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