(C)春クラウドチュートリアル--Hystrix(Fバージョン)

参考:牙Zhipeng列

はじめに1. Hystrix

マイクロサービスアーキテクチャでは、サービスに応じたサービス間で互いに(RPC)サービスを呼び出すことができるサービスの数に分割されるとRestTemplate +リボンふりを使用し、このスプリングクラウドを呼び出すことができます。可用性を確保するために、単一のサービスは、多くの場合、展開をクラスタ化します。多数の要求の流入は、サーブレットコンテナのスレッドのリソースが完成消費される場合は、ネットワーク上の理由として、あるいは自分自身の理由のために、サービスの単一のサービスの問題が発生した場合、このサービスを呼び出すために、100%が利用可能保証するものではありませんが、スレッドは、この時点で、ブロックされます、サービスの麻痺になります。サービスおよびサービスの障害の間の依存関係広がっていく、全体のマイクロシステムにサービスを提供しますが、悲惨な深刻な影響を持っている、これは「なだれ」効果のサービス障害です。

この問題を解決するために、業界では、回路ブレーカのモデルを提案しました。

NetflixのHystrixオープンソースコンポーネント、カットアウトモードを達成するために、コンポーネントのSpringCloudを統合しました。下に示すように、マイクロサービスアーキテクチャでは、複数のサービスを呼び出すための要求の必要性は、非常に一般的です。

HystrixGraph.png

障害が発生した場合、より深いサービスは、それがカスケード故障につながります。コールは、特定のサービスが閾値(Hystric 5秒間20回)に達したために利用可能でない場合、回路ブレーカが開かれます。

HystrixFallback.png

オープン破壊した後、失敗をカスケード避けるために使用することができ、フォールバック方法は、固定値に直接返すことがあります。

この記事は、工学の記事に基づいており、工事はユーレカ・サーバープロジェクトを開始し、最初の記事で開始し、プロジェクトの開始サービス-HI、ポートは8762です。

2.リボンの回路ブレーカ

コードサービス・リボンの改修プロジェクトは、最初のpox.xmlファイル内の依存バネ - クラウドスターターNetflixの-hystrixを追加しました:

<dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
  </dependency>

在程序的启动类ServiceRibbonApplication 加@EnableHystrix注解开启Hystrix:

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.cloud.netflix.hystrix.EnableHystrix;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;

@SpringBootApplication
@EnableEurekaClient
@EnableDiscoveryClient
@EnableHystrix
public class ServiceRibbonApplication {

    public static void main(String[] args) {
        SpringApplication.run( ServiceRibbonApplication.class, args );
    }

    @Bean
    @LoadBalanced
    RestTemplate restTemplate() {
        return new RestTemplate();
    }

}

改造HelloService类,在hiService方法上加上@HystrixCommand注解。该注解对该方法创建了熔断器的功能,并指定了fallbackMethod熔断方法,熔断方法直接返回了一个字符串,字符串为”hi,”+name+”,sorry,error!”,代码如下:

import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.web.client.RestTemplate;

@Service
public class HelloService {

    @Autowired
    RestTemplate restTemplate;

    @HystrixCommand(fallbackMethod = "hiError")
    public String hiService(String name) {
        return restTemplate.getForObject("http://SERVICE-HI/hi?name="+name,String.class);
    }

    public String hiError(String name) {
        return "hi,"+name+",sorry,error!";
    }

}

启动:service-ribbon 工程,当我们访问http://localhost:8764/hi?name=zang,浏览器显示:

此时关闭 service-hi 工程,当我们再访问http://localhost:8764/hi?name=forezp,浏览器会显示:

这就说明当 service-hi 工程不可用的时候,service-ribbon调用 service-hi的API接口时,会执行快速失败,直接返回一组字符串,而不是等待响应超时,这很好的控制了容器的线程阻塞。

3. Feign中使用断路器

Feign是自带断路器的,在D版本的Spring Cloud之后,它没有默认打开。需要在配置文件中配置打开它,在配置文件加以下代码:

feign.hystrix.enabled: true

基于service-feign工程进行改造,只需要在FeignClient的SchedualServiceHi接口的注解中加上fallback的指定类就行了:

import com.zang.servicefeign.clients.fallback.SchedualServiceHiHystric;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;

@FeignClient(value = "service-hi",fallback = SchedualServiceHiHystric.class)
public interface SchedualServiceHi {
    @RequestMapping(value = "/hi",method = RequestMethod.GET)
    String sayHiFromClientOne(@RequestParam(value = "name")文字列名)。
}

以下、SchedualServiceHiHystric Sc​​hedualServiceHiインターフェイスを実装する必要があり、IOCは、容器に注入されます。

輸入com.zang.servicefeign.clients.SchedualServiceHi;
輸入org.springframework.stereotype.Component; 

@Component 
パブリック クラス SchedualServiceHiHystric 実装SchedualServiceHi { 
    @Override 
    パブリック文字列sayHiFromClientOne(文字列名){
         リターンは +「申し訳ありませんが、あなたは、失敗している」名。
    } 
}

:この時点でプロジェクトはサービス-HI、Webページの表示を開始していないことを// localhostの:? 8765 / HI名=奘、ノート:スタートservcie-装うプロジェクトのhttpを開くには、ブラウザ

 オープンサービス-HIエンジニアリング、再度アクセス、ブラウザが表示されます。

 これは、回路ブレーカが役割を果たしたことを証明しています。

 

おすすめ

転載: www.cnblogs.com/zjfjava/p/12189517.html