阿里云Kubernetes SpringCloud 实践进行时(2): 分布式配置管理

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
容器镜像服务 ACR,镜像仓库100个 不限时长
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
简介: 讲述了在阿里云Kubernetes容器服务基础之上,如何快速搭建基于Spring Cloud的微服务架构中的基础设施之分布式配置管理系统Spring Cloud Config。

简介

为了更好地支撑日益增长的庞大业务量,我们常常需要把服务进行整合、拆分,使我们的服务不仅能通过集群部署抵挡流量的冲击,又能根据业务在其上进行灵活的扩展。随着分布式的普及、服务的快速增长与云计算技术的进步,微服务架构也因其特有的优势而备受关注。微服务架构的本质,是把整体的业务拆分成很多有特定明确功能的服务,通过很多分散的小服务之间的配合,去解决更大,更复杂的问题。对被拆分后的服务进行分类和管理,彼此之间使用统一的接口来进行交互。

而随着服务数量的剧增,这些服务所依赖的配置文件则需要实现统一管理并且能够实时更新;否则对于分布式环境中多达上千、上百的服务实例来说,单单修改配置这项目工作就会耗费程序员很多时间和精力,甚至更为糟糕的是可能会带来配置不一致、错误的灾难。

本系列讲述了在阿里云Kubernetes容器服务基础之上,如何快速搭建基于Spring Cloud的微服务架构中的基础设施:

本文是系列中的第二篇,着重介绍分布式配置管理系统Spring Cloud Config。

Spring Cloud Config

为了应对分布式系统带来的这些复杂配置管理问题,Spring Cloud Config从以下几个角度提供必要的功能:

  • 集中管理的需求:一个使用微服务架构的应用系统可能会包括成百上千个微服务,因此集中管理很有必要;
  • 不同环境不同配置:例如数据源在不同的环境(开发,测试,生产)是不同的;
  • 运行期间可以动态调整。例如根据各个微服务的负载状况,动态调整数据源连接池大小或者熔断阀值,并且调整时不停止微服务;
  • 配置修改后可以自动更新;

针对分布式系统的外部配置,Spring Cloud Config主要提供了服务器端和客户端的支持,包括Config Server和Config Client两部分。由于Config Server和Config Client都实现了对Spring Environment和PropertySource抽象的映射,因此Spring Cloud Config很适合基于Spring Boot的应用程序。

  • Config Server: 是一个看横向扩展的,集中式的配置服务器,它用于集中管理应用程序各个环境下配置,默认使用Git存储配置内容。
  • Config Client: 是一个Config Server的客户端,用于操作存储在Config Server上的配置属性,所有微服务都指向Config Server,启动的时候会请求它获取所需要的配置属性,然后缓存这些属性以提高性能。

刷新配置机制

尽管使用/refresh 端点手动刷新配置,但是如果所有微服务节点的配置都需要手动去刷新的话,那必然是一个繁琐的工作,并且随着系统的不断扩张,会变得越来越难以维护。因此,实现配置的自动刷新是很有必要的,Spring Cloud Bus实现配置的自动刷新机制是一旦接收到RefreshEvent,就会启动ContextRefresher.refresh。

Spring Cloud Bus提供了批量刷新配置的机制,它使用轻量级的消息代理(例如RabbitMQ、Kafka等)连接分布式系统的节点,这样就可以通过Spring Cloud Bus广播配置的变化或者其他的管理指令。

图片.png

下面讲述一下在阿里云Kubernetes容器服务基础之上,如何快速搭建一套分布式配置管理系统。

准备Kubernetes环境

阿里云容器服务Kubernetes 1.9.3目前已经上线,可以通过容器服务管理控制台非常方便地快速创建 Kubernetes 集群。具体过程可以参考创建Kubernetes集群

体验通过服务目录简便部署RabbitMQ

搭建RabbitMQ

以RabbitMQ为例,点击左侧的服务目录,在右侧选中rabbitmq-broker

图片.png

点击参数, 可以通过修改参数配置进行定制化,例如指定服务名称等。此处注意一点的是,为了后面Config Client端能远程访问RabbitMQ,服务网络类型指定为LoadBalancer。修改之后,在右侧点击创建按钮。

图片.png

几分钟之后,一个RabbitMQ代理就可以安装完毕。

注册RabbitMQ代理

安装完成之后,首先需要通过kubectl命令注册RabbitMQ代理。

建立一个名为rabbitmq-broker.yaml的文件,内容如下:

apiVersion: servicecatalog.k8s.io/v1beta1
kind: ClusterServiceBroker
metadata:
  name: rabbitmq-broker
spec:
  url: http://aliacs-rabbitmq-broker-rabbitmq-broker.catalog.svc.cluster.local

执行kubectl create -f rabbitmq-broker.yaml,注册RabbitMQ代理。

其中:

  • name项可以根据需要进行修改;
  • url项为上述RabbitMQ代理的地址,格式为:{Kubernetes Service名称}.{Kubernetes 命名空间名称}.svc.cluster.local;
  • {Kubernetes 命名空间名称} 默认为catalog,也就是说从上述页面点击创建RabbitMQ代理对应的命名空间名称为catalog;
  • {Kubernetes Service名称}可以通过kubectl get svc -n catalog来获取;

图片.png

执行如下命令可以查看broker状态、service plan服务计划等,如下:

图片.png

创建RabbitMQ实例

服务目录中的RabbitMQ Broker提供了多种配置参数,来支持不同实例类型的创建。

建立一个名为rabbitmq-instance.yaml的文件,内容如下:

apiVersion: servicecatalog.k8s.io/v1beta1
kind: ServiceInstance
metadata:
  name: rabbitmq-instance
  namespace: catalog
spec:
  clusterServiceClassExternalName: rabbitmq-service
  clusterServicePlanExternalName: self-define
  Parameters: 
    PersistenceEnabled: false
    ServiceType: LoadBalancer

其中:

  • spec.clusterServicePlanExternalName指定为self-define,意味着可以进行定制化配置;
  • spec.Parameters.PersistenceEnabled指定为false,意味着不进行序列化存储;
  • spec.Parameters.ServiceType指定为LoadBalancer,意味着服务类型为LoadBalancer;

执行命令kubectl create -f rabbitmq-instance.yaml,创建实例。

创建集群角色

首先,建立一个名为rabbitmq-clusterrole.yaml的文件,内容如下:

kind: ClusterRole
apiVersion: rbac.authorization.k8s.io/v1
metadata:
  name: resources-holder-rabbitmq
rules:
- apiGroups: [""] # "" indicates the core API group
  resources: ["secrets","services","endpoints","nodes"]
  verbs: ["get", "watch", "list","create", "update", "patch", "delete"]

执行命令kubectl create -f rabbitmq-clusterrole.yaml,创建集群角色。

创建集群角色绑定

其次,建立一个名为rabbitmq-clusterrolebinding.yaml的文件,内容如下:

kind: ClusterRoleBinding
apiVersion: rbac.authorization.k8s.io/v1
metadata:
  name: read-resources-rabbitmq
subjects:
- kind: User
  name: system:serviceaccount:catalog:default
  apiGroup: rbac.authorization.k8s.io
roleRef:
  kind: ClusterRole
  name: resources-holder-rabbitmq
  apiGroup: rbac.authorization.k8s.io

执行命令kubectl create -f rabbitmq-clusterrolebinding.yaml,创建集群角色绑定。

创建服务绑定

其次,建立一个名为rabbitmq-binding.yaml的文件,内容如下:

apiVersion: servicecatalog.k8s.io/v1beta1
kind: ServiceBinding
metadata:
  name: rabbitmq-binding
  namespace: catalog
spec:
  instanceRef:
    name: rabbitmq-instance
  secretName: rabbitmq-instance-credentials

执行命令kubectl create -f rabbitmq-binding.yaml,创建服务绑定。

至此,RabbitMQ服务实例已经创建并且绑定信息可以从rabbitmq-instance-credentials中获取到。

$ kubectl get secret -n catalog
NAME                            TYPE                                  DATA      AGE
rabbitmq-instance-credentials      Opaque                                6         2m

点击左侧的服务,在右侧选中刚创建的RabbitMQ服务,可以查看到对应的Web地址,如下:

图片.png

体验通过应用目录简便部署Config Server

创建Spring Config Server

点击左侧的应用目录,在右侧选中ack-springcloud-configserver,如下:

图片.png

点击参数, 可以通过修改参数配置进行定制化,重点注意spring.cloud.config.server.git部分的配置信息。

  • 指定global.rabbitmq.host为访问上述创建的RabbitMQ服务的地址;
  • 指定global.rabbitmq.username为访问上述创建的RabbitMQ服务的访问用户;
  • 指定global.rabbitmq.password为访问上述创建的RabbitMQ服务的访问用户密码;
  • 指定spring.cloud.config.server.git.uri为存放配置属性文件的git仓库地址,如https://github.com/spring-cloud-samples/config-repo
  • 指定spring.cloud.config.server.git.searchPaths为配置仓库路径,以逗号隔开
  • 指定spring.cloud.config.label为配置仓库的分支
  • 指定spring.cloud.config.server.git.username为访问git仓库的用户名
  • 指定spring.cloud.config.server.git.password为访问git仓库的用户密码

修改之后,在右侧选择对应的集群、命名空间,指定发布名称,然后点击部署。

图片.png

几分钟之后,一个挂载了RabbitMQ的Spring Config Server实例就可以创建出来。

体验Spring Config Server

点击左侧的服务,在右侧点击刚创建的Spring Config Server服务提供的访问地址,

图片.png

如果访问http://{public-ip}:8888/foo/development,可以看到如下类似的内容,则证明Spring Config Server已正常启动。

图片.png

自动同步刷新

Spring Cloud Bus提供了批量刷新配置的机制,它使用轻量级的消息代理(例如RabbitMQ、Kafka等)连接分布式系统的节点,这样就可以通过Spring Cloud Bus广播配置的变化或者其他的管理指令。

一旦某个Config Server上 /refresh 被触发,则该Config Server会向Spring Cloud Bus(本例中使用了RabbitMQ)发布RefreshRemoteApplicationEvent事件。
与此同时,其他的Config Server和Config Client会接收到该事件进行刷新,执行如下逻辑:
图片.png

总结

我们可以利用阿里云Kubernetes容器服务,快速搭建一套分布式配置管理系统,应对分布式系统带来的这些复杂配置管理问题。欢迎大家使用阿里云上的容器服务,快速搭建一套基于Spring Cloud的分布式配置管理系统Config Server,比较简单地集成到自己项目的微服务开发中。

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
3月前
|
资源调度 Java 调度
Spring Cloud Alibaba 集成分布式定时任务调度功能
定时任务在企业应用中至关重要,常用于异步数据处理、自动化运维等场景。在单体应用中,利用Java的`java.util.Timer`或Spring的`@Scheduled`即可轻松实现。然而,进入微服务架构后,任务可能因多节点并发执行而重复。Spring Cloud Alibaba为此发布了Scheduling模块,提供轻量级、高可用的分布式定时任务解决方案,支持防重复执行、分片运行等功能,并可通过`spring-cloud-starter-alibaba-schedulerx`快速集成。用户可选择基于阿里云SchedulerX托管服务或采用本地开源方案(如ShedLock)
114 1
|
29天前
|
JSON SpringCloudAlibaba Java
Springcloud Alibaba + jdk17+nacos 项目实践
本文基于 `Springcloud Alibaba + JDK17 + Nacos2.x` 介绍了一个微服务项目的搭建过程,包括项目依赖、配置文件、开发实践中的新特性(如文本块、NPE增强、模式匹配)以及常见的问题和解决方案。通过本文,读者可以了解如何高效地搭建和开发微服务项目,并解决一些常见的开发难题。项目代码已上传至 Gitee,欢迎交流学习。
109 1
Springcloud Alibaba + jdk17+nacos 项目实践
|
10天前
|
分布式计算 Java 开发工具
阿里云MaxCompute-XGBoost on Spark 极限梯度提升算法的分布式训练与模型持久化oss的实现与代码浅析
本文介绍了XGBoost在MaxCompute+OSS架构下模型持久化遇到的问题及其解决方案。首先简要介绍了XGBoost的特点和应用场景,随后详细描述了客户在将XGBoost on Spark任务从HDFS迁移到OSS时遇到的异常情况。通过分析异常堆栈和源代码,发现使用的`nativeBooster.saveModel`方法不支持OSS路径,而使用`write.overwrite().save`方法则能成功保存模型。最后提供了完整的Scala代码示例、Maven配置和提交命令,帮助用户顺利迁移模型存储路径。
|
23天前
|
存储 边缘计算 城市大脑
阿里云入选Gartner®分布式混合基础设施魔力象限
Gartner正式发布了《分布式混合基础设施魔力象限》(Magic Quadrant™ for Distributed Hybrid Infrastructure),阿里云在入选的中国厂商中于执行能力(纵轴)和愿景完整性(横轴)上均处在最高、最远的位置。
|
24天前
|
人工智能 文字识别 Java
SpringCloud+Python 混合微服务,如何打造AI分布式业务应用的技术底层?
尼恩,一位拥有20年架构经验的老架构师,通过其深厚的架构功力,成功指导了一位9年经验的网易工程师转型为大模型架构师,薪资逆涨50%,年薪近80W。尼恩的指导不仅帮助这位工程师在一年内成为大模型架构师,还让他管理起了10人团队,产品成功应用于多家大中型企业。尼恩因此决定编写《LLM大模型学习圣经》系列,帮助更多人掌握大模型架构,实现职业跃迁。该系列包括《从0到1吃透Transformer技术底座》、《从0到1精通RAG架构》等,旨在系统化、体系化地讲解大模型技术,助力读者实现“offer直提”。此外,尼恩还分享了多个技术圣经,如《NIO圣经》、《Docker圣经》等,帮助读者深入理解核心技术。
SpringCloud+Python 混合微服务,如何打造AI分布式业务应用的技术底层?
|
2月前
|
运维 Kubernetes 调度
阿里云容器服务 ACK One 分布式云容器企业落地实践
3年前的云栖大会,我们发布分布式云容器平台ACK One,随着3年的发展,很高兴看到ACK One在混合云,分布式云领域帮助到越来越多的客户,今天给大家汇报下ACK One 3年来的发展演进,以及如何帮助客户解决分布式领域多云多集群管理的挑战。
阿里云容器服务 ACK One 分布式云容器企业落地实践
|
2月前
|
存储 NoSQL Redis
SpringCloud基础7——Redis分布式缓存,RDB,AOF持久化+主从+哨兵+分片集群
Redis持久化、RDB和AOF方案、Redis主从集群、哨兵、分片集群、散列插槽、自动手动故障转移
SpringCloud基础7——Redis分布式缓存,RDB,AOF持久化+主从+哨兵+分片集群
|
2月前
|
SQL NoSQL 数据库
SpringCloud基础6——分布式事务,Seata
分布式事务、ACID原则、CAP定理、Seata、Seata的四种分布式方案:XA、AT、TCC、SAGA模式
SpringCloud基础6——分布式事务,Seata
|
25天前
|
存储 边缘计算 城市大脑
阿里云入选Gartner®分布式混合基础设施魔力象限
Gartner正式发布了《分布式混合基础设施魔力象限》(Magic Quadrant™ for Distributed Hybrid Infrastructure),全球共9家厂商入围,阿里云成功入选,位居利基者(Niche Players)象限。
|
2月前
|
消息中间件 Java 对象存储
数据一致性挑战:Spring Cloud与Netflix OSS下的分布式事务管理
数据一致性挑战:Spring Cloud与Netflix OSS下的分布式事务管理
50 2

相关产品

  • 容器服务Kubernetes版
  • 下一篇
    无影云桌面