Spring Boot核心之基本配置、日志配置、自动配置、条件注解

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: Spring Boot核心之基本配置、日志配置、自动配置、条件注解

Spring Boot的基本配置


启动类和核心注解


Spring Boot应用通常都有一个名为*Application的程序入口类 该入口类需要使用Spring Boot的核心注解@SpringBootApplicaiton标注为应用的启动类 该入口类有一个标准的Java应用程序的main方法 代码如下

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


Spring Boot的全局配置文件


1:设置端口号


例如在项目的src/main/resources目录下找到名为application.properties的全局配置文件 添加如下配置文件


server.port=8888


可以将内嵌的Tomcat的默认端口改为8888


2:设置Web应用的上下文路径


同样在application.properties文件下配置如下内容


server.servlet.context-path=/xxx


Spring Boot的Starters


Spring Boot提供了很多简化企业级开发的开箱即用的Starters 可以自动关联项目开发所需要的相关依赖 如在pom.xml中添加如下配置 则Spring Boot将会自动关联Web开发的相关依赖

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-web</artifactId>
</dependency>


读取应用配置


Spring Boot提供了三种方式读取项目的application.properties配置文件的内容 分别是Environment类 @Value注解以及@ConfigurationProperties注解


1:Environment


Environment是一个通用的读取应用程序运行时环境变量的类 可以通过key-value方式读取


快速创建一个Spring Boot Web应用 如果不会可以参考我这篇文章


快速构建Spring Boot


在application.properties文件中加入


test.msg=read config


创建一个名为EnvReaderConfigController的类 代码如下

package com.test.ch3_2.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.core.env.Environment;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class EnvReaderConfigController {
@Autowired
private Environment env;
@RequestMapping("/testEnv")
public String testEnv() {
  return "方法一"+env.getProperty("test.msg");
}
}


在运行main方法 发现配置已经读进去了


2:@Value


使用@Value注解读取配置文件内容示例代码如下

@Value ("${test.msg})
private String msg;


3:@ConfigurationProperties


使用它则首先建立配置文件与对象的映射关系 然后在控制器方法中使用@Autowired注解将对象注入 首先在application.properties加入以下代码


obj.sname=chenheng

obj.sage=88


创建StudentProperties类

package com.ch.ch4_1.model;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
@Component//使用Component注解,声明一个组件,被控制器依赖注入
@ConfigurationProperties(prefix = "obj")//obj为配置文件中key的前缀
public class StudentProperties {
  private String sname;
  private int sage;
  public String getSname() {
  return sname;
  }
  public void setSname(String sname) {
  this.sname = sname;
  }
  public int getSage() {
  return sage;
  }
  public void setSage(int sage) {
  this.sage = sage;
  }
  @Override
    public String toString() {
        return "StudentProperties [sname=" + sname + ", sage=" + sage + "]";
    }
}


创建ConfigurationPropertiesController类

package com.ch.ch4_1.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import com.ch.ch4_1.model.StudentProperties;
@RestController
public class ConfigurationPropertiesController {
  @Autowired
  StudentProperties studentProperties;
  @RequestMapping("/testConfigurationProperties")
  public String  testConfigurationProperties() {
   return studentProperties.toString();
  }
}


日志配置


默认情况下 Spring Boot项目使用LogBack实现入职 使用apache Commons Logging作为日志接口 因此代码中通常如下使用日志

package com.ch.ch4_1.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.core.env.Environment;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class LogTestController{
   private Log log=LogFactory.getLog(LogTestController.class);
  @RequestMapping("/testLog")
 public String testLog(){
 log.info("测试日志);
return "测试日志";
}
}


Spring Boot的自动配置原理


Spring Boot是通过加载所有META-INF/spring.factories配置文件进行自动配置的 所以@SpringBootApplication注解通过使用@EnableAutoConfiguration注解自动配置的原理是:从classpath中搜索所有META-INF/spring.factories配置文件并将其中,并将其中org.springframework.boot.autoconfigure.EnableAutoConfigturation对应的配置项通过Java反射机制进行实例化,然后汇总并加载到Spring的IOC容器


Spring Boot的条件注解


所谓Spring的条件注解 就是应用程序的配置类的配置项 在满足某些特定条件后才会被自动启用


下图所有的条件注解都是组合了@Conditional元注解 只是针对不同的条件去实现


1666445119540.jpg

1666445129400.jpg





 


相关实践学习
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
相关文章
|
1月前
|
监控 安全 程序员
Python日志模块配置:从print到logging的优雅升级指南
从 `print` 到 `logging` 是 Python 开发的必经之路。`print` 调试简单却难维护,日志混乱、无法分级、缺乏上下文;而 `logging` 支持级别控制、多输出、结构化记录,助力项目可维护性升级。本文详解痛点、优势、迁移方案与最佳实践,助你构建专业日志系统,让程序“有记忆”。
215 0
|
2月前
|
缓存 监控 Java
SpringBoot @Scheduled 注解详解
使用`@Scheduled`注解实现方法周期性执行,支持固定间隔、延迟或Cron表达式触发,基于Spring Task,适用于日志清理、数据同步等定时任务场景。需启用`@EnableScheduling`,注意线程阻塞与分布式重复问题,推荐结合`@Async`异步处理,提升任务调度效率。
511 128
|
1月前
|
JavaScript Java Maven
【SpringBoot(二)】带你认识Yaml配置文件类型、SpringMVC的资源访问路径 和 静态资源配置的原理!
SpringBoot专栏第二章,从本章开始正式进入SpringBoot的WEB阶段开发,本章先带你认识yaml配置文件和资源的路径配置原理,以方便在后面的文章中打下基础
269 3
|
1月前
|
XML Java 应用服务中间件
【SpringBoot(一)】Spring的认知、容器功能讲解与自动装配原理的入门,带你熟悉Springboot中基本的注解使用
SpringBoot专栏开篇第一章,讲述认识SpringBoot、Bean容器功能的讲解、自动装配原理的入门,还有其他常用的Springboot注解!如果想要了解SpringBoot,那么就进来看看吧!
351 2
|
2月前
|
XML Java 数据格式
常用SpringBoot注解汇总与用法说明
这些注解的使用和组合是Spring Boot快速开发和微服务实现的基础,通过它们,可以有效地指导Spring容器进行类发现、自动装配、配置、代理和管理等核心功能。开发者应当根据项目实际需求,运用这些注解来优化代码结构和服务逻辑。
288 12
|
2月前
|
缓存 Java 应用服务中间件
Spring Boot配置优化:Tomcat+数据库+缓存+日志,全场景教程
本文详解Spring Boot十大核心配置优化技巧,涵盖Tomcat连接池、数据库连接池、Jackson时区、日志管理、缓存策略、异步线程池等关键配置,结合代码示例与通俗解释,助你轻松掌握高并发场景下的性能调优方法,适用于实际项目落地。
529 5
|
2月前
|
传感器 Java 数据库
探索Spring Boot的@Conditional注解的上下文配置
Spring Boot 的 `@Conditional` 注解可根据不同条件动态控制 Bean 的加载,提升应用的灵活性与可配置性。本文深入解析其用法与优势,并结合实例展示如何通过自定义条件类实现环境适配的智能配置。
178 0
探索Spring Boot的@Conditional注解的上下文配置
|
2月前
|
智能设计 Java 测试技术
Spring中最大化@Lazy注解,实现资源高效利用
本文深入探讨了 Spring 框架中的 `@Lazy` 注解,介绍了其在资源管理和性能优化中的作用。通过延迟初始化 Bean,`@Lazy` 可显著提升应用启动速度,合理利用系统资源,并增强对 Bean 生命周期的控制。文章还分析了 `@Lazy` 的工作机制、使用场景、最佳实践以及常见陷阱与解决方案,帮助开发者更高效地构建可扩展、高性能的 Spring 应用程序。
129 0
Spring中最大化@Lazy注解,实现资源高效利用
|
消息中间件 SpringCloudAlibaba Java
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(八)Config服务配置+bus消息总线+stream消息驱动+Sleuth链路追踪
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(八)Config服务配置+bus消息总线+stream消息驱动+Sleuth链路追踪
1640 0
|
XML Java 数据库连接
【Spring学习笔记 五】Spring注解及Java类配置开发
【Spring学习笔记 五】Spring注解及Java类配置开发
189 0

热门文章

最新文章

下一篇
oss云网关配置