参考:牙Zhipeng列
はじめに1. Hystrix
マイクロサービスアーキテクチャでは、サービスに応じたサービス間で互いに(RPC)サービスを呼び出すことができるサービスの数に分割されるとRestTemplate +リボンふりを使用し、このスプリングクラウドを呼び出すことができます。可用性を確保するために、単一のサービスは、多くの場合、展開をクラスタ化します。多数の要求の流入は、サーブレットコンテナのスレッドのリソースが完成消費される場合は、ネットワーク上の理由として、あるいは自分自身の理由のために、サービスの単一のサービスの問題が発生した場合、このサービスを呼び出すために、100%が利用可能保証するものではありませんが、スレッドは、この時点で、ブロックされます、サービスの麻痺になります。サービスおよびサービスの障害の間の依存関係広がっていく、全体のマイクロシステムにサービスを提供しますが、悲惨な深刻な影響を持っている、これは「なだれ」効果のサービス障害です。
この問題を解決するために、業界では、回路ブレーカのモデルを提案しました。
NetflixのHystrixオープンソースコンポーネント、カットアウトモードを達成するために、コンポーネントのSpringCloudを統合しました。下に示すように、マイクロサービスアーキテクチャでは、複数のサービスを呼び出すための要求の必要性は、非常に一般的です。
障害が発生した場合、より深いサービスは、それがカスケード故障につながります。コールは、特定のサービスが閾値(Hystric 5秒間20回)に達したために利用可能でない場合、回路ブレーカが開かれます。
オープン破壊した後、失敗をカスケード避けるために使用することができ、フォールバック方法は、固定値に直接返すことがあります。
この記事は、工学の記事に基づいており、工事はユーレカ・サーバープロジェクトを開始し、最初の記事で開始し、プロジェクトの開始サービス-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 SchedualServiceHiインターフェイスを実装する必要があり、IOCは、容器に注入されます。
輸入com.zang.servicefeign.clients.SchedualServiceHi; 輸入org.springframework.stereotype.Component; @Component パブリック クラス SchedualServiceHiHystric 実装SchedualServiceHi { @Override パブリック文字列sayHiFromClientOne(文字列名){ リターンは +「申し訳ありませんが、あなたは、失敗している」名。 } }
:この時点でプロジェクトはサービス-HI、Webページの表示を開始していないことを// localhostの:? 8765 / HI名=奘、ノート:スタートservcie-装うプロジェクトのhttpを開くには、ブラウザ
オープンサービス-HIエンジニアリング、再度アクセス、ブラウザが表示されます。
これは、回路ブレーカが役割を果たしたことを証明しています。