【SpringBoot从入门到精通】01_SpringBoot概述

一、Spring与SpringBoot

1.1 Spring

Spring 是一款目前主流的 Java EE 轻量级开源框架,是 Java 世界最为成功的框架之一。Spring 由“Spring 之父”Rod Johnson(罗宾·约翰逊) 提出并创立,其目的是用于简化 Java 企业级应用的开发难度和开发周期。

  • 广义的 Spring 泛指以 Spring Framework 为核心的 Spring 技术栈;
  • 狭义的 Spring 特指 Spring Framework,通常我们将它称为 Spring 框架;
  • Spring官网:https://spring.io/

Spring是如何简化Java开发的

为了降低Java开发的复杂性,Spring采用了以下4种关键策略:

  1. 基于POJO的轻量级和最小侵入性编程,所有东西都是bean;
  2. 通过IOC,依赖注入(DI)和面向接口实现松耦合;
  3. 基于切面(AOP)进行声明式编程;
  4. 通过切面和模版减少样式代码,比如:JDBCTemplate;

Spring的能力

在这里插入图片描述

  1. Microservices 微服务:通过可独立开发的微服务快速交付生产级功能。SpringBoot的特性使得在生产环境中大规模构建和运行微服务变得非常容易。而SpringCloud则在此基础上,帮助微服务应用进一步减轻管理并提高容错能力。

  2. Reactive 响应式编程:Spring 的异步,非阻塞架构意味着您可以使用少量资源(线程、CPU、内存),开发一个高吞吐量、高并发的应用。

  3. Cloud 云端技术:开发分布式微服务系统具有一定的挑战性,复杂性从应用层转移到网络层,并要求在服务之间进行更多的交互。SpringCloud包含使应用程序在云中运行所需的众多服务,帮助构建云原生。

  4. Web apps Web应用程序:这是我们最常用的一个模块,Spring提供了SpringMVC,让我们摆脱了以前使用Servlet的那种繁琐的开发方式,以更简洁和更优雅的API,来完成Web应用程序的开发。

  5. Serverless 无服务器编程:Serverless的全称是Serverless computing无服务器运算,又被称为函数即服务(Function-as-a-Service,缩写为 FaaS),是云计算的一种模型。以平台即服务(PaaS)为基础,无服务器运算提供一个微型的架构,终端客户不需要部署、配置或管理服务器服务,代码运行所需要的服务器服务皆由云端平台来提供。Spring Cloud Function提供让Spring开发人员利用无服务器或FaaS平台的功能。

  6. Event Driven 事件驱动:对业务事件做出反应,实时处理您的流数据。事件驱动系统反映了现代企业的实际工作方式,在微服务应用架构中被广泛使用。Spring帮助开发人员能够围绕事件构建应用程序, Spring有很多事件驱动项目,比如Streaming,Integration和Data Flow等。

  7. Batch 批处理:批处理具有高效处理大量数据的能力, Spring Batch的标准处理模式帮助开发者在JVM上构建健壮的批处理作业和关键任务应用程序。

Spring的生态

https://spring.io/projects/spring-boot

覆盖了:

  • web开发
  • 数据访问
  • 安全控制
  • 分布式
  • 消息服务
  • 移动开发
  • 批处理

Spring5重大升级

响应式编程

在这里插入图片描述

上图是Spring官方给出的SpringMVC和Spring WebFlux的对比图,先看最上面的描述信息:

  • 右侧是Spring MVC的描述:Spring MVC构建在Servlet API之上,使用同步阻塞I/O架构,每个线程一个请求模型。

  • 左边是Spring WebFlux的描述:Spring WebFlux是一个从头开始构建的非阻塞web框架,它利用多核、新一代处理器并处理大量并发连接。

Spring WebFlux 作为一个响应式 (reactive-stack) web 框架补充,在 5.0 的版本开始加入到 Spring 全家桶。

这是一个完全非阻塞的,支持 Reactive Streams,运行在诸如 Netty,Undertow,以及 Servlet 3.1+ 容器上的。Spring WebFlux 可以让你使用更少的线程去处理并发请求,同时能够让你使用更少的硬件资源来拓展你的应用。

Spring MVC or WebFlux?

WebFlux 并不是 Spring MVC 替代,它主要应用还是在异步非阻塞编程模型上。如果你的项目并不是该模型或者你的应用目前本身已经足够应付当前情况,是不需要去切换成 WebFlux 的。

内部源码设计

基于Java8的一些新特性,重新设计源码架构。

使用Spring Framework 5.0,基准版本是Java 8。Spring Framework代码现在已升级为使用Java 8中的新特性。会改进更可读和更有效的框架代码。

使用的一些Java 8特性如下:

  • 核心Spring接口中的Java8 static 方法;
  • 基于Java 8反射增强的内部代码改进;
  • 接口默认实现;
  • 在框架代码中使用函数式编程——lambda表达式和stream流。

1.2 SpringBoot

什么是SpringBoot

Spring Boot makes it easy to create stand-alone, production-grade Spring based Applications that you can “just run”.

Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置

简单来说就是能快速创建出生产级别的Spring应用,简化开发,约定大于配置, you can “just run”,能迅速的开发web应用,几行代码开发一个http接口。

所有的技术框架的发展似乎都遵循了一条主线规律:从一个复杂应用场景衍生一种规范框架,人们只需要进行各种配置而不需要自己去实现它,这时候强大的配置功能成了优点;发展到一定程度之后,人们根据实际生产应用情况,选取其中实用功能和设计精华,重构出一些轻量级的框架;之后为了提高开发效率,嫌弃原先的各类配置过于麻烦,于是开始提倡“约定大于配置”,进而衍生出一些一站式的解决方案。

是的,这就是Java企业级应用->JavaEE->Spring->SpringBoot的过程。

随着 Spring 不断的发展,涉及的领域越来越多,项目整合开发需要配合各种各样的文件,慢慢变得不那么易用简单,违背了最初的理念,甚至人称配置地狱。Spring Boot 正是在这样的一个背景下被抽象出来的开发框架,目的为了让大家更容易的使用 Spring 、更容易的集成各种常用的中间件、开源软件;

SpringBoot优缺点

优点
  • Create stand-alone Spring applications
    • 创建独立Spring应用
  • Embed Tomcat, Jetty or Undertow directly (no need to deploy WAR files)
    • 内嵌web服务器
  • Provide opinionated ‘starter’ dependencies to simplify your build configuration
    • 自动starter依赖,简化构建配置
  • Automatically configure Spring and 3rd party libraries whenever possible
    • 自动配置Spring以及第三方功能
  • Provide production-ready features such as metrics, health checks, and externalized configuration
    • 提供生产级别的监控、健康检查及外部化配置
  • Absolutely no code generation and no requirement for XML configuration
    • 无代码生成、无需编写XML
  • SpringBoot是整合Spring技术栈的一站式框架,SpringBoot是简化Spring技术栈的快速开发脚手架;
缺点
  • 人称版本帝,迭代快,需要时刻关注变化;
  • 封装太深,内部原理复杂,不容易精通;

总结

概念:SpringBoot是一个用于快速敏捷的搭建Spring项目的脚手架;

作用: SpringBoot是为了快速创建一个大型的Spring项目;

优点:快速搭建、开箱即用、内嵌容器、零配置、微服务基础;

核心:自动装配、场景启动器。

SpringBoot时代背景

微服务

James Lewis and Martin Fowler (2014) 提出微服务完整概念。

In short, the microservice architectural style is an approach to developing a single application as a suite of small services, each running in its own process and communicating with lightweight mechanisms, often an HTTP resource API. These services are built around business capabilities and independently deployable by fully automated deployment machinery. There is a bare minimum of centralized management of these services, which may be written in different programming languages and use different data storage technologies.-- James Lewis and Martin Fowler (2014)

  • 微服务是一种架构风格;
  • 一个应用拆分为一组小型服务;
  • 每个服务运行在自己的进程内,也就是可独立部署和升级;
  • 服务之间使用轻量级HTTP交互;
  • 服务围绕业务功能拆分;
  • 可以由全自动部署机制独立部署;
  • 去中心化,服务自治。服务可以使用不同的语言、不同的存储技术;

英文文档:https://martinfowler.com/microservices/

简体中文:https://blog.cuicc.com/blog/2015/07/22/microservices/

分布式

在这里插入图片描述

分布式的困难

  • 远程调用:每个服务独立部署,一般使用http进行服务交互;
  • 服务发现:就是看哪些服务是可用的,可能存在服务故障;
  • 负载均衡:按照配置的算法合理的将请求分配给不同的服务器;
  • 服务容错:各种错误情况下的处理方式,比如非代码问题,而是因为网络问题导致访问失败;
  • 配置管理:配置中心,修改配置让服务们自己同步;
  • 服务监控:多个服务以及云平台的资源消耗和健康状况;
  • 链路追踪:在服务调用过程中,如果某个服务出错,需要找到什么原因导致的出错;
  • 日志管理:在分布式环境下,如果实现日志管理;
  • 任务调度:比如我们想要让A服务执行定时任务,是所有的A服务执行还是某些执行;执行的方式是以串行还是并行的;

分布式的解决

  • SpringBoot + SpringCloud
    • SpringBoot:快速构建Spring应用;
    • SpringCloud:协调任何事情,分布式治理方案;

在这里插入图片描述

云原生

原生应用如何上云。 Cloud Native

上云的困难

  • 服务自愈:一个服务出现错误怎么复原;
  • 弹性伸缩:根据不同的性能需求分配更多的服务器;
  • 服务隔离:服务之间不相互影响;
  • 自动化部署:服务自动化部署;
  • 灰度发布:同样的服务有多台服务器运行,先把服务部署在其中一两台上看运行效果,没有问题了再慢慢全部升级;
  • 流量治理:根据服务器性能,进行流量的限制;

上云的解决

  • Docker + Kubernetes…

如何学习SpringBoot

官网文档架构

在这里插入图片描述

查看版本新特性:https://github.com/spring-projects/spring-boot/wiki#release-notes

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Windows下安装使用Squirrel

引言 SQuirrel SQL Client是一个用Java写的数据库客户端,用JDBC统一数据库访问接口以后,可以通过一个统一的用户界面来操作MySQL PostgreSQL MSSQL Oracle等等任何支持JDBC访问的数据库。使用起来非常方便。而且,SQuirrel SQL Client还是一个典型的Swing程序。 如果您的工作…

基于单片机锂电池电量检测数码管显示系统设计

**单片机设计介绍,基于单片机锂电池电量检测数码管显示系统设计 文章目录 一 概要二、功能设计设计思路 三、 软件设计原理图 五、 程序六、 文章目录 一 概要 基于单片机锂电池电量检测数码管显示系统设计的主要目标是实时、准确地检测锂电池的电量,并…

LDL^H分解求逆矩阵与MATLAB仿真(Right-Looking)

通过分解将对称正定厄米特矩阵分解成下三角矩阵L和对角矩阵D来求其逆矩阵 目录 前言 一、LDL^H基本算法 二、LDL^H Right-Looking算法 三、D矩阵求逆 四、L矩阵求逆 五、A矩阵求逆 六、计算量分析 七、MATLAB仿真 八、参考资料 总结 前言 在线性代数中,LDL…

2-HDFS常用命令及上传下载流程

HDFS NameNode 安全模式(safemode) 当NameNode被重启的时候,自动进入安全模式 在安全模式中,NameNode首先会触发edits_inprogress文件的滚动。滚动完成之后,更新fsimage文件 更新完成之后,NameNode会将fsimage文件中的元数据加…

(免费分享)基于springboot,vue付费自习室系统带论文

在当今数字化时代,高效、便捷的管理系统成为了各行各业不可或缺的工具。特别是在教育服务领域,自习室作为学生和在职人员重要的学习场所,其预约和管理需求日益增长。为了满足这一市场需求,本文开发了这款基于微信小程序的付费自习…

DC-5靶机

一.环境搭建 1.下载地址 靶机下载地址:https://download.vulnhub.com/dc/DC-5.zip 2.虚拟机配置 切换nat模式,有问题全选重试和是,打到这了,我感觉这个配置我都不用写了,启动靶机如下图所示即可 二.开始渗透 1.信…

设计模式 - 简单工厂模式

文章目录 前言 大家好,今天给大家介绍一下23种常见设计模式中的一种 - 工厂模式 1 . 问题引入 请用C、Java、C#或 VB.NET任意一种面向对象语言实现一个计算器控制台程序,要求输入两个数和运算符 号,得到结果。 下面的代码实现默认认为两个操作数为Inte…

2. Java基本语法

文章目录 2. Java基本语法2.1 关键字保留字2.1.1 关键字2.1.2 保留字2.1.3 标识符2.1.4 Java中的名称命名规范 2.2 变量2.2.1 分类2.2.2 整型变量2.2.3 浮点型2.2.4 字符型 char2.2.5 Unicode编码2.2.6 UTF-82.2.7 boolean类型 2.3 基本数据类型转换2.3.1 自动类型转换2.2.2 强…

报错:torch.distributed.elastic.multiprocessing.errors.ChildFailedError:

错误: torch.distributed.elastic.multiprocessing.errors.ChildFailedError: 这个主要是torch的gpu版本和cuda不适配 我的nvcc -V是11.8 torch使用的: pip install torch2.0.1 torchvision0.15.2 torchaudio2.0.2 --index-url https://download.pyt…

Day47:WEB攻防-PHP应用文件上传函数缺陷条件竞争二次渲染黑白名单JS绕过

目录 文件上传与测试环境安装 1、前端 JS 2、.htaccess(apache独有的配置文件) 3、MIME类型 4、文件头判断 5、黑名单-过滤不严 6、黑名单-过滤不严 7、低版本GET-%00截断 8、低版本POST-%00截断 9、黑名单-过滤不严 10、逻辑不严-条件竞争 11、二次渲染 12、函数…

Leetcoder Day43| 单调栈2

503.下一个更大元素II 给定一个循环数组(最后一个元素的下一个元素是数组的第一个元素),输出每个元素的下一个更大元素。数字 x 的下一个更大的元素是按数组遍历顺序,这个数字之后的第一个比它更大的数,这意味着你应该…

2024最新Guitar Pro 8.1中文版永久许可证激活

Guitar Pro是一款非常受欢迎的音乐制作软件,它可以帮助用户创建和编辑各种音乐曲谱。从其诞生以来就送专门为了编写吉他谱而研发迭代的。 尽管这款产品可能已经成为全球最受欢迎的吉他打谱软件,在编写吉他六线谱和乐队总谱中始终处于行业领先地位&#x…

大话设计模式之原型模式

原型模式(Prototype Pattern)是一种创建型设计模式,它用于创建对象的复制,同时又能保持对象的封装。原型模式通过复制现有对象的方式来创建新的对象,而无需知道具体创建过程的细节。 在原型模式中,通常会有…

Excel·VBA数组分组问题

看到一个帖子《excel吧-数据分组问题》,对一组数据分成4组,使每组的和值相近 目录 代码思路1,分组形式、可分组数代码1代码2代码2举例 2,数组所有分组形式举例 这个问题可以转化为2步:第1步,获取一组数据…

【大数据运维】minio 常见shell操作

文章目录 1. 安装2. 入门操作3. 命令帮助 1. 安装 下载 https://dl.min.io/client/mc/release/linux-amd64/ 赋权与使用 cp mc /usr/bin && chmod x /usr/bin/mc ./mc --help 2. 入门操作 # 添加minio到mc mc config host add minio_alias_name endpoint_adress …

SpringBoot动态数据源实现

一、背景 一个应用难免需要连接多个数据库,像我们系统起码连接了5个以上数据库,AWS RDS主库,ECS自搭MySQL从库,工厂系统三个SQLServer数据库,在线网站MySQL数据库,记得很早以前是用SessionFactory配置&…

Java中有哪些容器(集合类)?

Java中的集合类主要由Collection和Map这两个接口派生而出,其中Collection接口又派生出三个子接 口,分别是Set、List、Queue。所有的Java集合类,都是Set、List、Queue、Map这四个接口的实现 类,这四个接口将集合分成了四大类&#…

C语言--编译和链接

1.翻译环境 计算机能够执行二进制指令,我们的电脑不会直接执行C语言代码,编译器把代码转换成二进制的指令; 我们在VS上面写下printf("hello world");这行代码的时候,经过翻译环境,生成可执行的exe文件&…

WebGIS概述

1.地图组成 底图(Map): 所有信息的载体 图层(Layer):将不同地理信息分类形成的一个集合 要素(Feature):表示不同的地物 几何(Geometry): 信息的数据模型和抽象 2.地图容器Container 即在准备阶段所创建的指定了id的div对象,这个div将作为承载所有图层、点标记、矢量…

分布式部署LNMP+WordPress

需要四台虚拟机,实际上,我们只需要操作三台 一个数据库,一个nginx,一个php,还需要准备一个软件包wordpress-4.7.3-zh_C 首先配置nginx的服务环境 [rootnginx ~]# vi /usr/local/nginx/conf/nginx.conf 修改文件中的loc…