springCloud:Finchley.RELEASE
Feign ist ein deklarativer Rest-Client im Spring Cloud-System. Er kann den Aufruf von Restful-Diensten durch einfache Konfiguration, Erstellung von Schnittstellen und Anmerkungen realisieren. Und es beginnt, SpringMvc zu unterstützen.
Abhängigkeit: org.springframework.cloud:spring-cloud-starter-openfeign
Add @ at der Eingang EnableFeignClients-Anmerkung
Erstellen Sie die entsprechende Schnittstelle und fügen Sie die Anmerkung hinzu
//入口类 @SpringBootApplication @EnableFeignClientspublic class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } //原型接口声明 @FeignClient("stores")public interface StoreClient { @RequestMapping(method = RequestMethod.GET, value = "/stores") List<Store> getStores(); @RequestMapping(method = RequestMethod.POST, value = "/stores/{storeId}", consumes = "application/json") Store update(@PathVariable("storeId") Long storeId, Store store); }
feign.hystrix.enabled=true
# To disable Hystrix in Feignfeign: hystrix: enabled: true# To set thread isolation to SEMAPHORE# 将断路器隔离级别由默认的线程隔离调整为信号灯hystrix: command: default: execution: isolation: strategy: SEMAPHORE
Der Leistungsschalter unterstützt Fallback, was bedeutet, dass die Rückrufdefinition ausgeführt wird, wenn der Der Leistungsschalter ist eingeschaltet oder es tritt ein Fehler auf der Schnittstelle auf. Methode, die vordefinierte Ergebnisse zurückgibt. Um die Rückrufunterstützung zu aktivieren, müssen Sie nur den Fallback-Parameter in der @FeignClient-Annotation als Rückruf-Implementierungsklasse der Schnittstelle konfigurieren und die Rückruf-Implementierungsklasse muss als Spring Bean annotiert sein (kann über @Component, @Service implementiert werden). Weitere Informationen finden Sie in der Anmerkungsdokumentation von Spring 4.
@FeignClient(name = "hello", fallback = HystrixClientFallback.class) protected interface HystrixClient { @RequestMapping(method = RequestMethod.GET, value = "/hello") Hello iFailSometimes(); } @Componentstatic class HystrixClientFallback implements HystrixClient { @Override public Hello iFailSometimes() { return new Hello("fallback"); } }
Wenn Sie den Grund für das Rollback kennen müssen, können Sie die Rollback-Factory verwenden. Das Codebeispiel lautet wie folgt:
@FeignClient(name = "hello", fallbackFactory = HystrixClientFallbackFactory.class) protected interface HystrixClient { @RequestMapping(method = RequestMethod.GET, value = "/hello") Hello iFailSometimes(); } @Componentstatic class HystrixClientFallbackFactory implements FallbackFactory<HystrixClient> { @Override public HystrixClient create(Throwable cause) { return new HystrixClient() { @Override public Hello iFailSometimes() { return new Hello("fallback; reason was: " + cause.getMessage()); } }; } }
Feign unterstützt die Schnittstellenvererbung.
//生产者的控制层接口public interface UserService { @RequestMapping(method = RequestMethod.GET, value ="/users/{id}") User getUser(@PathVariable("id") long id); } //生产者的控制器实现 @RestController public class UserResource implements UserService {} //消费端的Feign接口定义 package project.user; @FeignClient("users") public interface UserClient extends UserService {}
Das Aktivieren der Komprimierung kann effektiv Netzwerkressourcen sparen, erhöht jedoch die CPU-Belastung. Es wird empfohlen, die Mindestgröße des komprimierten Dokuments entsprechend zu erhöhen
//开启压缩 feign.compression.request.enabled=true feign.compression.response.enabled=true //配置压缩文档类型及最小压缩的文档大小 feign.compression.request.mime-types=text/xml,application/xml,application/json feign.compression.request.min-request-size=2048
Das Paket, in dem sich die Schnittstelle des Verbraucherdienstes befindet, muss debuggt sein
# 日志支持logging.level.project.user.UserClient: DEBUG
Definieren Sie eine benutzerdefinierte Konfigurationsklasse und definieren Sie die Protokollebene
@Configurationpublic class FooConfiguration { @Bean Logger.Level feignLoggerLevel() { return Logger.Level.FULL; } }
Protokollebene
NONE, Keine Protokollierung (STANDARD ).
BASIC, Protokolliert nur die Anforderungsmethode und URL sowie den Antwortstatuscode und die Ausführungszeit.
HEADERS, Protokolliert die grundlegenden Informationen zusammen mit Anfrage- und Antwortheadern.
VOLLSTÄNDIG, Protokollieren Sie die Header, den Text und die Metadaten für Anfragen und Antworten.
Das obige ist der detaillierte Inhalt vonSpring Cloud2.0-Studiennotizen Vortäuschende Praxis. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!