Spring Cloud Hystrix

什么是Spring Cloud Hystrix 雅采?

在微服務架構中爵憎,我們將系統(tǒng)拆分成了一個個的服務單元,各單元應用間通過服務注冊與訂閱的方式互相依賴婚瓜。由于每個單元都在不同的進程中運行宝鼓,依賴通過遠程調用的方式執(zhí)行,這樣就有可能因為網絡原因或是依賴服務自身問題出現(xiàn)調用故障或延遲闰渔,而這些問題會直接導致調用方的對外服務也出現(xiàn)延遲席函,若此時調用方的請求不斷增加铐望,最后就會出現(xiàn)因等待出現(xiàn)故障的依賴方響應而形成任務積壓冈涧,線程資源無法釋放,最終導致自身服務的癱瘓正蛙,進一步甚至出現(xiàn)故障的蔓延最終導致整個系統(tǒng)的癱瘓督弓。如果這樣的架構存在如此嚴重的隱患,那么相較傳統(tǒng)架構就更加的不穩(wěn)定乒验。為了解決這樣的問題愚隧,因此產生了斷路器等一系列的服務保護機制。
針對上述問題锻全,在Spring Cloud Hystrix中實現(xiàn)了線程隔離狂塘、斷路器等一系列的服務保護功能录煤。它也是基于Netflix的開源框架 Hystrix實現(xiàn)的,該框架目標在于通過控制那些訪問遠程系統(tǒng)荞胡、服務和第三方庫的節(jié)點妈踊,從而對延遲和故障提供更強大的容錯能力。Hystrix具備了服務降級泪漂、服務熔斷廊营、線程隔離、請求緩存萝勤、請求合并以及服務監(jiān)控等強大功能露筒。

準備工作:
搭建 服務注冊中心,
發(fā)布 務提供者敌卓。

新建spring boot 項目
修改pom.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>chanzj</groupId>
    <artifactId>eureka-consumer-ribbon</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>

    <name>eureka-consumer-ribbon</name>
    <description>Demo project for Spring Boot</description>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.5.4.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-eureka</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-ribbon</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-hystrix</artifactId>
        </dependency>
    </dependencies>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>Dalston.SR1</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

在應用主類中使用@EnableCircuitBreaker或@EnableHystrix注解開啟Hystrix的使用:

package chanzj.eurekaconsumerribbon;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.circuitbreaker.EnableCircuitBreaker;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;

@EnableCircuitBreaker
@EnableDiscoveryClient
@SpringBootApplication
public class EurekaConsumerRibbonApplication {

    @Bean
    @LoadBalanced
    public RestTemplate restTemplate() {

        return new RestTemplate();
    }

    public static void main(String[] args) {

        SpringApplication.run(EurekaConsumerRibbonApplication.class, args);
    }
}

新建Service慎式,在為具體執(zhí)行邏輯的函數(shù)上增加@HystrixCommand注解來指定服務降級方法

package chanzj.eurekaconsumerribbon.service;

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

    @Autowired
    RestTemplate restTemplate;

    @HystrixCommand(fallbackMethod = "fallback")
    public String consumer(){
        return  restTemplate.getForObject("http://eureka-client/test", String.class);
    }

    public String fallback(){
        return "fallback";
    }
}

在Controller里調用方法:

package chanzj.eurekaconsumerribbon.web;

import chanzj.eurekaconsumerribbon.service.RibbonService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class RibbonController {

    @Autowired
    RibbonService ribbonService;

    @GetMapping("/test")
    public String test() {
        return ribbonService.consumer();
    }
}

最后在服務提供端加上延遲時間制造訪問超時,發(fā)布所有服務假哎,
訪問 http://localhost:2105/test
訪問超時的方法瞬捕。

好!結束舵抹!

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末肪虎,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子惧蛹,更是在濱河造成了極大的恐慌扇救,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,386評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件香嗓,死亡現(xiàn)場離奇詭異迅腔,居然都是意外死亡,警方通過查閱死者的電腦和手機靠娱,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評論 3 394
  • 文/潘曉璐 我一進店門沧烈,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人像云,你說我怎么就攤上這事锌雀。” “怎么了迅诬?”我有些...
    開封第一講書人閱讀 164,704評論 0 353
  • 文/不壞的土叔 我叫張陵腋逆,是天一觀的道長。 經常有香客問我侈贷,道長惩歉,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,702評論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮撑蚌,結果婚禮上上遥,老公的妹妹穿的比我還像新娘。我一直安慰自己争涌,他們只是感情好露该,可當我...
    茶點故事閱讀 67,716評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著第煮,像睡著了一般解幼。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上包警,一...
    開封第一講書人閱讀 51,573評論 1 305
  • 那天撵摆,我揣著相機與錄音,去河邊找鬼害晦。 笑死特铝,一個胖子當著我的面吹牛,可吹牛的內容都是我干的壹瘟。 我是一名探鬼主播鲫剿,決...
    沈念sama閱讀 40,314評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼稻轨!你這毒婦竟也來了灵莲?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 39,230評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后篮条,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經...
    沈念sama閱讀 45,680評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡着撩,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,873評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,991評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡苦锨,死狀恐怖,靈堂內的尸體忽然破棺而出趴泌,到底是詐尸還是另有隱情舟舒,我是刑警寧澤,帶...
    沈念sama閱讀 35,706評論 5 346
  • 正文 年R本政府宣布踱讨,位于F島的核電站魏蔗,受9級特大地震影響砍的,放射性物質發(fā)生泄漏痹筛。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,329評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望帚稠。 院中可真熱鬧谣旁,春花似錦、人聲如沸滋早。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽杆麸。三九已至搁进,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間昔头,已是汗流浹背饼问。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留揭斧,地道東北人莱革。 一個月前我還...
    沈念sama閱讀 48,158評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像讹开,于是被迫代替她去往敵國和親盅视。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,941評論 2 355

推薦閱讀更多精彩內容