最后
本人也收藏了一份Java面试核心知识点来应付面试,借着这次机会可以送给我的读者朋友们
目录:
Java面试核心知识点
一共有30个专题,足够读者朋友们应付面试啦,也节省朋友们去到处搜刮资料自己整理的时间!
Java面试核心知识点
已经有读者朋友靠着这一份Java面试知识点指导拿到不错的offer了
假设如果上图中的微服务 9 失败了,那么使用传统方法我们将传播一个异常。但这仍然会导致整个系统崩溃。
随着微服务数量的增加,这个问题变得更加复杂。微服务的数量可以高达 1000.这是 hystrix
出现的地方我们将使用 Hystrix
在这种情况下的 Fallback
方法功能。我们有两个服务 employee-consumer
使用由 employee-consumer
公开的服务。
简化图如下所示
现在假设由于某种原因,employee-producer
公开的服务会抛出异常。我们在这种情况下使用 Hystrix
定义了一个回退方法。这种后备方法应该具有与公开服务相同的返回类型。如果暴露服务中出现异常,则回退方法将返回一些值。
问题五:什么是 Hystrix 断路器?我们需要它吗?
由于某些原因,employee-consumer
公开服务会引发异常。在这种情况下使用 Hystrix
我们定义了一个回退方法。如果在公开服务中发生异常,则回退方法返回一些默认值。
如果 firstPage method()
中的异常继续发生,则 Hystrix
电路将中断,并且员工使用者将一起跳过 firtsPage 方法,并直接调用回退方法。 断路器的目的是给第一页方法或第一页方法可能调用的其他方法留出时间,并导致异常恢复。可能发生的情况是,在负载较小的情况下,导致异常的问题有更好的恢复机会 。
问题六:什么是 Netflix Feign?它的优点是什么?
Feign 是受到 Retrofit
,JAXRS-2.0
和 WebSocket
启发的 java 客户端联编程序。Feign 的第一个目标是将约束分母的复杂性统一到 http apis
,而不考虑其稳定性。在 employee-consumer
的例子中,我们使用了 employee-producer
使用 REST 模板公开的 REST 服务。
但是我们必须编写大量代码才能执行以下步骤
- 使用功能区进行负载平衡。
- 获取服务实例,然后获取基本 URL。
- 利用 REST 模板来使用服务。 前面的代码如下
@Controller
public class ConsumerControllerClient {
@Autowired
private LoadBalancerClient loadBalancer;
public void getEmployee() throws RestClientException, IOException {
ServiceInstance serviceInstance=loadBalancer.choose(“employee-producer”);
System.out.println(serviceInstance.getUri());
String baseUrl=serviceInstance.getUri().toString();
baseUrl=baseUrl+“/employee”;
RestTemplate restTemplate = new RestTemplate();
ResponseEntity response=null;
try{
response=restTemplate.exchange(baseUrl,
HttpMethod.GET, getHeaders(),String.class);
}catch (Exception ex){
System.out.println(ex);
}
System.out.println(response.getBody());
}
}
之前的代码,有像 NullPointer
这样的例外的机会,并不是最优的。我们将看到如何使用 Netflix Feign
使呼叫变得更加轻松和清洁。如果 Netflix Ribbon
依赖关系也在类路径中,那么 Feign
默认也会负责负载平衡。
写在最后
废话就不多说了,希望大家能够多多三连!
需要资料的同学记得关注我私信 【Spring Cloud】 免费获取 Java架构学习资料和金三银四专题面经!!!
分享
这次面试我也做了一些总结,确实还有很多要学的东西。相关面试题也做了整理,可以分享给大家,了解一下面试真题,想进大厂的或者想跳槽的小伙伴不妨好好利用时间来学习。学习的脚步一定不能停止!
Spring Cloud实战
Spring Boot实战
面试题整理(性能优化+微服务+并发编程+开源框架+分布式)
ab5e56a57acb)收录**