1. 前言
在开发工程中,我们发现当一个微服务挂掉之后,如果我们访问此微服务的接口,zuul也会挂掉。因为zuul负责分配请求,当目标微服务挂掉之后,zuul便找不到目标微服务,因为我们需要设置一个熔断,即使寻找不到目标微服务,zuul也不会挂掉。
比如我们停掉my-user微服务,然后访问其中的一个接口,zuul会出现以下错误。
2. 代码编写
2.1 新建ApiFallbackProvider.java
2.2 编写ApiFallbackProvider.java
package com.zuul.filter;
import org.springframework.cloud.netflix.zuul.filters.route.FallbackProvider;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType;
import org.springframework.http.client.ClientHttpResponse;
import org.springframework.stereotype.Component;
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
@Component
public class ApiFallbackProvider implements FallbackProvider {
@Override
public String getRoute() {
// 所有请求,皆通过这里
return "*";
}
@Override
public ClientHttpResponse fallbackResponse(String route, Throwable cause) {
return new ClientHttpResponse() {
@Override
public HttpStatus getStatusCode() throws IOException {
return HttpStatus.OK;
}
@Override
public int getRawStatusCode() throws IOException {
return HttpStatus.OK.value();
}
@Override
public String getStatusText() throws IOException {
return HttpStatus.OK.getReasonPhrase();
}
@Override
public void close() {
}
@Override
public InputStream getBody() throws IOException {
//返回的内容,暂时不知道如何使用
String response = "{\n" +
" \"msg\": \"core服务失去联系,请联系管理员\",\n" +
" \"code\": 400,\n" +
" \"data\": null\n" +
"}";
ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(response.getBytes());
return byteArrayInputStream;
}
@Override
public HttpHeaders getHeaders() {
HttpHeaders httpHeaders = new HttpHeaders();
httpHeaders.setContentType(MediaType.APPLICATION_JSON);
return httpHeaders;
}
};
}
}
3. 测试
同样关掉my-user,然后访问zuul,zuul没有挂掉。这样其他的微服务接口还可以继续使用。