ACM 无缝支持 Spring 全栈

简介: ACM 产品介绍 应用配置管理 ACM(Application ConfigurationManagement)前身为淘宝内部配置中心Diamond,是一款在分布式架构环境中对应用配置进行集中管理和推送的应用配置中心产品。

ACM 产品介绍

应用配置管理 ACM(Application Configuration
Management)前身为淘宝内部配置中心
Diamond,是一款在分布式架构环境中对应用配置进行“集中管理”和“动态推送”的配置中心产品。利用
ACM,您可以在微服务、DevOps、大数据等场景下极大减轻配置管理的工作量,并增强配置管理的服务能力。

核心功能

image

  • 统一管控:您可以在 ACM 的控制台统一管理所有应用的配置,而不再像传统配置那样,分散在各处。
  • 动态推送:当你在 ACM 控制台修改了配置, ACM 能够实时将修改后的配置推送到接入 ACM 服务的应用进程中。
  • 版本管理:ACM 控制台保留配置变更各个历史版本,当前你发现误修改配置后,能够快速得回滚,降低影响面。
  • 灰度发布:有一些配置是相对比较重要,一旦变更,可能会带来很大的影响。通过灰度发布功能,您可以让新配置在少数的几台机器上生效,待观察服务到达预期,并对业务没有负面的影响,之后,再将配置全量发布。
  • 推送轨迹:通过推送轨迹,您可以查到到那些 IP 在什么时间点来拿过配置。当您发布配置后,想看看有哪些机器已经来获取最新配置了,就可以通过它来查看。

ACM 应用场景

场景 1:微服务应用架构下的配置管理

在微服务架构下,随着应用和机器数目的增多,配置(如
DB_URL 访问信息、服务连接池、服务内部缓存大小等)管理的工作会变得很繁琐。单个应用下多个机器的配置分发,应用对应用的配置依赖,都将成为挑战。在传统架构的应用发布过程中,修改一个应用配置就需要将整个应用重新打包发布,整个过程非常繁琐,且容易出错。

image

在基于 ACM 的微服务场景下,应用的重要配置信息被发布到 ACM 中。新的配置发布并不依赖配置打包。在新版本的配置发布后,所有应用立即生效。

image

在微服务应用架构下使用 ACM 带来的好处:

  • 所有配置中心化,在应用众多的情况下配置管理变得更加方便。
  • 所有配置不依赖版本发布,使得配置变更更加灵活。
  • ACM 天生支持灰度发布和回滚,使得配置的变更发布在微服务架构下变得更加安全。

场景 2:分布式架构下的服务治理

在各类分布式架构下,基于某类 RPC 框架(RESTful,HSF,Dubbo 等)做好服务治理是非常关键的。其中,服务治理的服务路由、服务限流、服务降级、服务鉴权等功能,均可通过配置中心实现。

以限流降级为例,在阿里巴巴双11,每一次服务限流降级相关操作都要求秒级响应,此需求就通过
ACM 来实现。其中,每个 RPC 的服务端都会通过 ACM 注册监听对应服务的流控管理信息。

当应用需要流控时,管理员在服务治理控制台做出限流操作,服务治理系统就会通过
ACM 将流控信息推送到对应的目标应用服务端,让应用服务端对应配置采取相应的限流动作。

image

在分布式架构下使用 ACM 带来的好处:

  • 性能良好,通过采用配置推送的方式来监听服务治理信息,对性能几乎无影响。
  • 响应时间迅速,相关的服务治理信息可以被秒级推送。
  • 安全性高,当限流降级错推以后还可以通过秒级配置回滚来恢复状态

场景 3:企业级互联网架构下的异地多活场景

异地多活是企业级互联网架构中的一种高级容灾架构。相对于传统容灾架构,有业务恢复时间短,容量需求低,运维快捷简单等特点。目前异地多活架构被阿里巴巴和饿了么等公司广泛采用。

在阿里巴巴内部,容灾多活架构的核心算法、ID 分片和对应的的路由规则均采用 ACM 来动态推送。其中,相应的客户端和服务端,如 RPC,MQ,DB 都植入了路由路径。当容灾演练或者真实灾难发生时,管理员只需要动态地推送规则,相应的规则会影响到所有架构组件。

image

采用 ACM 为异地多活场景中的应用带来以下好处:

  • 基础架构和容灾逻辑解耦,具体的路由逻辑由容灾规则切换决定。
  • 生效快,理论上容灾的切换规则可以秒级推送到十万级别机器。

ACM 与 Nacos 的关系

Nacos 是阿里中间件今年 7 月开源的产品,包括配置管理、服务管理、动态 DNS 服务、服务元数据管理等功能,其中的 Nacos 配置管理模块是跟 ACM 完全对等的,因此 Nacos 的客户端,包括 nacos-client、 nacos-spring-context 等,只需设置了连接 ACM 服务所需的 endpoint、namespace、access key、secret key,就可以直接访问 ACM 的服务。

两者对比如下:

image

ACM 如何支持 Spring

如上所述,Nacos 的客户端可以直接访问 ACM 服务,ACM 支持 Spring 也就是通过 nacos-spring-context 来支持的。

Nacos Spring 提供的一些注解如下:

image

除了注解外,Nacos Spring 还提供了一些事件,在配置发布、删除等操作时能传播事件出来,方便用户做日志或者审计相关的工作,如下:

image

示例

ACM 如何支持 Spring Boot

Nacos Spring Boot 底下是封装了 Nacos Spring ,因此,上面描述的 Nacos Spring 的注解、功能都可以在引入 Nacos Spring Boot 的依赖 之后直接使用。

另外,Nacos Spring Boot 在 Nacos Spring 的基础上做了 Spring Boot Actuator 服务监控和管理相关的 Endpoint 和 Health Check。

示例

ACM 如何支持 Spring Cloud

Nacos Spring Cloud 是属于 Spring Cloud Alibaba 中的一个子模块,支持从 Spring Cloud Config 平滑迁移过来,相对于 Spring Cloud Config,有更多的优势:

image

示例

相关实践学习
通过EDAS实现K8s微服务应用的金丝雀发布
本实验旨在通过使用分布式应用服务EDAS纳管容器服务ACK Serverless,体验微服务应用的部署、访问和高级发布能力。
SpringMVC框架入门
Spring MVC属于SpringFrameWork的后续产品,已经融合在Spring Web Flow里面。Spring 框架提供了构建 Web 应用程序的全功能 MVC 模块。在使用Spring进行WEB开发时,可以选择使用Spring的SpringMVC框架或集成其他MVC开发框架,如Struts2等。 相关的阿里云产品企业级分布式应用服务 EDAS:企业级分布式应用服务 EDAS(Enterprise Distributed Application Service)是一个应用托管和微服务管理的 PaaS 平台,提供应用开发、部署、监控、运维等全栈式解决方案,同时支持 Spring Cloud、Apache Dubbo(以下简称 Dubbo )等微服务运行环境,助力您的各类应用轻松上云。产品详情: https://www.aliyun.com/product/edas 
相关文章
|
8月前
|
Dubbo Java 应用服务中间件
实战指南:如何在Spring Boot中无缝整合Dubbo【四】
实战指南:如何在Spring Boot中无缝整合Dubbo【四】
128 0
|
2月前
|
前端开发 JavaScript Java
如何使用 Spring Boot 和 Angular 开发全栈应用程序:全面指南
如何使用 Spring Boot 和 Angular 开发全栈应用程序:全面指南
51 1
|
6月前
|
消息中间件 Java Spring
实现Spring Boot与RabbitMQ消息中间件的无缝集成
实现Spring Boot与RabbitMQ消息中间件的无缝集成
|
8月前
|
Cloud Native Java 关系型数据库
【阿里云云原生专栏】构建云原生应用:基于Spring Boot与阿里云服务的全栈指南
【5月更文挑战第21天】构建云原生应用是企业数字化转型的关键,本文提供了一份基于Spring Boot和阿里云的全栈指南。涵盖从阿里云账号注册、ECS与Docker搭建,到Spring Boot项目创建、业务代码编写和部署。此外,还介绍了如何集成阿里云OSS存储、RDS数据库服务以及ACK容器服务,助力打造高效、可扩展和易管理的云原生应用。
681 3
|
8月前
|
Java Spring
快速解决Spring Boot跨域困扰:使用CORS实现无缝跨域支持
这是一个简单的配置示例,用于在Spring Boot应用程序中实现CORS支持。根据你的项目需求,你可能需要更详细的配置来限制允许的来源、方法和标头。
774 3
|
Java 文件存储 Spring
轻松实现Spring Boot与FastDFS的无缝整合
家人们啦!,上篇文章了,我们讲了如何使用docker-compose快速部署fastdfs,在今天的文章中,我将向大家介绍如何将Spring Boot与FastDFS进行无缝整合,以便高效地管理和操作文件存储。通过这个整合,你将能够轻松地在Spring Boot应用程序中实现文件的上传和下载等功能。让我们开始吧
282 0
轻松实现Spring Boot与FastDFS的无缝整合
|
8月前
|
机器学习/深度学习 人工智能 自然语言处理
探索Spring AI:将人工智能与软件开发无缝融合
这是一个简单的Spring AI入门示例,演示了如何使用Spring Boot和Spring AI来构建一个简单的机器学习应用程序。通过这个示例,你可以了解到如何利用Spring AI轻松地集成机器学习功能到你的应用程序中。
306 0
|
SpringCloudAlibaba Java 开发者
现在国内最牛逼的 Spring CloudAlibaba全栈操作手册,不接受反驳
Spring Cloud Alibaba 近几年在受到国内不少开发者的广泛关注,也成为面试比较吃香的一个技能点了,如果你连Spring Cloud Alibaba 微服务生态都没用过,那么你可能就要被时代淘汰了。
106 0
|
Java Spring
阿里新作!阿里大佬纯手写Angular和Spring Boot全栈技能修炼手册
全栈,就像武侠小说里常常会说打通任督二脉之后功力大增,为什么打通任督二脉如此重要?因为它们统率着全身的经脉,它们是一切经脉的根本。相对于其他经脉来说,任督二脉很简单,但也最难打通。
115 0
|
缓存 负载均衡 Java
Spring Cloud Gateway + Nacos 实现服务上下线无缝切换
Spring Cloud Gateway + Nacos 实现服务上下线无缝切换
下一篇
开通oss服务