标签:rod resource 配置文件 dep 引号 mave 概述 文件的 键值
微服务 响应式 分布式
Spring Boot makes it easy to create stand-alone, production-grade Spring based Applications that you can "just run".
---------------约定大于配置
SpringBoot优点
何为微服务
何为分布式
解决:SpringBoot + SpringCloud
1.创建maven工程
2.引入依赖
<parent>
<!--
starter-parent定义了各种技术的版本信息,组合了一套最优搭配的技术版本
-->
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.4.RELEASE</version>
</parent>
<dependencies>
<!--
在各种starter中,定义了完成该功能需要的坐标合集,其中大部分版本信息来自于父工程
-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
<!--
工程继承parent,引入starter后,通过依赖传递,就可以获得需要的jar包,
并且不存在版本冲突等问题
-->
3.主程序 --- 用于启动项目
@SpringBootApplication
public class MainApplication {
public static void main(String[] args) {
SpringApplication.run(MainApplication.class, args);
}
}
4.编写业务 --- Controller等
5.直接运行main方法 ---- 项目入口
6.简化配置 --- 直接在application.properties中配置
很多配置都有默认值,使用application.properties或者application.yml(application.yaml)使自己的配置替换默认配置
7.简化部署 --- 添加plugin ----
把项目打成jar包,直接在目标服务器执行即可
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
yaml/yml文件
适合以数据为中心的配置文件
#字面量:单个的、不可再分的值 --- date、boolean、string、number、null
k: v
#对象:键值对的集合。map、hash --- map、hash、set、object
k: {k1:v1,k2:v2,k3:v3}
k:
k1: v1
k2: v2
k3: v3
#数组:一组按次序排列的值 --- array、list、queue
k: [v1,v2,v3]
k:
- v1
- v2
- v3
#参数引用
name: jack
person:
name: ${name} # 引用上边定义的name值
@Value
//注解在属性上,使用 ${名称} 获取配置中对应值
@Value("${name}")
private String name;
Evironment
//引入环境
@Autowired
private Environment env;
//可直接获取配置文件的值
System.out.println(env.getProperty("person.name"));
@ConfigurationProperties(prefix = "xxx") + @Component
注解在类上,根据前缀xxx获取配置中的值,从而获取对象
不同环境下,配置动态切换功能
多profile文件方式:提供多个配置文件,每个代表一种环境。
例如
激活方式
内部加载位置顺序
标签:rod resource 配置文件 dep 引号 mave 概述 文件的 键值
原文地址:https://www.cnblogs.com/fremontxutheultimate/p/14934554.html