最近学到了springboot,我是看的动力节点王鹤老师的视频,今天这篇博客,主要说说spring,springboot,springcloud这三者都是干嘛的?

视频资源:https://www.bilibili.com/video/BV1XQ4y1m7ex


架构 > 解偶


开发框架 spring

IOC AOP

Ioc :控制反转        

原来我们都是自己一步步操作,现在交给容器了!我们需要什么就去拿就可以了         

Aop :切面(本质,动态代理)        

为了解决什么?不影响业务本来的情况下,实现动态增加功能,大量应用在日志,事务 … 等等方面   

spring 是一个轻量级的java开源框架,容器目的:解决企业开发的复杂性问题 spring 是春天,觉得他是春天,也十分复杂,配置文件!      

SpringBoot

SpringBoot 并不是新东西,就是spring的升级版!

新一代JavaEE的开发标准,开箱即用!一>拿过来就可以用!      

它自动帮我们配置了非常多的东西,我们拿来即用!

特性:约定大于配置!

随着公司体系越来越大,用户越来越多!


微服务架构-一>新架构


模块化.功能化!

用户,支付,签到,娱乐 … ;

人多余多:一台服务器解决不了;在增加服务器!横向

假设A服务器占用 98 %资源, B 服务器只占用了 10 %。--负载均衡

将原来的整体项目.分成模块化.用户就是,个单独的项目.签到也是一个单独的项目,项目和项目之前需要通信,如何通信

用户非常多,而签到十分少!给用户多一点服务器,给签到少一点服务器

微服务架构问题?

分布式架构会遇到的四个核心问题?

1.这么多服务,客户端该如何去访问?

2.这么多服务.服务之间如何进行通信?

3.这么多服务.如何治理呢?

4.服务挂了.怎么办?

解决方案:

spring cloud,是一套生态,就是来解决以上分布式架构的 4个问题想使用 Spring cloud ,必须要掌握 SpringBoot,

因为 Spring cloud 是基于 springBoot。

1. Spring cloud NetFlix 出来了一套解决方案!一站式解决方案.我们都可以直接去这里拿?

  • Api 网关, zuul 组件
  • Feign 一> Httpclient --- HTTP的通信方式 同步并阻塞
  • 服务注册与发现Eureka
  • 熔断机制, Hystrix

2018年年底, NetFlix 宣布无限朋停止维护。生态不再维护,就会脱节.

2. Apache Dubbo zookeeper ,第二套解决系统.  

API:没有!要么找第三方组件.要么自己实现

Dubbo 是一个高性能基于Java 实现的 Rpc 通信框架! 2.6.x

服务注册与发现, zookeeper :动物园管理者( Hadoop ,Hive )

没有:借助了 Hystrix

不完兽, Doubbo 当前 Doubbo 3.0 将提倡具备当代特性(如响应式编程)的相关支持同时汲取阿里内部HSF的设计长处来实现两者融合

当前预览版的很多地方还在探讨中,希望大家能够积极反馏,我们都会虚心学习并参考。

3. springcloud Alibaba 一站式解决方案!

目前.又提出了一种方案:

服务网格:下一代微服务标准, Server Mesh

代表解决方案: Istio 。(你们未来可能需要掌握!)

万变不离其宗.一通百通!

1. API 网关,服务路由

2. HTTP , RpC 框架,异步调用

3. 服务注册与发现,高可用

4. 熔断机制,服务降级

如果,你们基于这四个问题,开发一套解决方案,也叫 Springcloud !

为什么要解决这个问题?本质二网络是不可靠的!程序猿,不要停下学习的脚步!