SpringBoot01
时间:2021-06-28 18:47:02
收藏:0
阅读:0
SpringBoot01:入门
1.概述
微服务 响应式 分布式
Spring Boot makes it easy to create stand-alone, production-grade Spring based Applications that you can "just run".
---------------约定大于配置
SpringBoot优点
- 创建独立Spring应用
- 内嵌web服务器
- 自动starter依赖,简化构建配置
- 自动配置Spring以及第三方功能
- 提供生产级别的监控、健康检查及外部化配置
- 无代码生成、无需编写XML
何为微服务
- 微服务是一种架构风格
- 一个应用拆分为一组小型服务
- 每个服务运行在自己的进程内,也就是可独立部署和升级
- 服务之间使用轻量级HTTP交互
- 服务围绕业务功能拆分
- 可以由全自动部署机制独立部署
- 去中心化,服务自治。服务可以使用不同的语言、不同的存储技术
何为分布式
解决:SpringBoot + SpringCloud
2.SpringBoot基本操作
2.1 HelloSpringBoot
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)使自己的配置替换默认配置
- 默认配置文件名称:application---------resources中
- 在同一级目录下优先级为:properties>yml > yaml
7.简化部署 --- 添加plugin ----
把项目打成jar包,直接在目标服务器执行即可
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
3.配置文件
yaml/yml文件
适合以数据为中心的配置文件
3.1 基本语法
- key: value;kv之间有空格
- 大小写敏感
- 使用缩进表示层级关系
- 相同层级的元素左对齐
- ‘#‘表示注释
- 字符串无需加引号 ---- ‘‘与""表示字符串内容 会被 转义/不转义
3.2 数据类型
#字面量:单个的、不可再分的值 --- 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值
3.3 获取数据
@Value
//注解在属性上,使用 ${名称} 获取配置中对应值
@Value("${name}")
private String name;
Evironment
//引入环境
@Autowired
private Environment env;
//可直接获取配置文件的值
System.out.println(env.getProperty("person.name"));
@ConfigurationProperties(prefix = "xxx") + @Component
注解在类上,根据前缀xxx获取配置中的值,从而获取对象
3.4 profile
不同环境下,配置动态切换功能
多profile文件方式:提供多个配置文件,每个代表一种环境。
例如
- application-dev.properties/yml 开发环境
- application-test.properties/yml 测试环境
- application-pro.properties/yml 生产环境
激活方式
- 配置文件: 再配置文件中配置:spring.profiles.active=dev
- 虚拟机参数:在VM options 指定:-Dspring.profiles.active=test
- 命令行参数:java –jar xxx.jar --spring.profiles.active=pro
3.5 加载配置文件
内部加载位置顺序
- file: ./config/ 当前项目下的/config目录下
- file:. / 当前项目的根目录
- classpath: /config/ classpath的/config目录
- classpath: / classpath的根目录
评论(0)