SpringBoot的配置文件以及日志设置

在使用SpringBoot开发的过程中我们通常会用到配置文件来设置配置信息

以及使用日志来进行记录我们的操作,方便我们对错误的定位


配置文件的作用在于:设置端口,设置数据库连接信息,设置日志等等 

在SpringBoot中,配置文件必须要以application作为命名,

同时在SpringBoot中有两种配置文件格式

一种是application.properties,另一种是application.yml的格式

两种格式的区别在于properties是SpringBoot中默认的配置文件的格式

而yml格式支持多种语言的格式

以properties格式为例子:properties存储配置信息是以key-value的形式进行存储的

#配置项中设置端口号
server.port = 9090#配置项中设置数据库的连接
spring.datasource.url = jdbc:mysql//127.0.0.1:3306/java?characterEncoding=utf8
spring.datasource.username = root
spring.datasource.password = 8888#配置项中设置日志
logging.level.com.example.demo = debug
logging.file=d:/work/demo.log#配置项中设置对象中的属性
student.name = tom
student.id = 1
student.gender = man

properties格式的配置文件的缺点在于不能够支持多种语言,并且配置内容过于冗余

但是在springboot中properties的优先级是比yml要高的

而我们使用yml的形式就可以弥补properties的缺点了

#设置端口号
server:port: 9090#设置字段的内容
mystr1: 你\n好
mystr2: '你\n好'
mystr3: "你\n好"#设置对象的属性
student:id: 1name: 张三age: 18# 日志级别的设置
logging:level:root: errorcom:example:demo:controller: tracefile:path: D:\

上面提到的设置字段的内容,我们都是可以在class类里面进行调用的

不管是使用哪种配置文件都是使用 @Value(${xxxx})注解的形式进行调用

    @Value("${mystr1}")private String str1;@Value("${mystr2}")private String str2;@Value("${mystr3}")private String str3; //"xxx\nxxx" 只有这样才能进行换行

在yml中我们要想将字段进行换行打印就需要用到字符串以及转义字符,否则无法进行换行输出

我们还提到了在可以设置对象的属性进行注入

这个时候我们就需要在实体类中使用注解

@ConfigurationProperties("xxx") <-此处的xxx为配置文件中对象名称 

这样就可以进行属性注入了

@ConfigurationProperties("student")
@Controller
public class StudentController {private int id;private String name;private int age;
}

在实际开发的过程中我们通常有三个环境:开发环境、测试环境、生产环境

可能每个环境下我们的配置文件都不一样,但是代码是相同的

所以为了适配各个环境下的配置文件

我们可以创建一个公共的配置文件来调用不同环境下的配置环境

我们各个环境的配置文件都要以 application 开头然后加上各自的命名

比如开发环境:application-dev.yml 测试环境application-test.yml 生产环境application-prod.yml

在公共的配置文件 application.yml中只需要输入这段代码就可以调用到不同的配置环境了

#设置平台 比如此时我想设置成生产环境
spring:profiles:active: prod

讲完了配置文件我们来说说日志

我们可以使用日志来进行记录错误等信息,当然也可以记录程序的执行时间以及程序的操作人等等

实际上SpringBoot中内置了日志,我们每次在启动SpringBoot的时候都能看到一长串的日志内容

那么SpringBoot中的日志框架里面的内容可以分为:日志门面以及日志实现

日志门面就相当于是一个中间人,我们在调用日志门面以后日志门面会帮我们找到具体的日志实现的项目 ,在日志门面包括(SLF4J以及common-logging)

在日志中,日志的等级分为(从低到高进行排序):

[trace]:级别最低

[debug] :调试的时候进行打印的内容

[info]:普通打印信息

[warn]:警告信息但不影响使用

[error]:错误信息影响正常使用

[fatal]:不会打印出来,直接导致程序退出

我们可以在配置文件中设置我们想要看到的日志等级,比如

#yml格式下的日志配置logging:level: #只查看error及以上的日志信息 root:error 

我们也可以设置某一个包在运行过程的日志提示,比如

#yml格式下的日志配置logging:level: #只查看error及以上的日志信息 root:error com: example: #查看controller包底下在运行过程中trace及以上的日志信息 controller: trace

 那么现在再来讲讲应该怎么样使用日志

我们首先要实例化日志这个类然后再将需要打印日志的类

(比如我现在的UserController需要答应日志)

private static final Logger logger = LoggerFactory.getLogger(UserController.class);

然后就可以正常使用了

    @RequestMapping("/sayHi")public String sayHi(){logger.trace("trace");        //打印一个trace日志 日志内容是tracelogger.info("info");          //打印一个info日志 日志内容是infologger.warn("warn");          //打印一个warn日志 日志内容是warnlogger.error("error");        //打印一个error日志 日志内容是errorreturn "hello world";}

实际上我们如果调用Lombok这个框架的话

只需要加入 @Slf4j 这个注解就不需要再实例化日志对象了

然后日志对象的名称注意 一定是 log

接下来的步骤和正常使用没有区别

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/40504.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux系统编程:通过System V共享内存实现进程间通信

目录 一. 共享内存实现进程间通信的原理 二. 共享内存相关函数 2.1 共享内存的获取 shmget / ftok 2.2 共享内存与进程地址空间相关联 shmat 2.3 取消共享内存与进程地址空间的关联 shmdt 2.4 删除共享内存 shmctl 2.5 通信双方创建共享内存代码 三. 共享内存实现进程间…

承接各种设计

小弟985研究生毕业&#xff0c;目前攻读读博士&#xff0c;可做各种设计&#xff0c;包括但不限于Matlab 电力电子/电气工程&#xff0c;matlab/simulink 电气专业仿真MATLAB 电气工程专业&#xff0c;matlab建模 电力电子&#xff0c;电气工程&#xff0c;电力系统&#xff0c…

vue echarts macd指标 完整代码

1 逻辑 给指定的series两个对象 两个对象有相同的xAxisIndex: 2,yAxisIndex: 2, 不同的data {name: "",type: "line",data: data1,xAxisIndex: 2,yAxisIndex: 2,},{name: "",type: "bar",data: data2,xAxisIndex: 2,yAxisIndex: 2,},…

Mac M2 Pro安装使用Cocoapods

Mac Pro M2安装使用Cocoapods 在新公司要做iOS开发&#xff0c;所以在新电脑上安装Cocoapods 在升级gem&#xff0c;sudo gem update --system&#xff0c;和安装cocoapods时都遇到如下的提示&#xff1a; ERROR: While executing gem ... (Errno::EPERM)Operation not per…

Linux下安装nodejs

1、下载nodejs 点击前往&#xff1a;Download | Node.js 2、解压 tar -xvf node-v18.16.0-linux-x64.tar.xz mv node-v18.16.0-linux-x64/ /usr/local/nodejs 3、 建立软链接 此时的bin文件夹中已经存在node以及npm&#xff0c;如果你进入到对应文件的中执行命令行一点问题…

现代C++:使用 shared_from_this 防止 this 提前被释放

首先概括一下shared_from_this的作用&#xff1a;可以在类的成员函数中直接通过this得到指向当前所在对象的shared_ptr的智能指针&#xff0c;具体操作如下。 使用方法 设需要提供shared_from_this方法的类为C0定义为类&#xff0c;首先需要将C0定义为 std::enable_shared_fr…

mysql 02 数据库的约束

为防止错误的数据被插入到数据表&#xff0c;MySQL中定义了一些维护数据库完整性的规则&#xff1b;这些规则常称为表的约束。常见约束如下&#xff1a; 主键约束 主键约束即primary key用于唯一的标识表中的每一行。被标识为主键的数据在表中是唯一的且其值不能为空。这点类似…

前后端分离------后端创建笔记(10)用户修改

本文章转载于【SpringBootVue】全网最简单但实用的前后端分离项目实战笔记 - 前端_大菜007的博客-CSDN博客 仅用于学习和讨论&#xff0c;如有侵权请联系 源码&#xff1a;https://gitee.com/green_vegetables/x-admin-project.git 素材&#xff1a;https://pan.baidu.com/s/…

Spring Boot实现第一次启动时自动初始化数据库流程详解

随着互联网的发展项目中的业务功能越来越复杂&#xff0c;有一些基础服务我们不可避免的会去调用一些第三方的接口或者公司内其他项目中提供的服务&#xff0c;但是远程服务的健壮性和网络稳定性都是不可控因素。 在测试阶段可能没有什么异常情况&#xff0c;但上线后可能会出…

设计HTML5文本

网页文本内容丰富、形式多样&#xff0c;通过不同的版式显示在页面中&#xff0c;为用户提供最直接、最丰富的信息。HTML5新增了很多文本标签&#xff0c;它们都有特殊的语义&#xff0c;正确使用这些标签&#xff0c;可以让网页文本更严谨、更符合语义。 1、通用文本 1.1、标…

算法竞赛备赛之搜索与图论训练提升,暑期集训营培训

目录 1.DFS和BFS 1.1.DFS深度优先搜索 1.2.BFS广度优先搜索 2.树与图的遍历&#xff1a;拓扑排序 3.最短路 3.1.迪杰斯特拉算法 3.2.贝尔曼算法 3.3.SPFA算法 3.4.多源汇最短路Floy算法 4.最小生成树 4.1.普利姆算法 4.2.克鲁斯卡尔算法 5.二分图&#xff1a;染色法…

7. CSS(四)

目录 一、浮动 &#xff08;一&#xff09;传统网页布局的三种方式 &#xff08;二&#xff09;标准流&#xff08;普通流/文档流&#xff09; &#xff08;三&#xff09;为什么需要浮动&#xff1f; &#xff08;四&#xff09;什么是浮动 &#xff08;五&#xff09;浮…

OpenAI全球招外包大军,手把手训练ChatGPT取代码农 ; 码农:我自己「杀」自己

目录 前言 OpenAI招了一千多名外包人员&#xff0c;训练AI学会像人类一样一步步思考。如果ChatGPT「学成归来」&#xff0c;码农恐怕真的危了&#xff1f; 码农真的危了&#xff01; 当时OpenAI也说&#xff0c;ChatGPT最合适的定位&#xff0c;应该是编码辅助工具。 用Cha…

计算机竞赛 opencv 图像识别 指纹识别 - python

0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; 基于机器视觉的指纹识别系统 &#x1f947;学长这里给一个题目综合评分(每项满分5分) 难度系数&#xff1a;3分工作量&#xff1a;3分创新点&#xff1a;4分 该项目较为新颖&#xff0c;适…

Vue引入Echarts报错 import * as echarts from “echarts“;

项目场景&#xff1a; 已经下载好echarts cnpm i echarts Vue引入Echarts import echarts from echarts mounted() {this.myChart echarts.init(document.querySelector(.right))this.myChart.setOption({title: {text: 消费列表,left: center},...问题描述 原因分析&#…

【100天精通python】Day38:GUI界面编程_PyQT从入门到实战(中)

目录 专栏导读 4 数据库操作 4.1 连接数据库 4.2 执行 SQL 查询和更新&#xff1a; 4.3 使用模型和视图显示数据 5 多线程编程 5.1 多线程编程的概念和优势 5.2 在 PyQt 中使用多线程 5.3 处理多线程间的同步和通信问题 5.3.1 信号槽机制 5.3.2 线程安全的数据访问 Q…

日常BUG——通过命令行创建vue项目报错

&#x1f61c;作 者&#xff1a;是江迪呀✒️本文关键词&#xff1a;日常BUG、BUG、问题分析☀️每日 一言 &#xff1a;存在错误说明你在进步&#xff01; 一、问题描述 在使用vue命令行创建一个vue项目时&#xff0c;出现一下的错误&#xff1a; vue create my…

UDP数据报结构分析(面试重点)

在传输层中有UDP和TCP两个重要的协议&#xff0c;下面将针对UDP数据报的结构进行分析 UDP结构图示 UDP报头结构的分析 UDP报头有4个属性&#xff0c;分别是源端口&#xff0c;目的端口&#xff0c;UDP报文长度&#xff0c;校验和&#xff0c;它们都占16位2个字节&#xff0c;所…

【java面向对象中static关键字】

提纲 static修饰成员变量static修饰成员变量的应用场景static修饰成员方法static修饰成员方法的应用场景static的注意事项static的应用知识&#xff1a;代码块static的应用知识&#xff1a;单例设计模式 static静态的意思&#xff0c;可以修饰成员变量&#xff0c;成员方法&a…

FPGA_学习_14_第一个自写模块的感悟和ila在线调试教程与技巧(寻找APD的击穿偏压)

前一篇博客我们提到了&#xff0c;如果要使用算法找到Vbr&#xff0c;通过寻找APD采集信号的噪声方差的剧变点去寻找Vbr是一个不错的方式。此功能的第一步是在FPGA中实现方差的计算&#xff0c;这个我们已经在上一篇博客中实现了。 继上一篇博客之后&#xff0c;感觉过了很久了…