Java-Interview-Advanced/docs/distributed-system/core-architecture-principle .md

45 lines
3.1 KiB
Markdown
Raw Normal View History

2020-04-25 11:55:58 +00:00
如果聊分布式这块的技术,围绕**Dubbo来拷问**的,但是呢,现在其实非常流行的是**Spring CloudDubbo和Spring Cloud以及阿里系的一些技术**,现在正在融合,**Spring Cloud Alibaba只不过现在用的公司暂时还没那么多而已**
作为合格的工程师,行业里主流的**分布式服务技术栈****Dubbo**和**Spring Cloud**两种,有的公司他是用**Dubbo**的,不用**Spring Cloud**的,有的公司是用**Spring Cloud**的,不用**Dubbo**的,他们是代表了两种主流技术栈
Java工程师Dubbo和Spring Cloud起码是基本原理都有一定的了解
**大白话 + 现场画图**
上网看一些博客资料或者是买一些Spring Cloud的书可能没考虑过一个事儿第一篇必须是用非常通俗的语言把一个系统如果用Spring Cloud来做分布式架构的话那么他需要用到Spring Cloud哪些组件为什么
跟着书或者博客直接上手开始搭建demo开始做起来了
**分别用Dubbo和Spring Cloud做两个最基本的Demo工程**,用电商背景来搭建几个服务
比如说,现在我们有一个电商系统
用户现在需要下单购买一些东西这样子,订单系统、库存系统、仓储系统、积分系统
不太可能说用单块的架构电商系统你想支撑多少用户量10万注册用户日活1000用户来你这里来购买
百万级用户,十万级日活,单块系统就不太合适了,背后有几十个人的团队在协作开发,此时单块系统是绝对不合适的
梳理和明确一个概念:电商系统,拆分为了多个子系统,一次下订单的请求需要多个子系统协作完成,每个子系统都完成一部分的功能,多个子系统分别完成自己负责的事情,最终这个请求就处理完毕
我们不会让每个视频太长按照我们大纲来讲说是60讲粗略的大纲其实最终会拆分成可能上百讲Spring Cloud架构原理我们就要分为上下两讲来说
![Spring Cloud核心架构原理](/docs/distributed-system/images/SpringCloud-core-architecture.png)
### Spring Cloud
#### Eureka服务注册中心
#### Feign服务调用
#### Ribbon负载均衡
#### Zuul/Spring Cloud Gatway:网关
这么多的系统电商系统包含了20个子系统每个子系统有20个核心接口一共电商系统有400个接口这么多的接口直接对外暴露前后端分离的架构难道你让前端的同学必须记住你的20个系统的部署的机器他们去做负载均衡记住400个接口
微服务那块,**网关**
**灰度发布**、**统一熔断**、**统一降级**、**统一缓存**、**统一限流**、**统一授权认证**
**Hystrix**、**链路追踪**、**stream**、很多组件Hystrix这块东西其实是会放在高可用的环节去说的并不是说一个普通系统刚开始就必须得用的没有用好的话反而会出问题**Hystrix线路熔断的框架**,必须得设计对应的一整套的限流方案、熔断方案、资源隔离、降级机制,配合降级机制来做