Heim >Java >javaLernprogramm >Spring Cloud2.0-Studiennotizen Vortäuschende Praxis

Spring Cloud2.0-Studiennotizen Vortäuschende Praxis

无忌哥哥
无忌哥哥Original
2018-07-20 12:02:453413Durchsuche

Hintergrund

  • springCloud:Finchley.RELEASE

Einführung

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.

Einfache Anwendung

  • 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);
}

Aktivieren Sie Feign-Leistungsschalter und Kontextunterstützung

  • 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

Rückruf des Leistungsschalters

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 Schnittstellenvererbung

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 {}

Komprimierungsunterstützung

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

Protokollkonfiguration

  • 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!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn