文章目录
一、SpringBoot简介
1、Spring能做什么
1.1、Spring的能力
1.2、Spring的生态
https://spring.io/projects/spring-boot
覆盖了:web开发、数据访问、安全控制、分布式、消息服务、移动开发、批处理 …
1.3、Spring5重大升级
1.3.1、响应式编程
1.3.2、内部源码设计
基于Java8的一些新特性,如:接口默认实现。重新设计源码架构。
2、为什么用SpringBoot
作用:能快速创建出生产级别的Spring应用(帮我们整合其他的spring的框架)
SpringBoot底层是Spring Framework(spring框架),spring的底层是java
2.1、SpringBoot作用
-
创建独立Spring应用
-
内嵌web服务器
-
自动starter依赖,简化构建配置(解决了整合之间jar包的版本问题)
-
自动配置Spring以及第三方功能(自动的整合其他的框架)
-
提供生产级别的监控、健康检查及外部化配置
-
无代码生成、无需编写XML(不用再写配置文件了)
SpringBoot是整合Spring生态圈技术栈的一站式框架
SpringBoot是简化Spring生态圈技术栈的快速开发脚手架(脚手架:帮我们搭建好所有的东西,只需要关注自己的业务就可以了)
2.2、SpringBoot缺点
- 人称版本帝,迭代快,需要时刻关注变化
- 封装太深,内部原理复杂,不容易精通
3、时代背景
3.1、微服务
James Lewis and Martin Fowler (2014) 提出微服务完整概念。https://martinfowler.com/microservices/
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交互
- 服务围绕业务功能拆分
- 可以由全自动部署机制独立部署
- 去中心化,服务自治。服务可以使用不同的语言、不同的存储技术
3.2、分布式
分布式的困难
- 远程调用
- 服务发现
- 负载均衡
- 服务容错
- 配置管理(同一服务的服务器进行统一的配置管理)
- 服务监控
- 链路追踪
- 日志管理
- 任务调度
- …
分布式的解决
- SpringBoot + SpringCloud
3.3、云原生
原生应用如何上云。 Cloud Native
上云的困难
- 服务自愈
- 弹性伸缩
- 服务隔离
- 自动化部署
- 灰度发布
- 流量治理
- …
上云的解决
4、如何学习SpringBoot
4.1、官网文档架构
官方网站:https://spring.io/
1、各种版本的查看
2、对应某个版本的学习
3、springboot的资源清单(到底能配置哪些东西)
5、查看版本新特性;
https://github.com/spring-projects/spring-boot/wiki#release-notes