springboot入门及application.yaml核心配置文件

springboot入门及application.yaml核心配置文件

什么是SpringBoot

SpringBoot是由Pivotal团队在2013年开始研发、2014年4月发布第一个版本的全新开源的轻量级框架。springboot是一个快速开发的框架,可以迅速搭建一套基于spring框架体系的应用。

SpringBoot优点

  1. 独立运行Spring项目

    Spring boot 可以以jar包形式独立运行,运行一个Spring Boot项目只需要通过java -jar xx.jar来运行

  2. 内嵌servlet容器

    Spring Boot可以选择内嵌Tomcat、jetty或者Undertow,这样我们无须以war包形式部署项目

  3. 提供starter简化Maven配置

    spring提供了一系列的start pom来简化Maven的依赖加载

  4. 自动装配Spring

    SpringBoot会对SpringBoot启动类的子包下的类进行自动装配

  5. 准生产的应用监控

    SpringBoot提供基于http ssh telnet对运行时的项目进行监控

  6. 无代码生产和xml配置

    SpringBoot不是借助与代码生成来实现的,而是通过条件注解来实现的

什么是微服务

​ 微服务是一种用于构建应用的架构方案。微服务架构有别于更为传统的单体式方案,可将应用拆分为多个核心功能。每个功能都被称为一项服务,可以单独构建和部署,各项服务在工作式不会相互印象

springboot与微服务的关系

​ spring Cloud依赖于springboot,spring boot专注于快速开发个体微服务,spring Cloud是关注全局的微服务协调治理框架


SpringBoot入门

  1. New Project

  2. 点击Spring Initializr

  3. 创建项目名称(jdk版本、及包名等)

  4. 场景依赖选择界面

  5. 存放位置

  6. springboot项目会默认生成项目启动类、存放静态资源和页面的文件夹、编写项目配置的配置文件以及进行项目单元测试的测试类

  7. 查看自动生成的启动类

    package com.sheep;
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    
    @SpringBootApplication
    public class DemoApplication {
        public static void main(String[] args) {
            SpringApplication.run(DemoApplication.class, args);
        }
    }
    

    @SpringBootApplication:表示当前类SpringBoot的入口,Application类的存放位置必须是其他相关业务类的存放位置的父级。

  8. pom.xml中查看自动生成添加的依赖

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
        <parent>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>2.4.5</version>
            <relativePath/> <!-- lookup parent from repository -->
        </parent>
        <groupId>com.sheep</groupId>
        <artifactId>demo</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <name>demo</name>
        <description>sheep Spring Boot project</description>
        <properties>
            <java.version>11</java.version>
        </properties>
        <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-test</artifactId>
                <scope>test</scope>
            </dependency>
        </dependencies>
        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                </plugin>
            </plugins>
        </build>
    </project>
    

    springboot依赖管理:

    ​ spring-boot-starter-parent:在spring-boot-starter-parent的父依赖spring-boot-dependencies中对框架 的依赖文件进行了统一版本号管理;

    启动器:

    ​ spring-boot-starter-web:web依赖启动器,添加后springboot框架会自动将web所依赖的包全部导入

    ​ spring-boot-devtools:热部署依赖启动器,· · · devtools所依赖的包全部导入

    ​ spring-boot-starter-test:单元测试依赖启动器,· · · test所依赖的包全部导入

    ​ 单元测试中的注解:

    ​ @RunWith(SpringRunner.class) //测试运行器,并加载SpringBoot测试注解

    ​ @SpringBootTest //标记单元测试类,并加载项目的上下文环境ApplicationContext

  9. 编写一个Controller

    package com.sheep.controller;
    import org.springframework.stereotype.Controller;
    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.ResponseBody;
    
    @Controller
    @RequestMapping("/hello")
    public class HelloController {
    
        @GetMapping("/hello")
        @ResponseBody
        public String hello(){
            return "hello spring boot";
        }
    }
    
  10. 运行


application.yaml核心配置文件

概念

1、yaml文件格式是SpringBoot支持的一种JSON超文本格式,相对于传统的properties文件格式,yaml文件以数据为核心,是一种更为直观且容易被计算机识别的数据序列化格式,application.yaml和application.properties工作原理是一样的,只不过yaml格式的配置文件更加简洁。

2、xxx.yaml和xxx.properties是全局配置文件可以对SpringBoot一些默认配置只进行修改,在.yaml和.properties中可以对系统属性、环境变量、命令参数等信息进行更改配置,在springboot中推荐使用.yaml的格式进行配置。

语法

properties语法:key=value

yaml语法:key: value

  • 大小写敏感
  • 使用缩进表示层级关系
  • 缩进时不允许使用Tab键,只允许使用空格。
  • 缩进的空格数目不重要,只要相同层级的元素左侧对齐即可

普通写法

name: sheep

对象写法

# 写法一
student1: {name: sheep,age: 3}
# 写法二
student2:
	name: sheep
	age: 3

数组写法

# 写法一
	# list
pets2: [cat,dog,pig]
	# map
pets2: {cat: 12,dog: 13,pig: 14}
# 写法二
	# list
pets1:
	- cat
	- dog
	# map
pets2:
	cat: 12
	dog: 13
	pig: 14

多文档模块

server:
  prot: 8080
---
server:
  prot: 8081
---
server:
  port: 8082

属性注入

1、使用@ConfigurationProperties(prefix = "")对属性注入值(SpringBoot自带注解)

  • yaml

    person:
      name: 梅西
      age: 33
      happy: true
      birth: 2000/08/12
      maps: {k1: v1,k2: v2}
      lists:
        - code
        - football
        - baesball
        - boxing
        - outdoor
      dog:
        name: 旺财
        age: 6
    
  • javaBean

    @Data
    @AllArgsConstructor
    @NoArgsConstructor
    @Component
    @ConfigurationProperties(prefix = "person")
    public class Person {
        private String name;
        private Integer age;
        private Boolean happy;
        private Date birth;
        private Map<String,Object> maps;
        private List<Object> lists;
        private Dog dog;
    }
    

2、使用@Value()对属性赋值(Spring框架注解)

  • JavaBean

    @Data
    @AllArgsConstructor
    @NoArgsConstructor
    @Component
    public class Person {
        @Value("梅西")
        private String name;
        @Value("33")
        private Integer age;
        private Boolean happy;
        private Date birth;
        private Map<String,Object> maps;
        private List<Object> lists;
        private Dog dog;
    }
    

3、两种注解对比

  • @ConfigurationProperties与@Value

    对比点 @ConfigurationProperties @Value
    底层框架 SpringBoot Spring
    功能 批量注入配置文件中的属性 单个注入
    setter方法 需要 不需要
    复杂类型属性注入 支持 不支持
    松散绑定 支持 不支持
    JSR303数据校验 支持 不支持
    SqEL表达式 不支持 支持

松散绑定、SqEL表达式和JSR303数据校验

  • 松散绑定

    松散绑定是当注入的属性名与bean中的不一致是仍然可以实现属性赋值;使用@ConfigurationProperties注解配

    置文件时支持松散语法绑定;

    proson: {mName: 梅西}		//标准写法
    proson: {m-Name: 梅西}	//可以使用-线
    proson: {m_Name: 梅西}	//可以使用_线
    proson: {M_NAME: 梅西}	//可以使用大小写格式
    
  • SqEL表达式

    SqEL表达式即不使用配置文件的情况下直接使用@Value("#{5*2}"),直接对属性赋值

  • JSR303数据校验

    对前端传过来的数据进行校验

    yaml

    messi:
    	esail: 123e
    	age: 33
    

    javaBean

    @Data
    @AllArgsConstructor
    @NoArgsConstructor
    @Component
    @ConfigurationProperties(prefix = "messi")
    public class Messi{
        @Email(message="邮箱格式错误")
        private String email;
        @Value("33")
        private Integer age;
    }
    

    如果异常控制台将会显示打印异常

    JSR303数据校验详细:https://blog.csdn.net/weixin_44440642/article/details/106335653

多环境配置

  1. 多个yaml文件配置和yaml的优先级

    • 当有多个.yaml或者.properties文件时可以使用@PropertySource(value = "")指定文件

      JavaBean

      @Data
      @AllArgsConstructor
      @NoArgsConstructor
      @Component
      @PropertySource(value = "classpath:sheep.yaml")//指定那个文件
      public class Person {
          private String name;
          private Integer age;
          private Boolean happy;
          private Date birth;
          private Map<String,Object> maps;
          private List<Object> lists;
          private Dog dog;
      }
      
    • 在SpringBoot项目中可以在多个位置定义.yaml配置文件;在不同位置指定的.yaml优先级都不一样

      上图对应的分别为:

      file:./config/:项目的config报下—优先级1

      file:./:项目文件下—优先级2

      classpath:/config/:类路径config报下—优先级3

      classpath:/:类路径下—优先级4

  2. yaml多个运行环境配置

    当应用程序需要部署到不同的运行环境中时,比如:开发环境、测试环境、生产环境,可以使用不同的properties文件配置。

    • properties方式

      在配置多个环境时为.yaml取名必须要求取名比如:application-{prifile}.yaml

      application-dev.properties		# 开发环境配置
      application-test.properties		# 测试环境配置
      application-prod.properties 	# 生产环境配置
      

      使用相应的环境时在全局配置文件中开启

      spring.profiles.action=dev
      
    • yaml方式

      server:
        port: 8080
      spring:
        profiles:
          active: test	# 开启test环境,如果不使用默认8080
      ---
      server:
        port: 8081
      spring:
        profiles: dev
      ---
      server:
        port: 8082
      spring:
        profiles: test
      

随机值设置和参数间引用

  • 随机值设置:${random.xxx},xxx表示指定生成随机数的范围和类型

    person:
      name: 梅西${random.uuid}	 # 随机生成UUID类型数 
      age: ${random.int}		  # 随机生成int类型数
      happy: true
      birth: 2000/08/12
      maps: {k1: v1,k2: v2}
      lists:
        - code
        - football
        - baesball
        - boxing
        - outdoor
      dog:
        name: 旺财
        age: 6
    

    常用随机数

    ${random.value}					# 随机字符串
    ${random.int}					# 随机整数
    ${random.long}					# 随机long类型数
    ${random.uuid}					# 随机UUID类型数
    ${random.int(10)}				# 小于10的随机整数
    ${random.int[1024,2000]}		# 在[1024,2000]之间的随机整数
    
  • 参数间引用:顾名思义先配置的参数可以在后配置的参数中使用

    person:
      name: 梅西${random.uuid}	   # 随机生成UUID类型数 
      age: ${random.int}            # 随机生成int类型数
      happy: true
      birth: 2000/08/12
      maps: {k1: v1,k2: v2}
      hello: happy
      lists:
        - code
        - football
        - baesball
        - boxing
        - outdoor
      dog:
        name: ${person.hello:hello}_旺财 # 参数间引用如果hello参数存在则happy__旺财,否则hello_参数
        age: 6
    
posted @ 2021-05-20 16:55  一程山水一年华^_^  阅读(1508)  评论(0编辑  收藏  举报
TOP 底部 /*显示代码块行号*/