一、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种关键策略:
- 基于POJO的轻量级和最小侵入性编程,所有东西都是bean;
- 通过IOC,依赖注入(DI)和面向接口实现松耦合;
- 基于切面(AOP)进行声明式编程;
- 通过切面和模版减少样式代码,比如:JDBCTemplate;
Spring的能力
-
Microservices 微服务:通过可独立开发的微服务快速交付生产级功能。SpringBoot的特性使得在生产环境中大规模构建和运行微服务变得非常容易。而SpringCloud则在此基础上,帮助微服务应用进一步减轻管理并提高容错能力。
-
Reactive 响应式编程:Spring 的异步,非阻塞架构意味着您可以使用少量资源(线程、CPU、内存),开发一个高吞吐量、高并发的应用。
-
Cloud 云端技术:开发分布式微服务系统具有一定的挑战性,复杂性从应用层转移到网络层,并要求在服务之间进行更多的交互。SpringCloud包含使应用程序在云中运行所需的众多服务,帮助构建云原生。
-
Web apps Web应用程序:这是我们最常用的一个模块,Spring提供了SpringMVC,让我们摆脱了以前使用Servlet的那种繁琐的开发方式,以更简洁和更优雅的API,来完成Web应用程序的开发。
-
Serverless 无服务器编程:Serverless的全称是Serverless computing无服务器运算,又被称为函数即服务(Function-as-a-Service,缩写为 FaaS),是云计算的一种模型。以平台即服务(PaaS)为基础,无服务器运算提供一个微型的架构,终端客户不需要部署、配置或管理服务器服务,代码运行所需要的服务器服务皆由云端平台来提供。Spring Cloud Function提供让Spring开发人员利用无服务器或FaaS平台的功能。
-
Event Driven 事件驱动:对业务事件做出反应,实时处理您的流数据。事件驱动系统反映了现代企业的实际工作方式,在微服务应用架构中被广泛使用。Spring帮助开发人员能够围绕事件构建应用程序, Spring有很多事件驱动项目,比如Streaming,Integration和Data Flow等。
-
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