第1章 课程介绍
本章从整体上介绍课程有什么收获,以及课程如何安排,其中包括微服务的两个不同学习阶段--单体开发阶段(基于SpringBoot)和微服务改造阶段(基于SpringCloud),知识点梳理&问答:https://www.imooc.com/article/23408( & A3 d4 v- $ j3 I; c5 @
1-1 课程导学
$ Z Q9 s( y* l5 H7 ^5 q- Y
第2章 单体架构之项目概要设计&数据表设计
本章会带着大家对房产销售平台一功能、模型、流程三个方面进行需求分析,之后我们将抽取出项目中的功能模型,分析功能模型之间的关联关系,同时在本章我们会对房产销售平台单体架构进行技术选型和架构设计,学习到做好技术选型有哪些技巧;之后会进行数据库设计,将功能模型落地到数据库中,并手把手带着大家使用Navicat Premiu...' }8 `. a% f3 a, {: h* . S
2-1 项目需求分析
2-2 单体项目技术选型和架构设计" F& v& w" u& f+ W! r
2-3 数据库设计概述" W7 R' Y/ ~' m9 p6 p y z
2-4 房产表设计- x( O P- W" {6 R) j
2-5 房产用户表,房产信息表设计! W6 I- u: o B# U; F. p
2-6 用户表设计' m4 J0 Z, }* C0 D
2-7 小区表,评论表设计1 z& u- C8 M5 F- T8 R& D3 C2 M8 Q& I
2-8 博客表,经纪机构表设计_音频.mp4 l( R& M; j0 s9 d; v- w% l
: O+ h% C/ S7 ~3 G8 P6 U0 t
第3章 单体架构之SpringBoot工程框架搭建与技巧1 G( l- x6 y4 Q& K0 h. J- q* ]
本章首先手把手教大家搭建Java,Maven开发环境,安装IDE工具STS; 然后以多种方式创建SpringBoot工程,并讲解SpringBoot的几大特性,pom文件接入SpringBoot的不同方式,内嵌servlet容器的接入与替换,Starter(起步依赖)的实现原理,SpringBoot与Mybatis,Freemarker等组件的整合,SpringBoot进行错误页处理, 自定义Starter,让大家...
3-1 开发环境搭建与验证(jdk,maven,sts)- G! I, R. g& }. X
3-2 创建SpringBoot工程3 m* q" p& f)
3-3 引入内嵌servlet容器
3-4 数据访问层搭建-整合MyBatis3 m" j9 \% ?8 A5 o; x
3-5 数据访问层搭建—集成Druid连接池% h' U1 v4 L3 v# @
3-6 表现层搭建-整合freemarker* / S" Z- C& F9 J2 T- m
3-7 表现层搭建-freemaker结构化布局
3-8 SpringBoot起步依赖stater ?9 q; O! u6 ` h5 A& R. }6 d
3-9 自定义SpringBoot起步依赖stater
3-10 maven多mudule工程实现
3-11 错误页面处理
3-12 学习spring boot技巧分享* A4 ?3 |( _) B7 M0 j: y
) A; C" o! o1 k$ Y$ Q+ ]
第4章 单体架构之用户注册及个人页面功能开发
本章会深入剖析SpringMvc的请求处理流程,并借助Guava Cache完成注册key的绑定,同时会详细介绍Guava Cache的存储数量限制,过期设置,事件监听器,之后使用Spring Mail + Spring Task完成异步发送激活链接;并通过Nginx搭建支持用户头像等静态资源的访问,之后会讲解用户注册、用户登录、用户鉴权的业务流程,并编写Sp...
4-1 SpringMVC整体流程讲解
4-2 用户注册-功能演示与流程讲解. a( ~8 w0 R# k0 l; v% q8 x) Y+ V7 J
4-3 用户注册-后端代码实现-1/ f) B- M9 H1 P. k
4-4 用户注册-后端代码实现-2& l f6 ~6 A7 g) ^2 I' O
4-5 用户注册-guava cache及异步spring mail发送激活链接* I! |! f* R2 l
4-6 注册流程-安装ngnix-1( ~( f; `* O3 J$ ^1 b G7 R
4-7 注册流程-安装ngnix-27 k! M; R8 @1 K: @
4-8 登录流程-后端代码实现
4-9 用户登录流程-spring拦截器实现鉴权-1
4-10 用户登录流程-spring拦截器实现鉴权-2
4-11 spring拦截器编写步骤6 b) | m, [/ m! w
4-12 个人页面开发2 E4 G4 R s5 s* [5 }
4-13 SpringBoot单元测试
第5章 单体架构之房产和推荐功能开发(分页组件、Ajax、Redis)
本章我会封装一个后端分页组件来完成房产列表分页功能,并带领大家应用Ajax技术实现房屋的评分和收藏, 之后会讲解如何通过table join查询来实现房屋收藏列表, 使用Redis的sorted sort数据结构来实现热门推荐,使用Jedis客户端工具进行Redis操作,每个功能的实现我都会带大家由功能演示到代码实现再到验证测试,然后...; j" K$ P- O/ d8 M9 ]" L0 `3 |
5-1 房产列表实现-1% q/ A+ J0 S% C8 s) Z0 R% z6 w
5-2 房产列表实现-2' A- r" y% ]3 D+ |. |9 u8 N5 z8 Z C
5-3 房产列表实现-3
5-4 房产列表实现-4: B. {1 m! F' g0 p+ I
5-5 访问详情的实现, p, x/ _9 [3 m9 z
5-6 经纪人详情实现4 U4 p; Z7 o4 }. A
5-7 热门房产的实现
5-8 首页推荐的实现
5-9 添加房产实现-1
5-10 添加房产实现-2
5-11 添加房产实现-39 R, N! Z# P4 t" b; _
5-12 通过ajax实现收藏与评价
第6章 单体架构之上线部署和监控实战(SprinBoot插件和工具)
本章会介绍Spring-Boot-Maven-Plugin的特性,以及如何配置SpringBoot maven打包工具,并通过SprinBoot提供的maven Plugin工具进行打包, 之后会讲解如何在工程接入SpringActuator来监控我们的应用,当然除了内嵌的监控组件,还会带来大家一起搭建SpringBoot Admin作为我们的外部可视化监控平台,并介绍SpringBoot Admin...
6-1 单体架构上线部署
6-2 通过SpringbootActuator进行健康监控
6-3 通过Spring Admin搭建简单监控平台/ ~7 `6 z0 t$ M9 k! ]3 m. A
第7章 单体架构的不足和解决方案
本章会介绍单体架构的优势和不足,还会讲解微服务架构是如何解决单体架构的问题。微服务也会带来一些挑战,那微服务都面临哪些挑战,面对这些挑战我们应该怎么来做,微服务需要关注哪些方面,微服务的最佳实践是什么, SOA和微服务有什么区别,这些问题都将在本章中得到答案。...
7-1 单体架构的优势和不足
7-2 微服务架构的优势* z8 ]1 x! l( }/ G+ K* t
7-3 微服务架构的挑战
7-4 微服务最佳实践
5 N7 x+ [: a/ O" g) A. ?1 A
第8章 微服务架构之服务拆分、确定服务边界6 T) T; X+ C# m: K+ N
本章结合房产销售平台项目阐述微服务拆分的原则,如何在处理服务拆分又能同时满足需求迭代,如何在服务拆分时又兼顾业务模型和团队结构,康威定律在架构设计中的应用。 同时对于如何做好架构设计,一个系统的架构是否优秀需要进行哪些衡量;微服务架构下,我们如何进行数据库拆分等问题,在本章中都能得到答案。...8 u) g7 h6 O6 W) I
8-1 微服务拆分的原则和方法5 g# y1 `( b$ g5 M5 y" @: d
8-2 从建模到模块服务拆分3 D/ {' v1 n* X2 d
8-3 微服务数据库的拆分
8-4 微服务架构下如何保证数据一致性
- l4 m2 A/ h3 ?! s$ z2 z) P
第9章 微服务架构之SpringCloud技术栈的选型及架构设计
本章会介绍SpringCloud基础知识,SpringCloud套件组件,微服务的架构场景,在目前SpringBoot工程中接入SpringCloud。然后进行微服务架构设计,搭建一个支持微服务架构的脚手架,包含服务注册和发现组件Spring Cloud Eureka,服务通信组件RestTemplate以及二次封装,同时支持直连和服务发现,负载均衡组件Spring Cloud R..., F) g9 b0 `2 K; w8 e
9-1 技术选型及Spring Cloud介绍! }1 x0 ]7 q9 P- _5 P# R7 X
9-2 微服务技术架构设计& o) L a# y/ K+ c4 R9 o" V
9-3 Spring Cloud Eureka服务注册和发现-1
9-4 Spring Cloud Eureka服务注册和发现-2# f7 ]0 `7 X1 W2 K
9-5 Spring Cloud Eureka服务注册和发现-3
9-6 RestTemplate + httpclient及http日志输出-1# Z1 ^5 N- n6 H r6 f3 F+ h W
9-7 RestTemplate + httpclient及http日志输出-2
9-8 RestTemplate + httpclient及http日志输出-3# k! D, I; H) G# Z1 d
9-9 RestTemplate + httpclient及http日志输出-43 H; b- v3 S6 K& M( |! @* h/ y) `8 Y
9-10 Spring Cloud Ribbon负载均衡组件实战! n: U9 J! E" E8 w
9-11 微服务代码脚手架搭建-14 e6 l5 i2 w! _( Q# Z7 ]
9-12 微服务代码脚手架搭建-29 - z/ p" ~6 p! _
9-13 使用Feign实现服务调用【拓展知识】
( M# E. y0 x( [3 j2 P" i! {/ v3 u
第10章 微服务架构之用户服务实战(SpringData Redis及JWT等技术)
本章我将学习到用户服务的接口设计,接入Spring Data Redis缓存实现用户查询接口,并基于JWT(Json Web Token)实现身份认证和鉴权; 在介绍SpringData Redis之前我会带领大家一起安装Redis,并通过时序图详细讲解从基于Session到Token再到JWT进行身份认证方案的演进过程,详细分析各个方案都有什么优缺点,最终借助JW...9 S& H9 T: s; A
10-1 用户服务接口设计3 |9 ?! M+ V9 n+ D! C: o* `1 y' _
10-2 接入分布式缓存Spring Data Redis实现用户查询接口7 r$ X" G4 u% ~) p8 {" |' c z8 _) o
10-3 新增用户、激活用户接口设计
10-4 基于JWT的Token认证实现登录、鉴权接口-1) l; f; z( [3 h3 g. w+ u0 r
10-5 基于JWT的Token认证实现登录、鉴权接口-2
10-6 经纪人、经纪机构接口设计, w& ~1 ?- v5 O' ]
1 Y0 r3 W+ u, ?8 B" F+ H
第11章 微服务架构之网关服务API Gateway实战
本章将介绍微服务API Gateway模块的实现,首先我会介绍API Gateway的接口设计,并通过RestTemplate来调用我们的用户服务来完成用户注册、登录和登出,以及个人页的编写,以及和原生的RestTemplate比较,最后会带大家基于RestTemplate封装一个更加易用的RESTFul组件,包括状态码判断,异常处理,请求链接构建,响应结果反序列.... V% c# h% @: m4 q- z+ F5 b5 g
11-1 API Gateway—模块设计; Z' ?( }' G# O& a9 l
11-2 用户注册实现
11-3 通过jwt token替换session实现用户登录与鉴权
11-4 二次封装RestTemplate实现个人页展示* c" S: E' F. u
11-5 获取经纪人详情页! e' Z) e1 n, G# F% a. B$ K
8 y! F7 k; P5 R* O* ^3 K+ }
第12章 微服务架构之房产服务
本章我将介绍房产服务以及通过API Gateway调用房产服务实现房产功能,同时介绍房产服务的接口设计,并通过Swagger暴露接口文档,以及Swagger的接入过程,最后介绍API Gateway调用房产服务完成房产详情、房产收藏的实现过程。
12-1 房产服务接口设计. k+ u5 }; c5 r* c' p
12-2 新增房产接口, 收藏房产接口, h' ]( i8 * M! s! M) h5 ?8 I
12-3 房产查询接口设计
12-4 评分与留言接口设计& D( Z$ V1 {" u# E) s9 E+ a
12-5 房产推荐接口设计: I7 b( ]/ C$ X- ? ] [2 R) U
12-6 通过Swagger暴露接口文档% U$ n3 z5 a) X% m; N
12-7 返回房产列表房产详情(API Gateway调用房产服务)( D9 N$ t# b2 b- |9 e4 J
12-8 用户收藏房产实现(API Gateway调用收藏服务)8 |5 P% y5 N& d5 I: o, e* P
12-9 SpringBoot CORS跨域解决方案- J: b3 _* `/ b3 T* k; h
第13章 微服务架构之评论博客服务
本章我将介绍评论博客服务的接口设计。首先在博客评分服务编写出接口实现,然后通过API Gateway调用评论服务,展示评论列表,并通过API Gateway调用博客服务,展示博客列表。
13-1 接口设计
13-2 评论列表接口设计
13-3 展示评论列表(API Gateway调用评论服务)% @/ D" Q$ n O% Z% P
13-4 博客服务接口设计
13-5 博客列表及详情接口设计$ o) v' B& o! 5 k3 ~
13-6 展示博客列表(API Gateway调用博客服务)4 ; G8 w1 y5 ! M7 x( }
第14章 微服务架构之Spring Cloud Hystrix实现服务容错
本章我们将学习微服务经常遇到的问题----级联故障,并深入讲解级联故障发生的背景和原因,进而引出解决级联故障的解决方案---SpringCloud Hystrix断路器,并讲解Hystrix断路器相关概念(舱壁隔离、超时控制、服务降级、服务熔断),Hystrix断路器的工作流程,工程接入Hystrix的步骤,接入后我们会进行实际演示来验证Hystri...
14-1 Spring Cloud Hystrix断路器介绍
14-2 Spring Cloud Hystrix的接入-1
14-3 Spring Cloud Hystrix的接入-2) G3 Z% g% b1 e
14-4 Spring Cloud Hystrix工作原理/ C0 ?. G m& x1 M( i
]3 l- o. L E
第15章 微服务架构之全链路追踪、搭建ELK日志检索架构
本章我们将学习微服务的链路追踪和日志检索,首先介绍下全链路追踪的背景及 一些基本概念,引出并讲解解决方案Spring Cloud Sleuth,,之后日志配置文件如何修改输出TraceId、SpanId,并通过Zipkin Ui图形化查询链路调用情况,并讲解Spring Cloud Sleuth的工作原理, 对应日志检索,ELK架构所用的三种技术及数据流程,...
15-1 Spring Cloud Sleuth全链路追踪解决方案介绍7 J% |4 S; L3 d( u5 L
15-2 接入log4j2日志组件- f( Y" v1 l8 h( m, a
15-3 接入Spring Cloud Sleuth及与Zipkin配合使用
15-4 Spring Cloud Sleuth的工作原理
15-5 ELK架构介绍及ES、Kibana的搭建-日志检索方案5 M$ j- l( I' Z9 {; {
15-6 Logstash配置的编写和调试9 K* B- h: i# G, l* r5 B9 ^
15-7 Kibana展示平台的使用( j7 a) t7 D& K; Y9 {
第16章 课程总结" R( R# M; b) r5 F8 J
本章就到了课程的尾声了,微服务是致力于后端架构开发同学的必备技能,本章会通过脑图重新梳理单体和微服务架构知识图谱,让大家能够对前面学到的东西进行记忆强化,希望大家都能学以致用,学有所成,开启职业新篇章。...