系统配置自动装载机制 - 分布式开发

简介: 系统配置自动装载机制 - 分布式开发

系统配置自动装载机制 - 分布式开发


  • 点击进入源码查看

1.png这个注解相当于三个注解的功能集成


1.1 @EnableAutoConfiguration

启用Spring Boot的自动bean加载机制


1.2 @ComponentScan

在应用程序所在的包上启用扫描

2.png

配置组件扫描指令,以与 Configuration 类一起使用。

提供与Spring XML的元素并行的支持。

可以指定{@link #basePackageClasses}或{@link #basePackages}(或其别名{@link #value})来定义要扫描的特定程序包。 如果未定义特定的程序包,则将从声明此批注的类的程序包中进行扫描。


请注意,{@code }元素具有一个

{@code注解-配置}属性; 但是,此注释没有。这是因为在几乎所有情况下,使用{@code @ComponentScan}时,都将采用默认的注释配置处理(例如,处理 @Autowired 和朋友。 此外,当使用{@link AnnotationConfigApplicationContext}时,注释配置处理器始终会被注册,这意味着在{@code @ComponentScan}级别禁用它们的任何尝试都将被忽略。

3.png

代码包扫描

默认的包结构及其作用

1.主程序Application.java放在根包, 在其他类之上。

2. @SpringBootApplication注 解写在主程序上。

3. Spring对类的扫描默认仅涵盖主程序所在的包及子包


1.3 @Configuration:允许在Spring中注册额外的bean或导入其他配置类


4.pngimage.png


〇Spring配置文件


SpringBoot中建议放弃通过XML定义Spring应用程序,推荐在代码类上面通过@Configuration实现配置。

如有需要,还可以通过@ImportResource来导入xml配置文件。

6.png


2 个性化依赖配置


image.png


3 外部参数配置信息加载


Spring应用程序可以通过属性文件,YAML文件,环境变量和命令行参数等方式的外部化参数配置


■ 启动时命令行传参

java -jar app.jar --name="test"


■ SpringBoot配置信息中的特殊值:

SPRING_ APPLICATION_ JSON='{"name'":"test"}'


■ 如果是web应用,可以读取ServletConfig init参数

如果是web应用,可以读取ServletContext init参数

■ JNDI属性来自

java:comp/env

■ Java系统属性(System.getProperties()

■ 操作系统环境变量

配置文件

application.properties

application.yml

application-{profile.properties、 application-{profile}.yml .

■ @PropertySource注解导入的配置: @PropertySource(value={“person.properties”})

■ 程序入口通过SpringApplication.setDefaultProperties方法设定的参数配置


4 环境化配置- profile


➢ profile是什么机制?

①Spring配置 文件提供的一种隔离应用程序配置的方法,使其仅在特定环境中可用。

②可通过profile指定Bean的应用环境 (如开发、测试、生产等环境)

③可通过profile指定 不同环境的配置参数值

➢ 如何指定profile?

通过配置参数spring.profiles.active来指定应用启用的profiles。默认default

①在环境变量中指定: jvm参数、命令行程序参数、application.properties中都可以

②代码中指定: springApplication.setAdditionalProfiles(“dev,test”);

➢ 如何在开发中使用?

①Configuration类或者Bean定义方法上,都可以通过添加@Profile(“dev”)注解,实现指定环境下生效。

②配置文件中:

<beans profile= "dev" ><bean ....</bean></beans>


5 配置文件


➢ 配置文件可以存放在哪些位置?

1.当前项目运行的盘符/config文件夹下面: file../config/

2.当前项目运行的目录下面(命令执行的所在目录) :file:./

3. classpath 下面的config文件夹: classpath:/config

4. classpath的根目录(我们平常就是用这种) : classpath:/

上述配置文件按优先级排列,排在上面的位置会覆盖优先级降低的配置。


6 配置文件格式

SpringBoot支持两种配置文件的格式: .properites、 .yml

yaml语法精简版说明

8.png

大小写敏感

使用空格缩进表示层级(不要用TAB),同一层级的左侧对齐

map键值对通过“:” 分隔

list列表元素通过“”表示

口properties示例:

spring.datasource.username=test



7 参数使用

方式一:

通辻@Value("${my.name}"'注解,将指定的参数配置注入到属性。

方式二:

注入Environment対象。

伪代码-注入env対象
@Autowired
Environment environment;
1使用示例
environment.getProperty("name");

方式三:

通辻注解@ConfigurationProperties(prefix= “my”)

将注解加在指定的炎上,spring会 カ突例対象的属性迸行賦値,属性需有getters和setters方法。


目录
相关文章
|
4月前
|
NoSQL Java Redis
实现基于Redis的分布式锁机制
实现基于Redis的分布式锁机制
|
1月前
|
存储 缓存 算法
分布式锁服务深度解析:以Apache Flink的Checkpointing机制为例
【10月更文挑战第7天】在分布式系统中,多个进程或节点可能需要同时访问和操作共享资源。为了确保数据的一致性和系统的稳定性,我们需要一种机制来协调这些进程或节点的访问,避免并发冲突和竞态条件。分布式锁服务正是为此而生的一种解决方案。它通过在网络环境中实现锁机制,确保同一时间只有一个进程或节点能够访问和操作共享资源。
67 3
|
1月前
|
NoSQL Java Redis
开发实战:使用Redisson实现分布式延时消息,订单30分钟关闭的另外一种实现!
本文详细介绍了 Redisson 延迟队列(DelayedQueue)的实现原理,包括基本使用、内部数据结构、基本流程、发送和获取延时消息以及初始化延时队列等内容。文章通过代码示例和流程图,逐步解析了延迟消息的发送、接收及处理机制,帮助读者深入了解 Redisson 延迟队列的工作原理。
|
1月前
|
消息中间件 存储 监控
消息队列系统中的确认机制在分布式系统中如何实现
消息队列系统中的确认机制在分布式系统中如何实现
|
1月前
|
消息中间件 存储 监控
【10月更文挑战第2天】消息队列系统中的确认机制在分布式系统中如何实现
【10月更文挑战第2天】消息队列系统中的确认机制在分布式系统中如何实现
|
5月前
|
消息中间件 NoSQL Java
Redis系列学习文章分享---第六篇(Redis实战篇--Redis分布式锁+实现思路+误删问题+原子性+lua脚本+Redisson功能介绍+可重入锁+WatchDog机制+multiLock)
Redis系列学习文章分享---第六篇(Redis实战篇--Redis分布式锁+实现思路+误删问题+原子性+lua脚本+Redisson功能介绍+可重入锁+WatchDog机制+multiLock)
227 0
|
6月前
|
关系型数据库 分布式数据库 数据库
【PolarDB开源】PolarDB-X源码解读:分布式事务处理机制揭秘
【5月更文挑战第20天】PolarDB-X,PolarDB家族的一员,专注于大规模分布式事务处理,采用2PC协议保证ACID特性。源码解析揭示其通过预提交、一致性快照隔离和乐观锁优化事务性能,以及利用事务日志进行故障恢复。深入理解其事务处理机制对开发者掌握分布式数据库核心技术至关重要。随着开源社区的发展,更多优化方案将涌现,助力构建更强大的分布式数据库系统。
221 6
|
30天前
|
消息中间件 存储 监控
消息队列系统中的确认机制在分布式系统中如何实现?
消息队列系统中的确认机制在分布式系统中如何实现?
|
3月前
|
消息中间件 存储 监控
消息队列系统中的确认机制在分布式系统中如何实现?
消息队列系统中的确认机制在分布式系统中如何实现?
|
3月前
|
消息中间件 Java Kafka
如何在Kafka分布式环境中保证消息的顺序消费?深入剖析Kafka机制,带你一探究竟!
【8月更文挑战第24天】Apache Kafka是一款专为实时数据管道和流处理设计的分布式平台,以其高效的消息发布与订阅功能著称。在分布式环境中确保消息按序消费颇具挑战。本文首先介绍了Kafka通过Topic分区实现消息排序的基本机制,随后详细阐述了几种保证消息顺序性的策略,包括使用单分区Topic、消费者组搭配单分区消费、幂等性生产者以及事务支持等技术手段。最后,通过一个Java示例演示了如何利用Kafka消费者确保消息按序消费的具体实现过程。
123 3

热门文章

最新文章