CN109639818B - 一种云环境下的服务发现方法、装置、服务器和存储介质 - Google Patents
一种云环境下的服务发现方法、装置、服务器和存储介质 Download PDFInfo
- Publication number
- CN109639818B CN109639818B CN201811615799.XA CN201811615799A CN109639818B CN 109639818 B CN109639818 B CN 109639818B CN 201811615799 A CN201811615799 A CN 201811615799A CN 109639818 B CN109639818 B CN 109639818B
- Authority
- CN
- China
- Prior art keywords
- service provider
- container
- node
- change information
- container node
- 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
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/50—Network services
- H04L67/51—Discovery or management thereof, e.g. service location protocol [SLP] or web services
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/08—Configuration management of networks or network elements
- H04L41/0803—Configuration setting
- H04L41/0813—Configuration setting characterised by the conditions triggering a change of settings
- H04L41/082—Configuration setting characterised by the conditions triggering a change of settings the condition being updates or upgrades of network functionality
-
- 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/34—Network arrangements or protocols for supporting network services or applications involving the movement of software or configuration parameters
-
- 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/50—Network services
- H04L67/56—Provisioning of proxy services
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Information Transfer Between Computers (AREA)
- Stored Programmes (AREA)
Abstract
本发明提供了一种云环境下的服务发现方法、装置、服务器和存储介质,该方法包括:监听容器编排工具,获取安装于云环境中所有宿主机的容器结点对应的变更信息,并确定变更的容器结点对应的服务提供方的标识;将所述变更信息和所述服务提供方的标识发送给注册中心,以指示所述注册中心根据所述变更信息和所述服务提供方的标识对所述服务提供方对应的结点信息进行更新。本发明不必在每个服务提供方所在的宿主机中安装代理,大大减少了注册中心的连接压力,而且更加易于维护,降低了运维复杂度。
Description
技术领域
本发明涉及数据处理技术领域,特别是涉及一种云环境下的服务发现方法、装置、服务器和存储介质。
背景技术
基于云的微服务架构已经成为当前企业尤其是互联网企业技术选型的重要参考。服务发现模块是微服务架构设计中不可不说的重要模块之一,当前的服务发现模块发现服务结点的方式主要有两种,一种是提供SDK(Software Development Kit,软件开发工具包),服务提供方调用SDK直连注册中心(如zookeeper、etcd或consul),给注册中心造成了较大的连接压力;另一种方式是在容器结点所在的宿主机上安装代理,由代理统一上报该机器上的所有容器结点的信息到注册中心。
在容器结点所在的宿主机上安装代理的方式中,有一些专为微服务提供服务发现的中间件,如开源软件Registrator,通过轮询部署环境或订阅事件去跟踪运行中的容器结点的变化,当新添加一个容器结点时就会到注册中心中注册这个容器结点,同时它也会将停止的容器结点从注册中心中注销掉。
但是,使用Registrator发现服务的方式需要为每一个宿主机安装Registrator服务的代理,一般一个云环境由很多宿主机构成,这样无形中就增加了部署、管理和监控组件的压力,为系统带来了比较大的运维复杂度。另外,随着服务规模的不断扩大,代理的数量会不断增加,对注册中心的连接压力也会不断增大。
发明内容
鉴于上述问题,提出了本发明实施例以便提供一种克服上述问题或者至少部分地解决上述问题的一种云环境下的服务发现方法、装置、服务器和存储介质。
依据本发明的第一方面,提供了一种云环境下的服务发现方法,包括:
监听容器编排工具,获取安装于云环境中所有宿主机的容器结点对应的变更信息,并确定变更的容器结点对应的服务提供方的标识;
将所述变更信息和所述服务提供方的标识发送给注册中心,以指示所述注册中心根据所述变更信息和所述服务提供方的标识对所述服务提供方对应的结点信息进行更新。
可选的,所述监听容器编排工具,获取安装于云环境中所有宿主机的容器结点对应的变更信息,并确定变更的容器结点对应的服务提供方的标识,包括:
获取所述容器编排工具监听到的云环境中所有宿主机的容器结点状态事件,并根据预设规则对所述容器结点状态事件进行过滤;
根据过滤得到的容器结点状态事件,确定容器结点的变更信息,并确定变更的容器结点对应的服务提供方的标识。
可选的,在将所述变更信息和所述服务提供方的标识发送给注册中心之后,还包括:
接收所述注册中心在对所述服务提供方对应的结点信息进行更新后发送来的所述变更信息和所述服务提供方的标识;
根据所述变更信息和所述服务提供方的标识,对内存中的结点信息列表进行更新。
可选的,还包括:
接收调用方的调用请求;
根据所述调用请求,确定所述调用方所调用的服务提供方;
根据负载均衡策略和所述结点信息列表,确定所述服务提供方中为所述调用方提供服务的容器结点,并将所述调用请求转发给该容器结点。
可选的,所述容器结点对应的变更信息包括增加容器结点或关闭容器结点。
可选的,还包括:
将所述变更信息和所述服务提供方的标识对应保存到数据库中。
依据本发明的第二方面,提供了一种云环境下的服务发现装置,包括:
服务发现代理模块,用于监听容器编排工具,获取安装于云环境中所有宿主机的容器结点对应的变更信息,并确定变更的容器结点对应的服务提供方的标识;
变更信息发送模块,用于将所述变更信息和所述服务提供方的标识发送给注册中心,以指示所述注册中心根据所述变更信息和所述服务提供方的标识对所述服务提供方对应的结点信息进行更新。
可选的,所述服务发现代理模块包括:
事件过滤单元,用于获取所述容器编排工具监听到的云环境中所有宿主机的容器结点状态事件,并根据预设规则对所述容器结点状态事件进行过滤;
事件处理单元,用于根据过滤得到的容器结点状态事件,确定容器结点的变更信息,并确定变更的容器结点对应的服务提供方的标识。
可选的,还包括:
配置更新模块,用于接收所述注册中心在对所述服务提供方对应的结点信息进行更新后发送来的所述变更信息和所述服务提供方的标识;
反向代理模块,用于根据所述变更信息和所述服务提供方的标识,对内存中的结点信息列表进行更新。
可选的,所述反向代理模块还用于:
接收调用方的调用请求;
根据所述调用请求,确定所述调用方所调用的服务提供方;
根据负载均衡策略和所述结点信息列表,确定所述服务提供方中为所述调用方提供服务的容器结点,并将所述调用请求转发给该容器结点。
可选的,所述容器结点对应的变更信息包括增加容器结点或关闭容器结点。
可选的,还包括:
变更信息保存模块,用于将所述变更信息和所述服务提供方的标识对应保存到数据库中。
本发明提供的云环境下的服务发现方法、装置、服务器和存储介质,通过监听容器编排工具,获取安装于云环境中所有宿主机的容器结点对应的变更信息并确定变更的容器结点对应的服务提供方的标识,将变更信息和服务提供方的标识发送给注册中心,从而不必在每个服务提供方所在的宿主机中安装代理,大大减少了注册中心的连接压力,而且更加易于维护,降低了运维复杂度。
上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的具体实施方式。
附图说明
通过阅读下文优选实施方式的详细描述,各种其他的优点和益处对于本领域普通技术人员将变得清楚明了。附图仅用于示出优选实施方式的目的,而并不认为是对本发明的限制。
图1是本发明实施例提供的一种云环境下的服务发现方法的步骤流程图;
图2是本发明实施例中的云环境下的服务发现系统的架构图;
图3是本发明实施例提供的一种云环境下的服务发现方法的步骤流程图;
图4是本发明实施例提供的一种云环境下的服务发现方法的步骤流程图;
图5是本发明实施例提供的一种云环境下的服务发现装置的结构框图;
图6为本发明实施例提供的一种服务器的结构框图。
具体实施方式
下面将参照附图更详细地描述本发明的示例性实施例。虽然附图中显示了本发明的示例性实施例,然而应当理解,可以以各种形式实现本发明而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本发明,并且能够将本发明的范围完整的传达给本领域的技术人员。
现有的服务发现方式中,提供SDK的方式,需要服务提供方调用SDK直连注册中心,从而一个服务提供方需要一个SDK,而一个宿主机上可能会有多个服务提供方,从而在一个宿主机上就会需要多个SDK,云环境中会存在多个提供服务的宿主机,从而会有大量的SDK,每个SDK都需要与注册中心通信进行容器结点的注册或注销,给注册中心造成了较大的连接压力。为了减少通过SDK的方式给注册中心造成的连接压力,可以使用在宿主机上安装代理的方式,由代理统一上报该机器上的所有容器结点的信息到注册中心,但是安装代理的方式需要将代理内置到部署环境中,一般一个云环境由很多宿主机构成,在每个宿主机中都需要安装代理,这样就增加了部署、管理和监控组件的压力,为系统带来了比较大的运维复杂度,而且随着服务规模的不断扩大,代理的数量会不断增加,对注册中心的连接压力也会不断增大。
为了解决上述问题,本发明实施例提供了如下方案。
图1是本发明实施例提供的一种云环境下的服务发现方法的步骤流程图,该方法可以应用于云环境中,可以由服务器执行,如图1所示,该方法可以包括:
步骤101,监听容器编排工具,获取安装于云环境中所有宿主机的容器结点对应的变更信息,并确定变更的容器结点对应的服务提供方的标识。
其中,容器编排工具可以由一个服务器组成,也可以由一个集群组成,负责调度云环境中的所有容器结点,其中包括创建和删除等操作。所述容器结点对应的变更信息可以至少包括:增加容器结点或关闭容器结点,还可以包括:变更的容器结点的结点信息。其中,容器结点的结点信息包括容器结点的标识。服务提供方的标识包括服务提供方的名称和IP地址等标识性信息。
本步骤可以由配置于服务器中的服务发现代理模块来执行。所述服务发现代理模块是服务发现的核心模块,实时感知云环境中所有服务提供方的结点变化并将变更信息及时的更新到注册中心。安装了服务发现代理模块的服务器与服务提供方所在的宿主机不同,位于单独的一个或多个宿主机中。
通过对容器编排工具进行监听,可以获取容器编排工具监听到云环境中的各个容器结点的状态事件,根据容器结点的状态事件,确定容器结点的变更信息,并确定变更的容器结点对应的服务提供方的标识。
图2是本发明实施例中的云环境下的服务发现系统的架构图,如图2所示,容器编排工具203可以监听所有的容器结点204,n表示容器结点的数量,容器结点是各个服务提供方的服务结点,容器结点可以扩充,服务发现代理模块201只需监听到容器编排工具203就可以获取到所有容器结点的变更信息,并发送给注册中心202,服务发现代理模块201独立于服务提供方所在的宿主机,从而注册中心不必与服务提供方进行交互,减少了服务提供方较多时对注册中心的连接压力。
其中,监听容器编排工具,获取安装于云环境中所有宿主机的容器结点对应的变更信息,并确定变更的容器结点对应的服务提供方的标识,可选包括:
获取所述容器编排工具监听到的云环境中所有宿主机的容器结点状态事件,并根据预设规则对所述容器结点状态事件进行过滤;
根据过滤得到的容器结点状态事件,确定容器结点的变更信息,并确定变更的容器结点对应的服务提供方的标识。
服务发现代理模块位于代理层,是实现服务监控和管理的模块,此模块会监听容器编排工具,并对容器编排工具上报的容器结点状态事件进行过滤。服务发现代理模块可以包括事件过滤单元和事件处理单元。事件过滤单元根据预设规则对容器结点状态事件进行过滤,在过滤得到需要的容器结点状态事件后将该容器结点状态事件传递给事件处理单元,事件处理单元对过滤得到的容器结点状态事件进行分析,确定容器结点对应的服务提供方,并将分析出的服务提供方的容器结点的变更信息同步到注册中心和数据库中。如果是新结点启动则捕获启动事件,并注册新启动的容器结点到注册中心。同时,实时感知停止或不健康的结点事件,并自动将相应的容器结点从注册中心中剔除。
事件过滤单元可以在众多的容器结点状态事件中及时地过滤出关键事件,关键事件是可以确定增加容器结点或者关闭容器结点的状态事件。比如:在容器结点启动时,事件过滤单元从容器编排工具中获取到一系列的容器结点状态事件,需要从这些容器结点状态事件中过滤出表示容器结点启动成功并可以对外提供服务的状态事件,作为关键事件,来保证将该容器结点对外暴露后该容器结点有能力处理调用请求;同样,在容器结点关闭时,事件过滤单元从容器编排工具中获取到一系列的容器结点状态事件,需要从这些容器结点状态事件中过滤出表示容器结点无法处理请求的状态事件,作为关键事件,从而可以及时禁止调用方请求对这个容器结点的访问来保证停止的容器结点不会影响正常的功能。事件处理单元接收到由事件过滤单元传递来的容器结点状态事件,将根据该容器结点状态事件确定的容器结点的变更信息实时更新到注册中心。
步骤102,将所述变更信息和所述服务提供方的标识发送给注册中心,以指示所述注册中心根据所述变更信息和所述服务提供方的标识对所述服务提供方对应的结点信息进行更新。
其中,注册中心负责存储服务与结点信息,所有开启服务发现开关的服务提供方以及服务提供方的可用结点信息都会存储到注册中心。
服务发现代理模块获取到容器结点的变更信息后,将该变更信息及变更的容器结点对应的服务提供方的标识发送给注册中心,由注册中心根据容器结点的变更信息对所述服务提供方对应的结点信息进行更新。
例如,变更信息为某一个服务提供方增加一个容器结点,则注册中心将该容器结点的结点信息注册到该服务提供方对应的结点信息中;变更信息为某一服务提供方关闭一个容器结点,则注册中心将该容器结点的结点信息从该服务提供方对应的结点信息中注销,即将该容器结点的结点信息从该服务提供方对应的结点信息中删除。
本发明实施例中,服务提供方和注册中心不进行直接交互,而是通过服务发现代理模块进行解耦,从而服务提供方可以不用直接与注册中心进行通信,所以即使服务提供方的数量不断增加也不会对注册中心带来连接上的压力。另外,也无需为服务提供方开发服务发现相关的SDK等组件,这样就可以避免在服务提供方多语言情况下多版本SDK的开发工作,以及极大的减少了后期升级维护的复杂度。同时,由于服务发现代理模块是直接与容器编排工具进行交互,也做到了整个服务暴露过程对服务提供方是无感知的,服务提供方不用做任何处理就可以达到容器结点对外暴露的目的。
本实施例提供的方法,通过监听容器编排工具,获取安装于云环境中所有宿主机的容器结点对应的变更信息并确定变更的容器结点对应的服务提供方的标识,将变更信息和服务提供方的标识发送给注册中心,从而不必在每个服务提供方所在的宿主机中安装代理,大大减少了注册中心的连接压力,而且更加易于维护,降低了运维复杂度。
在上述技术方案的基础上,还可选包括:
将所述变更信息和所述服务提供方的标识对应保存到数据库中。
将容器结点对应的变更信息和容器结点对应的服务提供方的标识保存到数据库中,可以为可视化管理平台提供信息以供展示,同时也可以为自动校验程序提供数据支持。
其中,可视化管理平台主要负责对发现的服务信息进行展示,同时向服务提供方开放手动增加和删除服务提供方对应的容器结点的功能,实现手动和自动相结合的模式,服务提供方可以根据自己的需求选择不同的使用模式。在服务提供方手动增加容器结点后,可以通过可视化管理平台在注册中心中注册,并对应保存到数据库中。将容器结点的变更信息和服务提供方的标识对应保存到数据库中,自动校验程序还可以获取数据库中的结点信息,并将从数据库中获取到的结点信息与注册中心中的结点信息进行对比来校验两者是否一致。
图3是本发明实施例提供的一种云环境下的服务发现方法的步骤流程图,本实施例在上述实施例的基础上,还进一步包括:接收所述注册中心在对所述服务提供方对应的结点信息进行更新后发送来的所述变更信息和所述服务提供方的标识;根据所述变更信息和所述服务提供方的标识,对内存中的结点信息列表进行更新。如图3所示,该方法具体可以包括:
步骤301,监听容器编排工具,获取安装于云环境中所有宿主机的容器结点对应的变更信息,并确定变更的容器结点对应的服务提供方的标识。
本步骤的具体内容与上述实施例中的步骤101的具体内容相同,这里不再赘述。
步骤302,将所述变更信息和所述服务提供方的标识发送给注册中心,以指示所述注册中心根据所述变更信息和所述服务提供方的标识对所述服务提供方对应的结点信息进行更新。
本步骤的具体内容与上述实施例中的步骤102的具体内容相同,这里不再赘述。
步骤303,接收所述注册中心在对所述服务提供方对应的结点信息进行更新后发送来的所述变更信息和所述服务提供方的标识。
本步骤可以由配置于服务器中的配置更新模块来执行。所述配置更新模块用于监听注册中心的事件,实时接收注册中心发送来的服务提供方的结点信息。
注册中心在根据容器结点的变更信息,对服务提供方对应的结点信息进行更新后,将容器结点的变更信息和所述服务提供方的标识发送给服务器,以便于服务器对内存中的结点信息列表进行更新,便于后续根据已在注册中心注册的容器结点来处理调用方的调用请求。
步骤304,根据所述变更信息和所述服务提供方的标识,对内存中的结点信息列表进行更新。
本步骤可以由配置于服务器中的反向代理模块来执行。其中,所述反向代理模块还具有负载均衡和请求转发的功能,当接收到调用方的调用请求时,此模块会根据它的内存配置中所配置的服务提供方的结点信息,通过负载均衡策略选择一个容器结点并将调用请求转发到该容器结点中。
反向代理模块接收到配置更新模块下发的容器结点的变更信息和变更的容器结点对应的服务提供方的标识后,对内存中的结点信息列表进行更新,即对结点信息列表中所述服务提供方对应的结点信息进行更新,从而后续接收到调用方的调用请求时,可以根据负载均衡策略从更新后的结点信息列表中确定为调用方提供服务的容器结点。例如,容器结点的变更信息为增加容器结点时,则在内存中的结点信息列表中的所述服务提供方的标识对应的位置增加所述容器结点;容器结点的变更信息为关闭容器结点时,则在内存中的结点信息列表中的所述服务提供方的标识对应的位置删除所述容器结点。
本实施例提供的方法,通过接收所述注册中心在对所述服务提供方对应的结点信息进行更新后发送来的所述变更信息和所述服务提供方的标识,并及时的根据所述变更信息和所述服务提供方的标识对内存中的结点信息列表进行更新,从可以及时的根据最新的结点信息列表确定为调用方提供服务的容器结点。
图4是本发明实施例提供的一种云环境下的服务发现方法的步骤流程图,如图4所示,该方法可以包括:
步骤401,监听容器编排工具,获取安装于云环境中所有宿主机的容器结点对应的变更信息,并确定变更的容器结点对应的服务提供方的标识。
本步骤的具体内容与上述实施例中的步骤101的具体内容相同,这里不再赘述。
步骤402,将所述变更信息和所述服务提供方的标识发送给注册中心,以指示所述注册中心根据所述变更信息和所述服务提供方的标识对所述服务提供方对应的结点信息进行更新。
本步骤的具体内容与上述实施例中的步骤102的具体内容相同,这里不再赘述。
步骤403,接收所述注册中心在对所述服务提供方对应的结点信息进行更新后发送来的所述变更信息和所述服务提供方的标识。
本步骤的具体内容与上述实施例中的步骤203的具体内容相同,这里不再赘述。
步骤404,根据所述变更信息和所述服务提供方的标识,对内存中的结点信息列表进行更新。
本步骤的具体内容与上述实施例中的步骤204的具体内容相同,这里不再赘述。
步骤405,接收调用方的调用请求。
在调用方发出调用请求后,可以通过反向代理模块统一接收调用方的调用请求。所述调用请求中包括调用方所调用的服务提供方的标识。
步骤406,根据所述调用请求,确定所述调用方所调用的服务提供方。
本步骤可以由配置于服务器中的反向代理模块来执行。其中,反向代理模块根据调用请求中调用方所调用的服务提供方的标识,确定调用方所调用的服务提供方。
步骤407,根据负载均衡策略和所述结点信息列表,确定所述服务提供方中为所述调用方提供服务的容器结点,并将所述调用请求转发给该容器结点。
本步骤可以由配置于服务器中的反向代理模块来执行。其中,反向代理模块根据内存中的结点信息列表,确定所述服务提供方对应的所有的容器结点,并根据负载均衡策略从这些容器结点中选择负载少的容器结点,作为为所述调用方提供服务的容器结点,并将所述调用请求转发给该容器结点,从而由该容器结点为所述调用方提供服务。
例如,容器结点的变更信息为增加容器结点时,服务发现代理模块实时地将增加容器结点的信息在注册中心中对应的服务提供方位置进行注册,注册中心在对增加的容器结点的信息在对应的服务提供方的位置进行注册后,将增加容器结点的信息和对应的服务提供方的标识发送给配置更新模块,从而配置更新模块将增加容器结点的信息更新到反向代理模块的内存中该服务提供方对应的结点信息列表中,如果此时接收到调用方对该服务提供方的调用请求,则根据负载均衡策略可以将调用请求转发到该新增的容器结点中。
本实施例提供的方法,通过接收所述注册中心在对所述服务提供方对应的结点信息进行更新后发送来的所述变更信息和所述服务提供方的标识,根据所述变更信息和所述服务提供方的标识,对内存中的结点信息列表进行更新,统一接收调用方的调用请求,并根据负载均衡策略确定为调用方提供服务的容器结点,将调用请求转发给该容器结点,从而可以实时的对变更后的容器结点进行调用。
需要说明的是,对于方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本发明实施例并不受所描述的动作顺序的限制,因为依据本发明实施例,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于优选实施例,所涉及的动作并不一定是本发明实施例所必须的。
图5是本发明实施例提供的一种云环境下的服务发现装置的结构框图,该云环境下的服务发现装置可以应用于云环境中,如图5所示,该云环境下的服务发现装置可以包括:
服务发现代理模块501,用于监听容器编排工具,获取安装于云环境中所有宿主机的容器结点对应的变更信息,并确定变更的容器结点对应的服务提供方的标识;
变更信息发送模块502,用于将所述变更信息和所述服务提供方的标识发送给注册中心,以指示所述注册中心根据所述变更信息和所述服务提供方的标识对所述服务提供方对应的结点信息进行更新。
可选的,所述服务发现代理模块包括:
事件过滤单元,用于获取所述容器编排工具监听到的云环境中所有宿主机的容器结点状态事件,并根据预设规则对所述容器结点状态事件进行过滤;
事件处理单元,用于根据过滤得到的容器结点状态事件,确定容器结点的变更信息,并确定变更的容器结点对应的服务提供方的标识。
可选的,还包括:
配置更新模块,用于接收所述注册中心在对所述服务提供方对应的结点信息进行更新后发送来的所述变更信息和所述服务提供方的标识;
反向代理模块,用于根据所述变更信息和所述服务提供方的标识,对内存中的结点信息列表进行更新。
可选的,所述反向代理模块还用于:
接收调用方的调用请求;
根据所述调用请求,确定所述调用方所调用的服务提供方;
根据负载均衡策略和所述结点信息列表,确定所述服务提供方中为所述调用方提供服务的容器结点,并将所述调用请求转发给该容器结点。
可选的,所述容器结点对应的变更信息包括增加容器结点或关闭容器结点。
可选的,还包括:
变更信息保存模块,用于将所述变更信息和所述服务提供方的标识对应保存到数据库中。可以为可视化管理平台提供信息以供展示,同时也可以为自动校验程序提供数据支持。
本实施例提供的云环境下的服务发现系统,通过服务发现代理模块监听容器编排工具,获取安装于云环境中所有宿主机的容器结点对应的变更信息,并确定变更的容器结点对应的服务提供方的标识,发送给注册中心,通过服务发现代理模块实现了将服务提供方与注册中心的解耦,从而只有服务发现代理模块与注册中心进行通信,大大减少了注册中心的连接压力,而且不必在每个服务提供方所在的宿主机中安装代理,只需一个独立于服务提供方所在宿主机的服务发现代理模块,从而更加易于维护,降低了运维复杂度。
图6为本发明实施例提供的一种服务器的结构框图。如图6所示,该服务器600可以包括一个或多个处理器601以及与处理器601连接的一个或多个存储器602。服务器600还可以包括输入接口603和输出接口604,用于与另一装置或系统进行通信。被处理器601的CPU执行的程序代码可存储在存储器602中。
服务器600中的处理器601调用存储在存储器602的程序代码,以执行上述实施例中的云环境下的服务发现方法。
处理器为上述服务器的控制中心,并提供处理装置,用于执行指令,进行中断操作,提供计时功能以及多种其他功能。处理器可为单核(单CPU)处理器或多核(多CPU)处理器。除非另有声明,描述为用于执行任务的例如处理器或存储器的部件可实现为通用部件,其暂时用于在给定时间执行任务,或实现为专门制造用于执行该任务的特定部件。此处所用的术语“处理器”指一个或多个装置,电路和/或处理核,用于处理数据,例如计算机程序指令。
上述服务器中的上述元件可通过总线彼此连接,总线例如数据总线、地址总线、控制总线、扩展总线和局部总线之一或其任意组合。
根据本发明的一个实施例,还提供了一种计算机可读存储介质,所述计算机可读存储介质上存储有计算机程序,存储介质可以是只读存储器(Read-Only Memory,ROM),或是可读写的,例如硬盘、闪存。所述计算机程序被处理器执行时实现前述实施例的云环境下的服务发现方法。
本说明书中的各个实施例均采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似的部分互相参见即可。
本领域内的技术人员应明白,本发明实施例的实施例可提供为方法、装置、或计算机程序产品。因此,本发明实施例可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明实施例可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本发明实施例是参照根据本发明实施例的方法、终端设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理终端设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理终端设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理终端设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理终端设备上,使得在计算机或其他可编程终端设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程终端设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
尽管已描述了本发明实施例的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例做出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本发明实施例范围的所有变更和修改。
最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者终端设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者终端设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者终端设备中还存在另外的相同要素。
以上对本发明所提供的一种云环境下的服务发现方法、装置、服务器和存储介质,进行了详细介绍,本文中应用了具体个例对本发明的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本发明的方法及其核心思想;同时,对于本领域的一般技术人员,依据本发明的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本发明的限制。
Claims (12)
1.一种云环境下的服务发现方法,其特征在于,包括:
监听容器编排工具,获取安装于云环境中所有宿主机的容器结点对应的变更信息,并确定变更的容器结点对应的服务提供方的标识,其中包括:获取所述容器编排工具监听到的云环境中所有宿主机的容器结点状态事件,并根据预设规则对所述容器结点状态事件进行过滤;根据过滤得到的容器结点状态事件,确定容器结点的变更信息,并确定变更的容器结点对应的服务提供方的标识;
将所述变更信息和所述服务提供方的标识发送给注册中心,以指示所述注册中心根据所述变更信息和所述服务提供方的标识对所述服务提供方对应的结点信息进行更新。
2.根据权利要求1所述的方法,其特征在于,在将所述变更信息和所述服务提供方的标识发送给注册中心之后,还包括:
接收所述注册中心在对所述服务提供方对应的结点信息进行更新后发送来的所述变更信息和所述服务提供方的标识;
根据所述变更信息和所述服务提供方的标识,对内存中的结点信息列表进行更新。
3.根据权利要求2所述的方法,其特征在于,还包括:
接收调用方的调用请求;
根据所述调用请求,确定所述调用方所调用的服务提供方;
根据负载均衡策略和所述结点信息列表,确定所述服务提供方中为所述调用方提供服务的容器结点,并将所述调用请求转发给该容器结点。
4.根据权利要求1所述的方法,其特征在于,所述容器结点对应的变更信息包括增加容器结点或关闭容器结点。
5.根据权利要求1所述的方法,其特征在于,还包括:
将所述变更信息和所述服务提供方的标识对应保存到数据库中。
6.一种云环境下的服务发现装置,其特征在于,包括:
服务发现代理模块,用于监听容器编排工具,获取安装于云环境中所有宿主机的容器结点对应的变更信息,并确定变更的容器结点对应的服务提供方的标识;所述服务发现代理模块包括:事件过滤单元,用于获取所述容器编排工具监听到的云环境中所有宿主机的容器结点状态事件,并根据预设规则对所述容器结点状态事件进行过滤;事件处理单元,用于根据过滤得到的容器结点状态事件,确定容器结点的变更信息,并确定变更的容器结点对应的服务提供方的标识;
变更信息发送模块,用于将所述变更信息和所述服务提供方的标识发送给注册中心,以指示所述注册中心根据所述变更信息和所述服务提供方的标识对所述服务提供方对应的结点信息进行更新。
7.根据权利要求6所述的装置,其特征在于,还包括:
配置更新模块,用于接收所述注册中心在对所述服务提供方对应的结点信息进行更新后发送来的所述变更信息和所述服务提供方的标识;
反向代理模块,用于根据所述变更信息和所述服务提供方的标识,对内存中的结点信息列表进行更新。
8.根据权利要求7所述的装置,其特征在于,所述反向代理模块还用于:
接收调用方的调用请求;
根据所述调用请求,确定所述调用方所调用的服务提供方;
根据负载均衡策略和所述结点信息列表,确定所述服务提供方中为所述调用方提供服务的容器结点,并将所述调用请求转发给该容器结点。
9.根据权利要求6所述的装置,其特征在于,所述容器结点对应的变更信息包括增加容器结点或关闭容器结点。
10.根据权利要求6所述的装置,其特征在于,还包括:
变更信息保存模块,用于将所述变更信息和所述服务提供方的标识对应保存到数据库中。
11.一种服务器,其特征在于,包括:处理器、存储器及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述计算机程序被所述处理器执行时实现如权利要求1-5任一项所述的云环境下的服务发现方法。
12.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现如权利要求1-5任一项所述的云环境下的服务发现方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201811615799.XA CN109639818B (zh) | 2018-12-27 | 2018-12-27 | 一种云环境下的服务发现方法、装置、服务器和存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201811615799.XA CN109639818B (zh) | 2018-12-27 | 2018-12-27 | 一种云环境下的服务发现方法、装置、服务器和存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN109639818A CN109639818A (zh) | 2019-04-16 |
CN109639818B true CN109639818B (zh) | 2020-09-08 |
Family
ID=66078429
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201811615799.XA Active CN109639818B (zh) | 2018-12-27 | 2018-12-27 | 一种云环境下的服务发现方法、装置、服务器和存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN109639818B (zh) |
Families Citing this family (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110275775B (zh) * | 2019-05-17 | 2023-09-01 | 平安科技(深圳)有限公司 | 容器应用的资源配置方法、系统及存储介质 |
CN112231612B (zh) * | 2019-07-15 | 2023-08-25 | 腾讯科技(深圳)有限公司 | 配置信息的传输方法及装置、存储介质、电子装置 |
CN110445861B (zh) * | 2019-08-07 | 2021-10-22 | 上海浦东发展银行股份有限公司信用卡中心 | 一种基于f5适配器的容器云平台服务注册发现方法 |
CN110708356B (zh) * | 2019-09-06 | 2024-01-05 | 国云科技股份有限公司 | 一种注册中心管理第三方应用的方法和系统 |
CN111309367B (zh) * | 2020-02-19 | 2023-07-14 | 北京字节跳动网络技术有限公司 | 一种管理服务发现的方法、装置、介质和电子设备 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106331065A (zh) * | 2016-08-15 | 2017-01-11 | 众安在线财产保险股份有限公司 | 一种用于具有服务容器的主机系统的代理应用以及系统 |
CN106385435A (zh) * | 2016-08-30 | 2017-02-08 | 乐视控股(北京)有限公司 | 一种业务系统的服务治理方法和系统 |
CN106775702A (zh) * | 2016-12-09 | 2017-05-31 | 中电科华云信息技术有限公司 | 基于容器的服务内部接口发现方法 |
CN108632299A (zh) * | 2017-03-15 | 2018-10-09 | 北京京东尚科信息技术有限公司 | 增强注册中心可用性的方法、装置、电子设备和存储介质 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP6394455B2 (ja) * | 2015-03-24 | 2018-09-26 | 富士通株式会社 | 情報処理システム、管理装置およびプログラム |
-
2018
- 2018-12-27 CN CN201811615799.XA patent/CN109639818B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106331065A (zh) * | 2016-08-15 | 2017-01-11 | 众安在线财产保险股份有限公司 | 一种用于具有服务容器的主机系统的代理应用以及系统 |
CN106385435A (zh) * | 2016-08-30 | 2017-02-08 | 乐视控股(北京)有限公司 | 一种业务系统的服务治理方法和系统 |
CN106775702A (zh) * | 2016-12-09 | 2017-05-31 | 中电科华云信息技术有限公司 | 基于容器的服务内部接口发现方法 |
CN108632299A (zh) * | 2017-03-15 | 2018-10-09 | 北京京东尚科信息技术有限公司 | 增强注册中心可用性的方法、装置、电子设备和存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN109639818A (zh) | 2019-04-16 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN109639818B (zh) | 一种云环境下的服务发现方法、装置、服务器和存储介质 | |
CN109547570B (zh) | 服务注册方法、装置、注册中心管理设备及存储介质 | |
US7958210B2 (en) | Update management method and update management unit | |
CN112003961B (zh) | 一种kubernetes中资源暴露方法、系统、设备以及介质 | |
EP2474910B1 (en) | Setting program, workflow creating method, and work flow creating apparatus | |
CN111369350B (zh) | 冲正交易处理方法及装置 | |
CN110096424B (zh) | 测试的处理方法、装置、电子设备及存储介质 | |
JP2003256225A (ja) | コンピュータシステム、障害対応方法及びコンピュータシステムを機能させるためのプログラム | |
CN108255708B (zh) | 测试环境中访问生产文件的方法、装置、存储介质及设备 | |
CN109445937B (zh) | 一种组件化编程及无缝执行方法 | |
CN109697078B (zh) | 非高可用性组件的修复方法、大数据集群和容器服务平台 | |
CN111277633A (zh) | 一种请求处理方法、服务器、电子设备及存储介质 | |
CN116257438A (zh) | 接口测试用例的更新方法及相关设备 | |
CN108664343B (zh) | 一种微服务的有状态调用方法及装置 | |
CN114637496A (zh) | 组态数据处理系统、方法及电子设备 | |
US20130204921A1 (en) | Diagnostics agents for managed computing solutions hosted in adaptive environments | |
CN116743762A (zh) | 服务注册集群流量切换方法、流量切换装置及存储介质 | |
CN107291575B (zh) | 一种数据中心故障时的处理方法和设备 | |
WO2016131294A1 (zh) | 版本升级处理方法及装置 | |
US20180241848A1 (en) | Human-readable cloud structures | |
CN106909410A (zh) | 一种用于服务器系统的更新方法以及服务器系统 | |
US20210067402A1 (en) | Disaster Recovery of Cloud Resources | |
CN114461424A (zh) | 单元化部署架构下的单元间服务发现方法、装置及系统 | |
US9992305B2 (en) | Cloud models based on network definition data | |
CN112181512A (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 |