一、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都可以提供服务注册与发现的功能,请说说两个的区别?