欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringCloud Hystrix熔斷器使用方法介紹

 更新時(shí)間:2023年03月20日 08:32:07   作者:小乞丐程序員  
通過(guò)hystrix可以解決雪崩效應(yīng)問(wèn)題,它提供了資源隔離、降級(jí)機(jī)制、融斷、緩存等功能。接下來(lái)通過(guò)本文給大家分享SpringCloud集成Hystrix熔斷,感興趣的朋友一起看看吧

Hystrix(hi si ju ke si)概述

Hystix 是 Netflix 開(kāi)源的一個(gè)延遲和容錯(cuò)庫(kù),用于隔離訪問(wèn)遠(yuǎn)程服務(wù)、第三方庫(kù),防止出現(xiàn)級(jí)聯(lián)失?。ㄑ┍溃?。

雪崩:一個(gè)服務(wù)失敗,導(dǎo)致整條鏈路的服務(wù)都失敗的情形。

Hystix 主要功能

  • 隔離
  • 降級(jí)
  • 熔斷
  • 限流

隔離

  • 線(xiàn)程池隔離
  • 信號(hào)量隔離

Hystrix 降級(jí)

Hystix 降級(jí):當(dāng)服務(wù)發(fā)生異常或調(diào)用超時(shí),返回默認(rèn)數(shù)據(jù)

Hystrix降級(jí)-服務(wù)提供方

  • 在服務(wù)提供方,引入 hystrix 依賴(lài)
  • 定義降級(jí)方法
  • 使用 @HystrixCommand 注解配置降級(jí)方法
  • 在啟動(dòng)類(lèi)上開(kāi)啟Hystrix功能:@EnableCircuitBreaker

初始化程序和Fiegn程序一致

需要修改的程序

package com.itheima.provider;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.circuitbreaker.EnableCircuitBreaker;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
/**
 * 啟動(dòng)類(lèi)
 */
@EnableEurekaClient //該注解 在新版本中可以省略
@SpringBootApplication
@EnableCircuitBreaker ///開(kāi)啟Hystrix功能
public class ProviderApp {
    public static void main(String[] args) {
        SpringApplication.run(ProviderApp.class,args);
    }
}

測(cè)試的程序

package com.itheima.provider.controller;
import com.itheima.provider.domain.Goods;
import com.itheima.provider.service.GoodsService;
import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand;
import com.netflix.hystrix.contrib.javanica.annotation.HystrixProperty;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.Date;
/**
 * Goods Controller 服務(wù)提供方
 */
@RestController
@RequestMapping("/goods")
public class GoodsController {
    @Autowired
    private GoodsService goodsService;
    @Value("${server.port}")
    private int port;
    /**
     * 降級(jí):
     *   1 出現(xiàn)異常
     *   2 調(diào)用服務(wù)超時(shí)
     *      默認(rèn)1s超時(shí)
     *
     *@HystrixCommand(fallbackMethod = "findOne_fallback")
     * fallbackMethod 指定降級(jí)后的名稱(chēng)
     * @param id
     * @return
     */
    @GetMapping("/findOne/{id}")
    @HystrixCommand(fallbackMethod = "findOne_fallback",commandProperties = {
            //設(shè)置Hystrix的超時(shí)時(shí)間 默認(rèn)1s
            @HystrixProperty(name="execution.isolation.thread.timeoutInMilliseconds",value = "3000")
    })///指定降級(jí)后的方法
    public Goods findOne(@PathVariable("id") int id)  {
        ///1 造個(gè)異常
        //int i =3/0;
        try {
            Thread.sleep(2000);//sleep interrupted
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        Goods goods = goodsService.findOne(id);
        goods.setTitle(goods.getTitle() + ":" + port);//將端口號(hào),設(shè)置到了 商品標(biāo)題上
        return goods;
    }
    /**
     * 定義降級(jí)放啊
     * 1 方法的返回值需要和原方法一樣
     * 2 方法參數(shù)需要和原方法一樣
     */
    public Goods findOne_fallback(int id) {
        Goods goods = new Goods();
        goods.setTitle("降級(jí)了~~~");
        return goods;
    }
}

指定坐標(biāo)

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

Hystrix降級(jí)-服務(wù)消費(fèi)方

  • feign 組件已經(jīng)集成了 hystrix 組件。
  • 定義feign 調(diào)用接口實(shí)現(xiàn)類(lèi),復(fù)寫(xiě)方法,即降級(jí)方法
  • 在 @FeignClient 注解中使用 fallback 屬性設(shè)置降級(jí)處理類(lèi)。
  • 配置開(kāi)啟 feign.hystrix.enabled = true

provider與Fiegin一致

application.yml修改

server:
  port: 9000

eureka:
  instance:
    hostname: localhost # 主機(jī)名
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka
spring:
  application:
    name: hystrix-consumer # 設(shè)置當(dāng)前應(yīng)用的名稱(chēng)。將來(lái)會(huì)在eureka中Application顯示。將來(lái)需要使用該名稱(chēng)來(lái)獲取路徑
#開(kāi)啟feign對(duì)hystrix支持
feign:
  hystrix:
    enabled: true

ConsumerApp修改

package com.itheima.consumer;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.cloud.openfeign.EnableFeignClients;
@EnableDiscoveryClient // 激活DiscoveryClient
@EnableEurekaClient
@SpringBootApplication
@EnableFeignClients //開(kāi)啟Feign的功能
public class ConsumerApp {
    public static void main(String[] args) {
        SpringApplication.run(ConsumerApp.class,args);
    }
}

修改GoodsFeignClient方法

package com.itheima.consumer.feign;
import com.itheima.consumer.domain.Goods;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
@FeignClient(value = "HYSTRIX-PROVIDER",fallback = GoodsFeignClientFallback.class)
public interface GoodsFeignClient {
    @GetMapping("/goods/findOne/{id}")
    public Goods findGoodsById(@PathVariable("id") int id);
}

復(fù)寫(xiě)方法

package com.itheima.consumer.feign;
import com.itheima.consumer.domain.Goods;
import org.springframework.stereotype.Component;
/**
 * Fegin 客戶(hù)端降級(jí)處理類(lèi)
 * 1 定義類(lèi) 實(shí)現(xiàn)Feign 客戶(hù)端接口
 * 2 使用@Component注解將該類(lèi)的Bean加入SpringIOC容器
 */
@Component
public class GoodsFeignClientFallback implements  GoodsFeignClient{
    @Override
    public Goods findGoodsById(int id) {
        Goods goods = new Goods();
        goods.setTitle("又被降級(jí)了~~");
        return goods;
    }
}

Hystrix 熔斷

Hystrix 熔斷機(jī)制,用于監(jiān)控微服務(wù)調(diào)用情況,當(dāng)失敗的情況達(dá)到預(yù)定的閾值(5秒失敗20次),會(huì)打開(kāi)斷路器,拒絕所有請(qǐng)求,直到服務(wù)恢復(fù)正常為止。

  • circuitBreaker.sleepWindowInMilliseconds:監(jiān)控時(shí)間
  • circuitBreaker.requestVolumeThreshold:失敗次數(shù)
  • circuitBreaker.errorThresholdPercentage:失敗率

//設(shè)置Hystrix的超時(shí)時(shí)間 默認(rèn)1s
@HystrixProperty(name="execution.isolation.thread.timeoutInMilliseconds",value = "3000"),
//監(jiān)控的時(shí)間 默認(rèn)5000ms
@HystrixProperty(name="circuitBreaker.sleepWindowInMilliseconds",value = "1000"),
//失敗次數(shù),默認(rèn)20次
@HystrixProperty(name="circuitBreaker.requestVolumeThreshold",value = "2"),
//失敗率 百分之50
@HystrixProperty(name="circuitBreaker.errorThresholdPercentage",value = "100")

Hystrix 熔斷監(jiān)控

  • Hystrix 提供了 Hystrix-dashboard 功能,用于實(shí)時(shí)監(jiān)控微服務(wù)運(yùn)行狀態(tài)。
  • 但是Hystrix-dashboard只能監(jiān)控一個(gè)微服務(wù)。
  • Netflix 還提供了 Turbine ,進(jìn)行聚合監(jiān)控。

Turbine聚合監(jiān)控

搭建監(jiān)控模塊

1. 創(chuàng)建監(jiān)控模塊

創(chuàng)建hystrix-monitor模塊,使用Turbine聚合監(jiān)控多個(gè)Hystrix dashboard功能,

2. 引入Turbine聚合監(jiān)控起步依賴(lài)

<?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">
    <parent>
        <artifactId>hystrix-parent</artifactId>
        <groupId>com.itheima</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>
    <artifactId>hystrix-monitor</artifactId>
    <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>
    	<!--單獨(dú)熔斷監(jiān)控-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-hystrix-dashboard</artifactId>
        </dependency>
		<!--聚合熔斷監(jiān)控-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-turbine</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-netflix-eureka-client</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

3. 修改application.yml

spring:
  application.name: hystrix-monitor
server:
  port: 8769
turbine:
  combine-host-port: true
  # 配置需要監(jiān)控的服務(wù)名稱(chēng)列表
  app-config: hystrix-provider,hystrix-consumer
  cluster-name-expression: "'default'"
  aggregator:
    cluster-config: default
  #instanceUrlSuffix: /actuator/hystrix.stream
eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/

4. 創(chuàng)建啟動(dòng)類(lèi)

@SpringBootApplication
@EnableEurekaClient
@EnableTurbine //開(kāi)啟Turbine 很聚合監(jiān)控功能
@EnableHystrixDashboard //開(kāi)啟Hystrix儀表盤(pán)監(jiān)控功能
public class HystrixMonitorApp {
    public static void main(String[] args) {
        SpringApplication.run(HystrixMonitorApp.class, args);
    }
}

修改被監(jiān)控模塊

需要分別修改 hystrix-provider 和 hystrix-consumer 模塊:

1、導(dǎo)入依賴(lài):

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

2、配置Bean

此處為了方便,將其配置在啟動(dòng)類(lèi)中。

@Bean
    public ServletRegistrationBean getServlet() {
        HystrixMetricsStreamServlet streamServlet = new HystrixMetricsStreamServlet();
        ServletRegistrationBean registrationBean = new ServletRegistrationBean(streamServlet);
        registrationBean.setLoadOnStartup(1);
        registrationBean.addUrlMappings("/actuator/hystrix.stream");
        registrationBean.setName("HystrixMetricsStreamServlet");
        return registrationBean;
    }

3、啟動(dòng)類(lèi)上添加注解@EnableHystrixDashboard

@EnableDiscoveryClient
@EnableEurekaClient
@SpringBootApplication
@EnableFeignClients 
@EnableHystrixDashboard // 開(kāi)啟Hystrix儀表盤(pán)監(jiān)控功能
public class ConsumerApp {
    public static void main(String[] args) {
        SpringApplication.run(ConsumerApp.class,args);
    }
    @Bean
    public ServletRegistrationBean getServlet() {
        HystrixMetricsStreamServlet streamServlet = new HystrixMetricsStreamServlet();
        ServletRegistrationBean registrationBean = new ServletRegistrationBean(streamServlet);
        registrationBean.setLoadOnStartup(1);
        registrationBean.addUrlMappings("/actuator/hystrix.stream");
        registrationBean.setName("HystrixMetricsStreamServlet");
        return registrationBean;
    }
}

啟動(dòng)測(cè)試

1、啟動(dòng)服務(wù):

  • eureka-server
  • hystrix-provider
  • hystrix-consumer
  • hystrix-monitor

2、訪問(wèn):

在瀏覽器訪問(wèn)http://localhost:8769/hystrix/ 進(jìn)入Hystrix Dashboard界面

界面中輸入監(jiān)控的Url地址 http://localhost:8769/turbine.stream,監(jiān)控時(shí)間間隔2000毫秒和title,如下圖

  • 實(shí)心圓:它有顏色和大小之分,分別代表實(shí)例的監(jiān)控程度和流量大小。如上圖所示,它的健康度從綠色、黃色、橙色、紅色遞減。通過(guò)該實(shí)心圓的展示,我們就可以在大量的實(shí)例中快速的發(fā)現(xiàn)故障實(shí)例和高壓力實(shí)例。
  • 曲線(xiàn):用來(lái)記錄 2 分鐘內(nèi)流量的相對(duì)變化,我們可以通過(guò)它來(lái)觀察到流量的上升和下降趨勢(shì)。

到此這篇關(guān)于SpringCloud Hystrix熔斷器使用方法介紹的文章就介紹到這了,更多相關(guān)SpringCloud Hystrix熔斷器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Spring Aop 源碼增強(qiáng)獲取分享

    Spring Aop 源碼增強(qiáng)獲取分享

    這篇文章主要介紹了Spring Aop 源碼增強(qiáng)獲取分享,文章圍繞主題的內(nèi)容展開(kāi)Spring Aop的相關(guān)介紹,具有一定的參考價(jià)值需要的小伙伴可以參考一下
    2022-05-05
  • Java實(shí)現(xiàn)簡(jiǎn)易俄羅斯方塊

    Java實(shí)現(xiàn)簡(jiǎn)易俄羅斯方塊

    這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)簡(jiǎn)易俄羅斯方塊,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • mybatis plus自動(dòng)生成器解析(及遇到的坑)

    mybatis plus自動(dòng)生成器解析(及遇到的坑)

    這篇文章主要介紹了mybatis-plus自動(dòng)生成器及遇到的坑,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • Mybatis in條件傳參的三種實(shí)現(xiàn)方式(直接$,List,[])

    Mybatis in條件傳參的三種實(shí)現(xiàn)方式(直接$,List,[])

    這篇文章主要介紹了Mybatis in條件傳參的三種實(shí)現(xiàn)方式(直接$,List,[]),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • Java日常練習(xí)題,每天進(jìn)步一點(diǎn)點(diǎn)(45)

    Java日常練習(xí)題,每天進(jìn)步一點(diǎn)點(diǎn)(45)

    下面小編就為大家?guī)?lái)一篇Java基礎(chǔ)的幾道練習(xí)題(分享)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧,希望可以幫到你
    2021-07-07
  • 詳解Java ScheduledThreadPoolExecutor的踩坑與解決方法

    詳解Java ScheduledThreadPoolExecutor的踩坑與解決方法

    最近項(xiàng)目上反饋某個(gè)重要的定時(shí)任務(wù)突然不執(zhí)行了,很頭疼,開(kāi)發(fā)環(huán)境和測(cè)試環(huán)境都沒(méi)有出現(xiàn)過(guò)這個(gè)問(wèn)題。定時(shí)任務(wù)采用的是ScheduledThreadPoolExecutor,后來(lái)一看代碼發(fā)現(xiàn)踩了一個(gè)大坑。本文就來(lái)和大家聊聊這次的踩坑記錄與解決方法,需要的可以參考一下
    2022-10-10
  • SpringMVC的Dispatcher解讀

    SpringMVC的Dispatcher解讀

    這篇文章主要介紹了SpringMVC的Dispatcher用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • Spring?MVC的三種異常處理方式實(shí)例詳解

    Spring?MVC的三種異常處理方式實(shí)例詳解

    在SpringMVC 中,不管是編譯異常還是運(yùn)行時(shí)異常,都可以最終由 SpringMVC提供的異常處理器進(jìn)行統(tǒng)一處理,這樣就避免了隨時(shí)隨地捕獲處理的繁瑣性,這篇文章主要介紹了Spring?MVC的三種異常處理方式?,需要的朋友可以參考下
    2024-01-01
  • java微信開(kāi)發(fā)API第二步 獲取和回復(fù)消息

    java微信開(kāi)發(fā)API第二步 獲取和回復(fù)消息

    這篇文章主要為大家詳細(xì)介紹了java微信開(kāi)發(fā)API第二步,獲取消息和回復(fù)消息,感興趣的小伙伴們可以參考一下
    2016-06-06
  • SpringBoot項(xiàng)目從18.18M瘦身到0.18M的實(shí)現(xiàn)

    SpringBoot項(xiàng)目從18.18M瘦身到0.18M的實(shí)現(xiàn)

    本文主要介紹了SpringBoot項(xiàng)目從18.18M瘦身到0.18M的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01

最新評(píng)論