• Spring Boot框架


    目录

    一、Spring Boot

    1、Spring Boot优点

    2、创建Spring Boot

    3、Spring Boot配置文件

    (1)配置文件的作用

    (2)properties文件格式

    (3)yml文件的格式

    (4)properties vs yml

    二、Spring Boot日志框架

    1、java常见的日志框架

    2、日志级别

    3、日志打印


    一、Spring Boot

    Spring Boot也是Spring官方提供的一个顶级项目。便捷的开发Spring框的的项目(提高效率)。基于“约定大于配置”的设计原则。Spring Boot提供了绝大多数的约定(如果没有配置,就基于默认的约定来设置相关项目需要的属性)。

    1、Spring Boot优点

    • 快速集成框架:提供了启动添加依赖的功能,用于秒级集成各种框架(自动化配置)。如:添加Spring Boot支持的其它框架(如Spring-boot-driud-starter数据库连接池的框架,可以自动的帮助我们注册其中的Bean对象,完成数据库连接的配置)
    • 内置运行容器,无需配置Tomcat等Web容器,直接运行和部署。
    • 完全抛弃繁琐的XML,使用注解和配置的方式进行开发。(使用传统的Spring进行项目开发,会使用大量的xml文件,及文件内容)
    • 支持更多的监控指标,可以更好地了解项目的运行情况。(这是官方提供的一个专门监控Spring Boot项目的依赖包)。

    2、创建Spring Boot

    这里描述基于普通的maven项目进行搭建。

    (1)创建一个普通的maven项目

    (2)修改pom.xml文件,引入依赖

     (3)准备SpringBoot的启动配置文件

     (4)开发SpringBoot启动类

     【代码如下】

    1. package org.exmaple;
    2. //必须在某个包下
    3. import org.springframework.boot.SpringApplication;
    4. import org.springframework.boot.autoconfigure.SpringBootApplication;
    5. //SpringBoot的启动类注解
    6. @SpringBootApplication
    7. public class Application {
    8. public static void main(String[] args) {
    9. //基于SpringBoot的方式启动
    10. SpringApplication.run(Application.class,args);
    11. }
    12. }

    配置成功如下:

     可以提供web静态资源,在resources目录下的public或者static文件夹中,访问时路径为资源路径,不需要添加public等文件夹路径。

     url格式:http://ip:port/应用上下文路径/服务资源路径?queryString

    • 应用上下文路径:Springboot中默认为“/”;
    • 服务资源路径:public和static下的文件,但不包含本身。

    3、Spring Boot配置文件

    (1)配置文件的作用

    整个项目中所有重要的数据都是在配置文件中配置:

    • 数据库的连接信息(用户名和密码的设置);
    • 项目的启动端口;
    • 第三方系统的调用密钥等信息;
    • 用于发现和定位问题的普通日志和异常日志等。

    配置文件在resources目录下,文件名为application,格式为properties/yml。(只能出现一个配置文件)

    (2)properties文件格式

    以键值对的形式进行配置(每个键值对一行),key和value之间使用“=”连接。键的多层级之间使用“."连接。

     读取配置文件:

    使用@Value注解来实现。使用${}格式读取。

    1. @RestController
    2. @RequestMapping("/user")
    3. public class UserController {
    4. //@Value直接,使用${“配置项键名”},就可以将该键对应的值设置到属性中
    5. @Value("${server.port}")
    6. private String port;
    7. @RequestMapping("/port")
    8. public String port(){
    9. return port;
    10. }
    11. }

     上面将端口号改为8085,此时访问该路径显示端口号为8085.

    (3)yml文件的格式

    yml是树形结构的配置文件,基础语法“key: value”,key和vlaue之间使用英文冒号加空格的方式组成,空格不可省略。yml文件最大的优势是可以跨语言,不只是java中可以使用,golang、python都可以使用yml作为配置文件。

     yml配置对象(这个时候就不能使用@Value来读取配置中的对象了,需要使用另一个注解@ConfigurationProperties来进行读取):

    (4)properties vs yml

    • properties通过键值对的形式配置文件;yml使用类似于json格式的属性方式进行配置,层级之间使用换行缩进的方式配置,key和value之间使用英文冒号加空格的方式配置,空格不能省略。
    • properties为早期并且默认的配置文件的格式,但其配置存在一定的冗余数据,使用yml可以很好的解决数据冗余的问题。
    • yml通用性好,支持更多语言,如果是云服务器开发,可以使用yml配置文件作为1Java和go的共同配置文件。

    二、Spring Boot日志框架

    日志框架的作用:

    • 设置多种日志级别;
    • 打印时,指定不同的日志级别;
    • 输出到不同的地方:比如控制台、本地文件等。

    不同的环境,需要不同的打印信息,如开发环境:需要打印一些调试信息:但生产环境(一般指linux服务器,运行项目,不需要观察控制台,日志一般输出到文件中),就不能打印这些调试信息。

    1、java常见的日志框架

    • log4j=>apache提供的日志框架;
    • log4j2=>log4j的升级版本;
    • logback=>springboot默认的内置日志框架
    • slf4j=>日志的桥接框架(如果直接使用耨个日志框架的api,比如logback,那么之后要切换到lig4j,必须改代码,不太方便,,所以产生了slf4j这个桥接框架。基于slf4j的api来打印日志,之后,就可以无缝切换日志框架的具体实现了)。

    2、日志级别

    级别由低到高:

    • trace:微量,级别最低;
    • debug:需要调试时候的关键信息打印;
    • info:普通的打印信息;
    • warn:警告,不影响使用,但需要注意的问题;
    • error:错误信息,级别较高的错误日志信息;
    • fatal:致命的,因为代码异常导致程序退出执行的事件。

    配置日志级别

    1. #root,表示默认的所有的代码中,设置的打印级别
    2. logging.level.root=INFO
    3. #自定义某个包/某个类的打印级别(符合条件的就不在世root的级别)
    4. #org.example.controller表示的这个包/类的打印级别自定义
    5. lohhing.level.org.example.controller=debug

    3、日志打印

    使用日志对象,调用不同级别的打印方法(添加@Slf4j注解):

     也可以使用字符串格式化的方式进行打印(变量替换占位符):

    将日志保存到本地文件

    1. # 设置日志文件的目录
    2. logging:
    3. file:
    4. path: D:\home\ruoyi
    5. # 设置日志文件的文件名
    6. logging:
    7. file:
    8. name: D:\home\ruoyi\spring-1204.log
  • 相关阅读:
    万界星空科技电子机电行业MES系统,2000元/年起
    基于SSM的学生(成绩)管理系统
    13.1 GAS基本框架搭建及第一个GA
    软件测试自学不知道如何下手?一篇文章7个步骤带你找准方向
    数据结构里的一棵树
    “今天星期五“-SAP SE09/STMS 请求号传输中遇到的错误及解决方案
    git代码管理工具保姆级教学
    Win10怎么快速删除超大数量文件群
    【PID专题】MATLAB如何实现PID?
    受欢迎的奶牛
  • 原文地址:https://blog.csdn.net/weixin_54342360/article/details/125944801