Spring Cloud Archaius 多配置源收集 原理简介(一)

简介: 功能强大的配置管理库 可用于从许多不同来源收集配置属性的框架,提供对配置信息的快速及线程安全访问Archaius可以从多个动态源中检索属性、允许属性在运行时动态更改,使系统无需重新启动应用程序即可获得这些变化(异构的属性源,运行时更改等)

概述

  • 功能强大的配置管理库 可用于从许多不同来源收集配置属性的框架,提供对配置信息的快速及线程安全访问
  • Archaius可以从多个动态源中检索属性、允许属性在运行时动态更改,使系统无需重新启动应用程序即可获得这些变化(异构的属性源,运行时更改等)

功能

  • 动态和类型属性
  • 在属性改变时调用的回调机制
  • 动态配置源(如URL,JDBC和Amazon DynamoDB)的实现
  • Spring Boot Actuator或JConsole可以访问的JMX MBean,用于检查和操作属性
  • 动态属性验证

添加依赖

微信图片_20220421225508.png

微信图片_20220421225512.png

用法

  • 一旦我们添加了所需的依赖项,我们就能够访问框架管理的属性:

微信图片_20220421225516.png

  • 默认情况下,它动态管理应用程序类路径中名为config.properties的文件中定义的所有属性。

所以我们将它添加到我们的资源文件夹中,其中包含一些任意属性:

springcloud.archaius.properties.one=one FROM:config.properties
springcloud.archaius.properties.three=three FROM:config.properties
  • 指定读取的配置文件

1⃣️ 可以通过 archaius.configurationSource.defaultFileName 指定读取的配置文件 在启动应用程序时将其作为参数传递给vm

2⃣️写在代码本身中

微信图片_20220421225521.png

3⃣️ 多个配置文件 指定加载顺序

微信图片_20220421225524.png

使用键“@ next = nextFile.properties”指定一个特殊属性来告诉Archaius哪个是应该加载的下一个文件。

  • 需要一种在任何特定时刻检查属性值的方法。在这种情况下,我们将创建一个RestController,将值作为JSON响应检索:

微信图片_20220421225528.png

微信图片_20220421225532.png

修改属性 无需重新启动服务 在一分钟左右之后,对端点的调用应检索出新值

工作原理

  • Archaius是Apache的Commons Configuration库的扩展,添加了一些很好的功能,如动态源的轮询框架,具有高吞吐量和线程安全的实现。
  • 然后 spring-cloud-netflix-archaius 库进入,合并所有不同的属性源,并使用这些源自动配置Archaius工具。

Netflix Archaius库

  • 它定义了一个复合配置,是可以从不同来源获得的各种配置的集合。
  • 其中一些配置源可以支持在运行时轮询更改。Archaius提供接口和一些预定义的实现来配置这些类型的源。
  • 源集合是分层的,因此如果属性存在于多个配置中,则最终值将是最顶部插槽中的值。
  • ConfigurationManager处理系统范围的配置和部署上下文。它可以安装最终的复合配置,或检索已安装的复合配置进行修改。

Spring Cloud Archaius库

主要任务是将所有不同的配置源合并为 ConcurrentCompositeConfiguration,并使用ConfigurationManager进行安装 。

库定义源的优先顺序是:

  • 上下文中定义的任何Apache公共配置AbstractConfiguration bean
  • Autowired Spring ConfigurableEnvironment中定义的所有源代码
  • 默认的Archaius源,我们在上面的例子中看到过
  • Apache的SystemConfiguration和EnvironmentConfiguration 源
  • Spring Cloud库提供的另一个有用功能是定义一个Actuator Endpoint 来监控属性并与之交互。
相关文章
|
18天前
|
Java API 数据库
构建RESTful API已经成为现代Web开发的标准做法之一。Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐。
【10月更文挑战第11天】本文介绍如何使用Spring Boot构建在线图书管理系统的RESTful API。通过创建Spring Boot项目,定义`Book`实体类、`BookRepository`接口和`BookService`服务类,最后实现`BookController`控制器来处理HTTP请求,展示了从基础环境搭建到API测试的完整过程。
33 4
|
15天前
|
Java API 数据库
Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐
本文通过在线图书管理系统案例,详细介绍如何使用Spring Boot构建RESTful API。从项目基础环境搭建、实体类与数据访问层定义,到业务逻辑实现和控制器编写,逐步展示了Spring Boot的简洁配置和强大功能。最后,通过Postman测试API,并介绍了如何添加安全性和异常处理,确保API的稳定性和安全性。
27 0
|
8天前
|
Java API Spring
在 Spring 配置文件中配置 Filter 的步骤
【10月更文挑战第21天】在 Spring 配置文件中配置 Filter 是实现请求过滤的重要手段。通过合理的配置,可以灵活地对请求进行处理,满足各种应用需求。还可以根据具体的项目要求和实际情况,进一步深入研究和优化 Filter 的配置,以提高应用的性能和安全性。
|
16天前
|
Java BI 调度
Java Spring的定时任务的配置和使用
遵循上述步骤,你就可以在Spring应用中轻松地配置和使用定时任务,满足各种定时处理需求。
102 1
|
17天前
|
负载均衡 算法 Java
蚂蚁面试:Nacos、Sentinel了解吗?Springcloud 核心底层原理,你知道多少?
40岁老架构师尼恩分享了关于SpringCloud核心组件的底层原理,特别是针对蚂蚁集团面试中常见的面试题进行了详细解析。内容涵盖了Nacos注册中心的AP/CP模式、Distro和Raft分布式协议、Sentinel的高可用组件、负载均衡组件的实现原理等。尼恩强调了系统化学习的重要性,推荐了《尼恩Java面试宝典PDF》等资料,帮助读者更好地准备面试,提高技术实力,最终实现“offer自由”。更多技术资料和指导,可关注公众号【技术自由圈】获取。
蚂蚁面试:Nacos、Sentinel了解吗?Springcloud 核心底层原理,你知道多少?
|
21天前
|
Java Spring 容器
Spring底层原理大致脉络
Spring底层原理大致脉络
|
22天前
|
XML Java 数据格式
手动开发-简单的Spring基于注解配置的程序--源码解析
手动开发-简单的Spring基于注解配置的程序--源码解析
37 0
|
22天前
|
XML Java 数据格式
手动开发-简单的Spring基于XML配置的程序--源码解析
手动开发-简单的Spring基于XML配置的程序--源码解析
67 0
|
存储 缓存 Java
Spring 缓存抽象简介|学习笔记
快速学习 Spring 缓存抽象简介
102 0
|
XML 开发框架 监控
Spring Boot 简介|学习笔记
快速学习 Spring Boot简介