【SpringBoot学习笔记】(技术细节、架构、原理篇)(1)历史及简介

简介: 本文是个人的SpringBoot学习笔记。
本文首发于稀土掘金。该平台的作者 逐光而行 也是本人。

前身——Spring

对EJB规范(Enterprise Java Beans)的颠覆

EJB规范的缺点:程序员需要耗费大量时间精力实现该规范所要求的各种类,还要管理其生命周期,违背了“将精力放在业务功能本身上”的初衷。

为了解决这个问题,就有了Spring系列。

Spring核心概念

IoC(inversion of control)和DI(dependency injection)

从本质上看,IoC和DI描述的是同一个事情,都是使得被依赖着不再由依赖者直接创建,而是由专门的 容器 来管理,从而实现解耦。

AOP(aspect(切面) oriented programming)

什么是切面

切面是一组模块化的且可以被多个类复用的逻辑。

什么时候用切面?

当目标对象的一段程序在某个执行点的切入点被判定为真时,切面逻辑会被触发执行,并将切面和目标对象连接在一起,这个过程被称为weaving(织入)

作用

将业务逻辑和非业务逻辑分离

Q:SpringAOP和AspectJ的异同及联系?

同:AspectJ由Eclipse基金会发布,也是AOP思想的实现。
异:两者实现的原理以及最终目标不同。

  • SpringAOP可根据runtime的不同状态在java的动态代理技术或CGLIB代理技术之间切换;而AspectJ是在编译期和类装载期织入。
  • Spring系只是简单实现了Spring框架需要的AOP功能,而AspectJ是一个大而全的Java实现。

联系:Spring框架也支持AspectJ。

SpringBoot设计理念

Convention Over Configuration(约定大于配置)

大部分项目的配置都是相似的,所以可以将最佳实践(指业界专家大佬的经验)和默认配置进行自动化装配,如管理Spring应用中的各类Bean。

SpringBoot核心1——SpringBoot Starter

  • 用途:作为“开始”,它可以很方便地帮助人们创建项目,能用Maven Archetype做的事情,用Spring Initializer(就是官网上的那个项目创建页)一样能做,而且更方便,不需要程序员考虑集成软件时的版本兼容问题。
  • 实现:所有依赖被预先定义到pom.xml中,引用starter后,所需依赖就能自动添加到项目中。

starter的使用如图所示:

image.png

SpringBoot核心2——Auto Configuration

体现:以在pom.xml中增加一项配置为例

(昨晚我初次创建SpringBoot项目时,发现无法引用@RestController,经上网搜索解决方案,在pom.xml的依赖配置中新增了以下一项,再启动就成功了)

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

这个过程发生了什么

除了pom中的配置外,我并没有增加别的代码或配置,这说明SpringBoot自动完成了相应Bean的装配工作,减少了我设置配置文件的工作量。过程如下:

  • 应用启动时,扫描项目classpath中存在的框架类。
  • 检查显式配置。
  • 结合Condition自动完成相应Bean的装配。而Condition和@Conditional注解相联系,从而控制某个Bean是否被加载。

如何实现自动配置?

通过对源码分析可知:SpringBoot利用Condition对各种常用的开源框架定义了AutoConfiguration类,并将其放在spring-boot-autoconfigure-2.*.jar/META-INF/spring.factories中。项目启动时,会按照相应的condition判断是否需要注册相应的类到Spring Context。

(源码分析路径:EnableAutoConfiguration类,AutoConfigurationImportSelector类,spring-boot-autoconfigure-2.*.jar/META-INF/spring.factories)

SpringBoot核心3——Properties

  • 加载配置项:@ConfigurationProperties
  • 加载除默认的application.properties外的其他配置文件:@PropertySource
  • 默认配置的寻址路径是从里到外(从当前目录一直寻到根目录),其中最先开始找的优先级最高。虽然最后会采用最开始找到的那个,但并不是因为找到了就停止寻找,只是因为后面找到的优先级低,而高优先级会覆盖低优先级。
  • YML优先级高于application.properties
  • 可通过spring.config.name和spring.config.location改变SpringBoot配置的默认行为。

application.properties注入顺序

(越靠前优先级越高)

  • Devtools
  • @TestPropertySource
  • @SpringBootTest
  • 命令行指定参数。优先级:Java>spring
  • Servlet相关。优先级:Config>Context
  • JNDI
  • Java系统参数
  • 操作系统环境变量
  • RandomValuePropertySource随机数
  • jar包外的配置文件
  • @Configuration 上的@PropertySource参数
  • SpringApplication.setDefaultProperties

profile(spring框架本身就有)

  • 作用:将环境隔离开来。如开发环境和生产环境
  • 使用方法:可以添加多个不同的配置文件,并在启动应用时通过启动参数指定profile加载不同的文件。

spring.profiles.active=xx(yy)

SpringBoot核心4——Actuator

使用场景

项目已经部署上线,发现有问题,无法直接调试。

基础方案:JMX(Java Management Extension)

在SpringBoot中的封装方案:通过Actuator暴露和访问JMX的MBean。

配置方式

  • 在pom.xml中添加actuator相关的内容

效果

运行之后可以发现,控制台输出多了这一项:

image.png

点开Endpoint,可以看到如下内容:

image.png

可以通过在浏览器输入对应网址/点击选项中的内容选择用浏览器打开,查看结果。

如查看health时,该结果表示容器状况良好,运行正常。

image.png

两点注意事项:

  • 控制某个endpoint开放还是关闭:

在application.properties中添加如下代码:
management.endpoint.{endpointName}.enabled:true/false

  • 发现某个endpoint通过web直接访问时404 not found,如metrics:
management.endpoints.web.exposure.include=metrics

设置成功后网页如图所示
image.png

SpringBoot核心5——Embedded Container

SpringBoot无需配置容器,因为它内置了容器。

也可以通过一些操作将内置的容器换掉或者使SpringBoot部署在独立容器中。(不过我还暂时没有这方面的需求,就先放一放了,等用到再去了解操作,现在要知道理论上是可行的)

参考文献

  • SpringBoot官网
  • 《微服务从小白到专家》 姚秋晨 张昕 卿睿著
相关文章
|
2天前
|
存储 设计模式 架构师
编码之道:从技术细节到系统架构的升华
【5月更文挑战第9天】 在编程的世界里,每一行代码都承载着功能与美学的双重使命。本文将探讨如何从关注技术细节出发,逐步深化对系统架构的理解,并在实践中实现从代码编写者到系统设计师的转变。通过分析具体案例,我们将揭示那些看似平凡的技术感悟如何在复杂系统的构建中发挥关键作用,以及这一过程中对软件开发者的启示。
13 3
|
2天前
|
前端开发 Java 关系型数据库
Java医院绩效考核系统源码B/S架构+springboot三级公立医院绩效考核系统源码 医院综合绩效核算系统源码
作为医院用综合绩效核算系统,系统需要和his系统进行对接,按照设定周期,从his系统获取医院科室和医生、护士、其他人员工作量,对没有录入信息化系统的工作量,绩效考核系统设有手工录入功能(可以批量导入),对获取的数据系统按照设定的公式进行汇算,且设置审核机制,可以退回修正,系统功能强大,完全模拟医院实际绩效核算过程,且每步核算都可以进行调整和参数设置,能适应医院多种绩效核算方式。
20 2
|
7天前
|
负载均衡 API 数据库
构建高效微服务架构的五大关键技术
【5月更文挑战第4天】 随着云计算和容器化技术的成熟,微服务架构已成为软件开发的主流模式。本文将详细探讨实现高效微服务架构的五个关键技术点:服务拆分策略、API网关设计、服务发现与注册、熔断机制以及分布式事务管理。这些技术点是确保微服务系统可扩展性、灵活性及稳定性的基石,对于后端开发者而言,掌握它们至关重要。文章将提供具体的实施建议和最佳实践,帮助读者构建和维护高性能的微服务系统。
|
11天前
|
设计模式 Cloud Native 算法
拥抱变化:我的技术适应之旅构建未来:云原生架构在企业数字化转型中的关键角色
【4月更文挑战第30天】 在技术的浪潮中,我学会了不仅仅是编码,还有如何与时俱进。本文记录了我从一名初出茅庐的开发者成长为一个能够适应不断变化技术环境的工程师的心路历程。从最初的困惑与挑战到后来的接纳与创新,我意识到,技术能力的提升和心态的转变同样重要。
|
11天前
|
前端开发 JavaScript 安全
【TypeScript技术专栏】TypeScript在微前端架构中的应用
【4月更文挑战第30天】微前端架构通过拆分应用提升开发效率和降低维护成本,TypeScript作为静态类型语言,以其类型安全、代码智能提示和重构支持强化这一架构。在实践中,TypeScript定义公共接口确保跨微前端通信一致性,用于编写微前端以保证代码质量,且能无缝集成到构建流程中。在微前端架构中,TypeScript是保障正确性和可维护性的有力工具。
|
12天前
|
Java Docker 微服务
|
12天前
|
安全 Java 数据安全/隐私保护
Spring Boot优雅实现多租户架构:概念与实战
【4月更文挑战第29天】在多租户系统中,一个应用实例服务于多个租户,每个租户享有独立的数据视图,而应用的基础设施被共享。这样的架构不仅优化了资源使用,还能降低维护和运营成本。本文将详细介绍如何在Spring Boot中实现多租户架构,并提供具体的实战案例。
38 2
|
13天前
|
设计模式 供应链 安全
如何在短频快的节奏中做好技术?业务开发必会的架构思维
本文提供一种业务架构设计模式:从业务&技术两个角度提炼出一个基础思维框架,供业务线开发同学参考。
如何在短频快的节奏中做好技术?业务开发必会的架构思维
|
14天前
|
消息中间件 监控 微服务
【专栏】随着技术发展,未来将探索服务网格、容器化和云原生技术,以提升微服务架构的效能
【4月更文挑战第27天】本文探讨了构建高效微服务架构的后端开发最佳实践。微服务以服务独立、去中心化、自治和轻量级通信为核心原则,带来可扩展性、独立性、技术灵活性和团队协作优势。实践中,要注意服务拆分粒度、选择合适的通信协议(如RESTful、RPC、消息队列)、处理数据一致性与分布式事务、实施服务治理和监控,以及确保安全性与权限控制。随着技术发展,未来将探索服务网格、容器化和云原生技术,以提升微服务架构的效能。
|
16天前
|
Java Spring 容器
SpringBoot自动装配原理之@Import注解解析
SpringBoot自动装配原理之@Import注解解析
53 0