SpringCloud


一、SpringCloud是什么

SpringCloud的目标是微服务架构下的一站式解决方案。

SpringCloud生态图

SpringCloud生态图

SpringCloud能干嘛?

  • Distributed/versioned configuration 分布式/版本控制配置

  • Service registration and discovery 服务注册与发现

  • Routing 路由

  • Service-to-service calls 服务到服务的调用

  • Load balancing 负载均衡配置

  • Circuit Breakers 断路器

  • Distributed messaging 分布式消息管理

1.1 SpringCloud和SpringBoot的关系

  • SpringBoot专注于开苏方便的开发单个个体微服务;
  • SpringCloud是关注全局的微服务协调整理治理框架,它将SpringBoot开发的一个个单体微服务,整合并管理起来,为各个微服务之间提供:配置管理、服务发现、断路器、路由、为代理、事件总栈、全局锁、决策竞选、分布式会话等等集成服务;
  • SpringBoot可以离开SpringCloud独立使用,开发项目,但SpringCloud离不开SpringBoot,属于依赖关系;
  • SpringBoot专注于快速、方便的开发单个个体微服务,SpringCloud关注全局的服务治理框架;

1.2 SpringCloud的通信方式

Spring Cloud 抛弃了Dubbo的RPC通信,采用的是基于HTTP的REST方式

严格来说,这两种方式各有优劣。虽然从一定程度上来说,后者牺牲了服务调用的性能,但也避免了上面提到的原生RPC带来的问题。而且REST相比RPC更为灵活,服务提供方和调用方的依赖只依靠一纸契约,不存在代码级别的强依赖,这个优点在当下强调快速演化的微服务环境下,显得更加合适。

1.3 SpringCloud五大件

服务访问 => Netfix Zuul

服务通信 => Feign –> HttpClient —> HTTP的通信方式 ( 同步并阻塞 )

服务治理 => Netfix Eureka( 服务注册与发现 )

服务熔断 => Netfix Hystrix ( 熔断机制 )

负载均衡 => 客户端负载均衡:Netfix Ribbon

​ 服务端负载均衡:Feign(依赖于Ribbon,只是将调用方式RestTemplate更改为Service接口)

分布式配置 => SpringCloud Config

二、SpringCloud常见面试题

1、什么是微服?

2、微服务之间是如何独立通讯的?

3、SpringCloud和Dubbo有哪些区别?

4、SpringBoot和SpringCIoud,请你谈谈对他们的理解

5、什么是服务熔断?什么是服务降级

6、微服务的优缺点是分别是什么?说下你在项目开发中遇到的坑

7、你所知道的微服务技术栈有哪些?请列举一二

8、eureka和zookeeper都可以提供服务注册与发现的功能,请说说两个的区别?


文章作者: JYong
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 JYong !
评论
  目录
动态线条背景