java基础面试题(五)

Spring Cloud

  1. 什么是springCloud?优缺点

springCloud是一系列框架的有序集合;它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发;springCloud没有重复造轮子,而是把把比较成熟的框架组合起来给开发者留出了一套简单易懂、易部署和易维护的分布式系统开发工具包;

优点:

  1. 各组件之间耦合度低,不影响其他模块的开发

  1. 减轻团队开发成本

  1. 配置简单

  1. 跨平台,可以用多种语言开发

  1. 组件丰富,功能齐全

缺点:

  1. 微服务过多,治理成本高,不利于维护系统

  1. 部署、性能监控、系统集成测试较麻烦

  1. 为什么需要springCloud?

springcloud基于spingboot的简化配置,约定大于配置优雅简洁;由于单体结构的应用随着系统复杂度的增高,会暴露出各种各样的问题,微服务架构逐渐取代了单体架构,且这种趋势将会越来越流行

  1. springCloud与springboot的区别?
  1. springboot专注于快速方便的开发单个个体微服务;springCloud关注全局的微服务协调整理治理框架,它将SpringBoot开发的一个个单体微服务整合并管理起来;

  1. springboot可以离开SpringCloud独立使用开发项目, 但是SpringCloud离不开SpringBoot ,属于依赖的关系

  1. springboot专注于快速、方便的开发单个微服务个体,SpringCloud关注全局的服务治理框架

  1. 使用 Spring Boot 开发分布式微服务时面临哪些问题?
  1. 与分布式系统相关的复杂性包括网络问题,延迟开销,带宽问题,安全问题

  1. 冗余-分布式系统中的冗余问题

  1. 负载平衡--负载平衡改善跨多个计算资源的工作负荷,诸如计算机,计算机集群,网络链路,中央处理单元,或磁盘驱动器的分布

  1. 性能-问题 由于各种运营开销导致的性能问题

  1. 部署复杂性

  1. REST和RPC的区别

rest:是一种架构风格,指的是一组架构约束条件和原则(CRUD)

rpc:是一种进程间通信方式。允许像调用本地服务一样调用远程服务

  1. rpc适用于内网服务调用,rest适合对外提供服务

  1. rpc适用于IO密集的服务,rest适用于低频服务

  1. rpc的通信协议一般使用tcp,rest的通信协议使用http

Eureka(注册中心)

  1. 什么是Eureka?

Eureka作为SpringCloud的服务注册功能服务器,他是服务注册中心,系统中的其他服务使用Eureka的客户端将其连接到Eureka Service中,并且保持心跳,这样工作人员可以通过EurekaService来监控各个微服务是否运行正常

  1. Eureka如何实现高可用

使用集群注册多台Eureka,然后把SpringCloud服务互相注册,客户端从Eureka获取信息时,按照Eureka的顺序来访问

  1. Eureka自我保护机制

默认情况下,如果Eureka Service在一定时间内没有接收到某个微服务的心跳,Eureka Service会进自我保护模式,在该模式下Eureka Service会保护服务注册表中的信息,不在删除注册表中的数据,当网络故障恢复后,Eureka Servic 节点会自动退出自我保护模式。

  1. 什么是服务续约

Eureka Client 会每隔 30 秒发送一次心跳来续约。 通过续约来告知 Eureka Server 该 Eureka Client 运行正常,没有出现问题。 默认情况下,如果 Eureka Server 在 90 秒内没有收到 Eureka Client 的续约,Server 端会将实例从其注册表中删除

  1. 剔除服务

提供方并不必定是正常下线,多是内存溢出,网络故障等缘由致使服务没法正常工做.EurekaServer会将这些失效的服务剔除服务列表.所以它会开启一个定时任务.每隔60秒会对失效的服务进行一次剔除

6.Eureka缺陷

由于集群间的同步复制是通过HTTP的方式进行,基于网络的不可靠性,集群中的Eureka Server间的注册表信息难免存在不同步的时间节点,不满足CAP中的C(数据一致性)

Ribbon(负载均衡)

  1. 什么是Ribbon

Ribbon客户端组件提供一系列完善的配置项,如连接超时,重试等。简单的说,就是在配置文件中列出后面所有的机器,Ribbon会自动的帮助你基于某种规则(如简单轮询,随即连接等)去连接这些机器。我们也很容易使用Ribbon实现自定义的负载均衡算法;主要功能是提供客户端的软件负载均衡算法

2.负载均衡的意义

负载均衡的意义是指将负载的任务进行平衡、分摊到多个操作单元上进行运行,主要是用来避免单一应用由于并发等原因,导致应用宕机从而让系统整体无法使用、多负载同时工作,则使用负载均衡能够解决高并发的问题并实现服务的高可用

3.Ribbon的原理

Ribbon使用discoveryClient从注册中心读取目标服务信息,对同一接口请求进行计数,使用%取余算法获取目标服务集群索引,返回获取到的目标服务信息。@LoadBalanced注解的作用开启客户端负载均衡

4.Ribbon如何选择调用哪个实例
  1. 获取服务列表:为了减少服务的延迟,客户端会通过eureka指定的zone对服务列表进行过滤

  1. 负载均衡:通过负载均衡策略从服务列表中获得其中一台,默认是轮询策略,再对服务端进行调用

5.Ribbon如何避免调用失效实例
  1. 通过IPing检测实例,如果检测到某服务实例不存在/一定时间未响应,则会从持有服务列表中及时移除

  1. 保留zone的统计数据,ribbon可以避免可能访问失效的zone

6.Ribbon有哪些负载均衡策略
  1. 随机策略:随机选择

  1. 轮询策略:按照顺序选择

  1. 重试策略:在配置时间内,当前选择不成功,一直尝试

  1. 最低并发策略:逐个考察,选择并发最低的

  1. 可用过滤策略:过滤掉失败的和高并发的

  1. 响应时间加权重策略:根据响应的时间分配权重,时间越长,权重越低

  1. 区域权重策略

7.Ribbon与Nginx的区别

Ribbon属于客户端负载,及在调用服务器以前,客户端自己根据策略,选择调用服务

Nginx属于服务端负载,服务只管调用负载地址即,负载会自己选择服务端调用

Hystrix(容错保护)

1.什么是Hystrix?

框架,提供了高可用相关的各种各样的功能,然后确保说在hystrix的保护下,整个系统可以长期处于高可用的状态;

2.Hystrix有什么功能?

资源隔离

限流

熔断

降级

运维监控

3.Hystrix的设计原则
  1. 阻止任何一个依赖服务耗尽所有的资源

  1. 避免请求排队和积压

  1. 提供 fallback 降级机制来应对故障

  1. 使用资源隔离技术来限制任何一个依赖服务的故障的影响

  1. 通过近实时的统计/监控/报警功能,来提高故障发现的速度

  1. 通过近实时的属性和配置热修改功能,来提高故障处理和恢复的速度

  1. 保护依赖服务调用的所有故障情况,而不仅仅只是网络故障情况

4.什么是雪崩效应?产生原因?防雪崩的方式?

雪崩效应:大型项目的微服务之间的调用是互通的,当某个服务发生宕机时,调用这个服务的其他服务也会发生宕机,这样就会将服务的不可用逐步扩大到各个其他服务中,从而使整个项目的服务宕机崩溃

产生原因:

  1. 单个服务的代码存在bug

  1. 请求访问量激增

  1. 服务器的硬件故障

防止方式:

服务降级:接口调用失败就调用本地的方法返回一个空

服务熔断:接口调用失败就会进入调用接口提前定义好的一个熔断的方法,返回错误信息

服务隔离:隔离服务之间相互影响

服务监控:在服务发生调用时,会将每秒请求数、成功请求数等运行指标记录下来

5.服务降级、服务熔断、服务隔离

服务降级:防止客户端一直等待,不会处理业务逻辑代码,直接返回一个友好的提示给客户端

服务熔断:请求直接走fallback方法,在设定时间后尝试恢复

服务隔离:为隔离的服务开启一个独立的线程池,这样在高并发的情况下不会影响其他服务

Feign(服务调用)

1.什么是Feign?有什么作用?

Feign是一个http客户端,只需要创建一个接口并添加一个注解就可以帮助我们更便捷的调用HTTP API

2.Feign原理
  1. 将feign接口的代理类扫描到Spring容器中

  1. 为接口的方法创建RequestTemplate

  1. 发出请求

3.Feign超时如何处理

底层内置了Ribbon框架,并且使用了Ribbon的请求连接超时时间和请求处理超时时间作为其超时时间,而Ribbon默认的请求连接超时时间和请求处理超时时间都是 1s;

修改超时时间:

  1. 通过修改 Ribbon 的超时时间,被动的修改Feign 的超时时间(ribbon.ConnectTimeout、ribbon.ReadTimeout)

  1. 直接修改Feign 的超时时间(feign.client.config.default.ConnectTimeout、feign.client.config.default..ReadTimeout)

4.Feign传参方式
  1. restful传参 @PathVariable() 将参数id以restful风格拼接到路径中

  1. ?传参 @RequestParam【拼接?形式的url】

  1. @RequestBody 将user对象以json字符串的形式传参

5.Feign优化
  1. 开启feign日志

  1. 配置feign超时

  1. http连接池

  1. gzip压缩

Zuul(网关)

1.什么是网关

网关相当于一个网络服务架构的入口,所有网络请求必须通过网关转发到具体的服务

2.网关的作用

统一管理微服务请求,权限控制、负载均衡、路由转发、监控、安全控制黑名单和白名单等

3.网关和过滤器的区别
  1. 网关是对所有服务的请求进行分析过滤,过滤器是对单个服务而言

  1. 网关是路由加过滤器

4.什么是zuul

Zuul是对SpringCloud提供的成熟对的路由方案,他会根据请求的路径不同,网关会定位到指定的微服务,并代理请求到不同的微服务接口,他对外隐蔽了微服务的真正接口地址。 三个重要概念:动态路由表,路由定位,反向代理。

态路由表:Zuul支持Eureka路由,手动配置路由,都支持自动更新

路由定位:根据请求路径,Zuul有自己的一套定位服务规则以及路由表达式匹配

反向代理:客户端请求到路由网关,网关受理之后,在对目标发送请求,拿到响应之后在给客户端

5.如何实现动态Zuul网关路由转发

通过path配置拦截请求,通过ServiceId到配置中心获取转发的服务列表,Zuul内部使用Ribbon实现本地负载均衡和转发

6. Zuul网关如何搭建集群

使用Nginx的upstream设置Zuul服务集群,通过location拦截请求并转发到upstream,默认使用轮询机制对Zuul集群发送请求。

7.Zuul如何实现流量控制

Zuul限流是通过引入spring-cloud-zuul-ratelimit依赖实现的

限流类型:

  1. 用户,根据认证用户或匿名用户限流

  1. 客户端IP地址,根据客户端IP地址限流

  1. 请求路径,根据请求URL限流

  1. 根据服务限流

你可能感兴趣的:(java,spring,面试)