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

SpringCloud hystrix服務(wù)降級學(xué)習(xí)筆記

 更新時間:2022年10月31日 10:00:18   作者:游坦之  
什么是服務(wù)降級?當(dāng)服務(wù)器壓力劇增的情況下,根據(jù)實際業(yè)務(wù)情況及流量,對一些服務(wù)和頁面有策略的不處理或換種簡單的方式處理,從而釋放服務(wù)器資源以保證核心交易正常運(yùn)作或高效運(yùn)作

一、Hystrix簡介

1、Hystrix是什么

 流量高峰時,一個單節(jié)點(diǎn)的宕機(jī)或延遲,會迅速導(dǎo)致所有服務(wù)負(fù)載達(dá)到飽和。應(yīng)用中任何一個可能通過網(wǎng)絡(luò)訪問其他服務(wù)的節(jié)點(diǎn),都有可能成為造成潛在故障的來源。更嚴(yán)重的是,還可能導(dǎo)致服務(wù)之間的延遲增加,占用隊列、線程等系統(tǒng)資源,從而導(dǎo)致多系統(tǒng)之間的級聯(lián)故障。

簡單的說,當(dāng)服務(wù)器依次請求A->P->H->I時,如果其中一個發(fā)生了故障,都有可能導(dǎo)致整個流程失敗,或者降低整個流程的效率。

更嚴(yán)重的是,當(dāng)網(wǎng)絡(luò)請求是通過第三方的一個黑盒客戶端來發(fā)起時,實現(xiàn)細(xì)節(jié)都被隱藏起來了,而且還可能頻繁變動,這樣發(fā)生問題時就很難監(jiān)控和改動。如果這個第三方還是通過傳遞依賴的,主應(yīng)用程序中根本沒有顯示地寫出調(diào)用的代碼,那就更難了。

網(wǎng)絡(luò)連接失敗或者有延遲,服務(wù)將會產(chǎn)生故障或者響應(yīng)變慢,最終反應(yīng)成為一個 bug。

所有上述表現(xiàn)出來的故障或延遲,都需要一套管理機(jī)制,將節(jié)點(diǎn)變得相對獨(dú)立,這樣任何一個單節(jié)點(diǎn)故障,都至少不會拖垮整個系統(tǒng)的可用性。

  所以Hystrix就是為了解決請求序列中請求出現(xiàn)問題的情況,核心原則就是丟車保帥,如果一個請求出現(xiàn)問題,常見的有兩種方案:

一種是按照原來的方案再來一次,這是有成功的可能的。

一種是只是反饋給用戶這個請求有問題,出故障的請求不會影響到序列中其他的請求。

2、Hystrix能干什么

1、服務(wù)熔斷

2、服務(wù)降級

3、數(shù)據(jù)監(jiān)控

二、服務(wù)熔斷

1、服務(wù)熔斷簡介

熔斷機(jī)制是賭贏雪崩效應(yīng)的一種微服務(wù)鏈路保護(hù)機(jī)制。

當(dāng)扇出鏈路的某個微服務(wù)不可用或者響應(yīng)時間太長時,會進(jìn)行服務(wù)的降級,進(jìn)而熔斷該節(jié)點(diǎn)微服務(wù)的調(diào)用,快速返回錯誤的響應(yīng)信息。檢測到該節(jié)點(diǎn)微服務(wù)調(diào)用響應(yīng)正常后恢復(fù)調(diào)用鏈路。在SpringCloud框架里熔斷機(jī)制通過Hystrix實現(xiàn)。Hystrix會監(jiān)控微服務(wù)間調(diào)用的狀況,當(dāng)失敗的調(diào)用到一定閥值缺省是5秒內(nèi)20次調(diào)用失敗,就會啟動熔斷機(jī)制。熔斷機(jī)制的注解是:@HystrixCommand。

服務(wù)熔斷解決如下問題:

  • 當(dāng)所依賴的對象不穩(wěn)定時,能夠起到快速失敗的目的;
  • 快速失敗后,能夠根據(jù)一定的算法動態(tài)試探所依賴對象是否恢復(fù)。

2、配置pom.xml

首先新建一個module,和springcloud-provider-dept-8001一模一樣(名字除外),修改一下application.yaml,一個是端口(也可以不改,最好修改一下,避免端口沖突),另一個是instance-id,這樣在尤里卡中可以分辨出來。

需要引入hystrix的依賴,和feign一樣,只是把feign換成hystrix

 <!--引入hystrix依賴-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-hystrix</artifactId>
            <version>1.4.6.RELEASE</version>
        </dependency>

3、配置application.yaml

和springcloud-provider-dept-8001一樣,只需要修改一下端口號和instance-id

#端口號
server:
  port: 8001

#配置數(shù)據(jù)庫
spring:
  datasource:
    url: jdbc:mysql:///dp80?serverTimezone=UTC
    username: root
    password: 200201203332
    driver-class-name: com.mysql.jdbc.Driver
  application:
    name: springcloud-provider-dept
debug: true

#配置Eureka的配置
eureka:
  client:
    service-url:
      defaultZone: http://localhost:7001/eureka/
  instance:
    instance-id: springcloud-provider-8001

info:  #autuator監(jiān)控信息
  app.name: rainhey-springcloud
  company.name: www.rainhey.com

4、修改Controller

@HystrixCommand注解

用來處理服務(wù)熔斷和服務(wù)降級,屬性和方法可以點(diǎn)進(jìn)去查看。

@HystrixCommand注解通常放到方法之上,當(dāng)這個方法拋出異常的時候,系統(tǒng)不會立刻停止處理異常,而是先找Hystrix里面綁定的備用方法,然后去執(zhí)行備用方法。

那么@HystrixCommand如何綁定備用方法呢?見下圖

@HystrixCommand注釋通過內(nèi)部屬性fallbackMethod綁定方法,具體步驟是@HystrixCommand(fallbackMethod = “備用方法名”)

package com.you.Controller;
import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand;
import com.you.mapper.DeptMapper;
import com.you.pojo.Dept;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cloud.client.ServiceInstance;
import org.springframework.cloud.client.discovery.DiscoveryClient;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
@RestController
@ResponseBody
@Component
public class DeptController {
    @Autowired
    DeptMapper deptMapper;
    @GetMapping("/dept/aDept/{id}")
    @HystrixCommand(fallbackMethod = "hystrixGetDeptOfId")
    public Dept getDeptOfId(@PathVariable("id") Long id)
    {
        System.out.println("進(jìn)來了,id是:"+id);
        Dept dept = deptMapper.finaDeptOfId(id);
        if(dept==null)
        {
            throw new RuntimeException("id=>"+id+"不存在該用戶,或者信息沒有找到!");
        }
        return dept;
    }
    /* 備用方案 */
    public Dept hystrixGetDeptOfId(@PathVariable("id") Long id)
    {
            Dept dept = new Dept();
            dept.setDeptno(id);
            dept.setDeptname("id=>"+id+"不存在該用戶,或信息沒有找到!@Hystrix");
            dept.setDb_source("no info in datebase");
            System.out.println("dept的值是:"+dept);
            return dept;
    }
}

5、修改啟動類

從前面的4篇文章里我們了解到,每次用到新的技術(shù),啟動類里都會增加一個新的注解,那么?Hystrix的注解是什么呢?@EnableCircuitBreaker,只要把這個注解加在主啟動類上,那么主啟動類就可以處理服務(wù)熔斷了。

6、效果圖

不開熔斷機(jī)制

開了熔斷機(jī)制

三、服務(wù)降級

1、什么是服務(wù)降級

服務(wù)降級是指 當(dāng)服務(wù)器壓力劇增的情況下,根據(jù)實際業(yè)務(wù)情況及流量,對一些服務(wù)和頁面有策略的不處理,或換種簡單的方式處理,從而釋放服務(wù)器資源以保證核心業(yè)務(wù)正常運(yùn)作或高效運(yùn)作。說白了,就是盡可能的把系統(tǒng)資源讓給優(yōu)先級高的服務(wù)。

例如假設(shè)有三個服務(wù)器ABC,在某一段時間,訪問A的用戶特別多,導(dǎo)致A服務(wù)器快要崩潰了,這時候訪問B、C的用戶很少,那么我暫時先把B、C停掉,用來處理A。

服務(wù)降級主要用于什么場景呢?當(dāng)整個微服務(wù)架構(gòu)整體的負(fù)載超出了預(yù)設(shè)的上限閾值或即將到來的流量預(yù)計將會超過預(yù)設(shè)的閾值時,為了保證重要或基本的服務(wù)能正常運(yùn)行,可以將一些 不重要 或 不緊急 的服務(wù)或任務(wù)進(jìn)行服務(wù)的 延遲使用 或 暫停使用。

降級的方式可以根據(jù)業(yè)務(wù)來,可以延遲服務(wù),比如延遲給用戶增加積分,只是放到一個緩存中,等服務(wù)平穩(wěn)之后再執(zhí)行 ;或者在粒度范圍內(nèi)關(guān)閉服務(wù),比如關(guān)閉相關(guān)文章的推薦。

2、DeptClientFailBackFactory類

在springcloud-api模塊下的service包中新建降級配置,DeptClientServiceFallBackFactory.java。同時實現(xiàn)其方法,他的返回類型就是我們寫服務(wù)的接口。

package com.you.service;
import com.you.pojo.Dept;
import feign.hystrix.FallbackFactory;
import org.springframework.stereotype.Component;
/*?。?!降級?。?!*/
@Component  //注冊到容器里面去
public class DeptClientFailBackFactory implements FallbackFactory {
    @Override
    public DeptClientService create(Throwable throwable) {
        return new DeptClientService() {
            @Override
            public Dept getDeptOfId(Long id) {
                Dept dept = new Dept();
                dept.setDeptno(id);
                dept.setDeptname("id=>"+id+"沒有對應(yīng)的信息,客戶端提供了降級的信息,這個服務(wù)現(xiàn)在被關(guān)閉了!");
                dept.setDb_source("沒有數(shù)據(jù)");
                return dept;
            }
        };
    }
}

3、添加注解

在DeptClientService中指定降級配置:DeptClientServiceFallBackFactory

package com.you.service;
import com.you.pojo.Dept;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
@Component
/*@FeignClient:value的值即為 服務(wù)的名字,fallbackFactory的值即為 實現(xiàn)FallbackFactory類的名字 */
@FeignClient(value = "SPRINGCLOUD-PROVIDER-DEPT",fallbackFactory = DeptClientFailBackFactory.class)
public interface DeptClientService {
    @GetMapping("/dept/aDept/{id}")
    public Dept getDeptOfId(@PathVariable("id") Long id);
}

4、修改application.yaml

為的是開啟服務(wù),但切記此處修改的application是springcloud-consumer-dept-feign下的application.yaml,添加如下代碼

#開啟降級 feign-hystrix
feign:
  hystrix:
    enabled: true

5、效果圖

依次啟動springcloud-eureka-7001、springcloud-consumer-dept-feign、springcloud-provider-dept-8001,訪問服務(wù)

正確打開服務(wù)

現(xiàn)在,停掉這個springcloud-provider-dept-8001,模擬服務(wù)降級中暫時關(guān)閉的一些端口。

8001端口的服務(wù)被停掉了,這時候刷新頁面。

端口是可以訪問的,只是顯示了我們設(shè)計的文字

四、DashBorder

1、新建一個module

新建一個名為springcloud-consumer-hystrix-dashborder的module

2、pom.xml配置

將springcloud-provider-dept-8001的依賴如復(fù)制過來,并且增加上dashborder的依賴

 <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>com.you</groupId>
            <artifactId>springcloud-api</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>
        <!--引入Eureka的依賴-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-eureka</artifactId>
            <version>1.4.6.RELEASE</version>
        </dependency>
        <!--引入ribbon-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-ribbon</artifactId>
            <version>1.4.6.RELEASE</version>
        </dependency>
        <!--引入DashBorder-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-hystrix-dashboard</artifactId>
            <version>1.4.6.RELEASE</version>
        </dependency>
        <!--引入hystrix依賴-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-hystrix</artifactId>
            <version>1.4.6.RELEASE</version>
        </dependency>
    </dependencies>

3、配置application.yml

只需要配置端口號

server:
  port: 9001

4、配置啟動類

創(chuàng)建一個名為DeptConsumerDashBorder_9001的JAVA類

package com.you;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.hystrix.dashboard.EnableHystrixDashboard;
@SpringBootApplication
@EnableHystrixDashboard
public class DeptConsumerDashBorder_9001 {
    public static void main(String[] args) {
        SpringApplication.run(DeptConsumerDashBorder_9001.class,args);
    }
}

5、添加被監(jiān)控的類

給springcloud-provider-dept-hystrix-8001模塊下的主啟動類添加如下代碼,添加監(jiān)控

package com.you;
import com.netflix.hystrix.contrib.metrics.eventstream.HystrixMetricsStreamServlet;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.web.servlet.ServletRegistrationBean;
import org.springframework.cloud.client.circuitbreaker.EnableCircuitBreaker;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.context.annotation.Bean;
@SpringBootApplication
@EnableEurekaClient
@EnableDiscoveryClient
/*對熔斷的支持*/
@EnableCircuitBreaker
public class DeptApplication_Hystrix_8001 {
    public static void main(String[] args) {
        SpringApplication.run(DeptApplication_Hystrix_8001.class,args);
    }
    @Bean
    public ServletRegistrationBean hystrixMetricsStreamServlet(){
        ServletRegistrationBean registrationBean = new ServletRegistrationBean(new HystrixMetricsStreamServlet());
        //訪問該頁面就是監(jiān)控頁面
        registrationBean.addUrlMappings("/actuator/hystrix.stream");
        return registrationBean;
    }
}

6、效果圖

啟動springcloud-eureka-7001、springcloud-consumer-hystrix-dashborder、springcloud-provider-dept-hystrix-8001

在7001尤里卡界面,看到springcloud-provider-dept-hystrix-8001被注冊進(jìn)來。

訪問8011,輸入http://localhost:8011/dept/aDept/1(我設(shè)置的端口號是8011),可以看到被成功訪問。

訪問http://localhost:8011/actuator/hystrix.stream,看到如下效果

訪問9001,地址輸入http://localhost:9001/hystrix,看到如下界面

將地址填入,http://localhost:8011/actuator/hystrix.stream

刷新這個界面,下面的圖像會隨之變化

到此這篇關(guān)于SpringCloud hystrix服務(wù)降級學(xué)習(xí)筆記的文章就介紹到這了,更多相關(guān)SpringCloud hystrix內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解Java如何有效避免空指針

    詳解Java如何有效避免空指針

    空指針,也就是NullPointerException 簡稱NPE的,怕一下子寫出NPE,部分的伙伴看不懂,索性就改成了空指針,在實際的開發(fā)中,我們最討厭的就是遇到空指針了,業(yè)務(wù)跑著跑著發(fā)現(xiàn)了空指針,所以本文詳細(xì)介紹了Java如何有效的避免空指針,需要的朋友可以參考下
    2023-12-12
  • MyBatis在SQL語句中如何獲取list的大小

    MyBatis在SQL語句中如何獲取list的大小

    這篇文章主要介紹了MyBatis在SQL語句中如何獲取list的大小問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • Java壓縮文件操作詳解

    Java壓縮文件操作詳解

    這篇文章主要為大家詳細(xì)介紹了如何利用Java語言進(jìn)行壓縮文件操作,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2022-08-08
  • Java中的collection集合類型總結(jié)

    Java中的collection集合類型總結(jié)

    Java的集合類型都是對java.util包中Collection接口的繼承,這里我們主要介紹依賴于collection的一些主分支,一起來看一下Java中的collection集合類型總結(jié)
    2016-05-05
  • MyBatis學(xué)習(xí)教程(六)-調(diào)用存儲過程

    MyBatis學(xué)習(xí)教程(六)-調(diào)用存儲過程

    這篇文章主要介紹了MyBatis學(xué)習(xí)教程(六)-調(diào)用存儲過程的相關(guān)資料,非常不錯,具有參考借鑒價值,感興趣的朋友一起看下吧
    2016-05-05
  • 使用IDEA搭建Hadoop開發(fā)環(huán)境的操作步驟(Window10為例)

    使用IDEA搭建Hadoop開發(fā)環(huán)境的操作步驟(Window10為例)

    經(jīng)過三次重裝,查閱無數(shù)資料后成功完成hadoop在win10上實現(xiàn)偽分布式集群,以及IDEA開發(fā)環(huán)境的搭建。一步一步跟著本文操作可以避免無數(shù)天坑
    2021-07-07
  • Hibernate之環(huán)境搭建及demo分享

    Hibernate之環(huán)境搭建及demo分享

    下面小編就為大家分享一篇Hibernate之環(huán)境搭建及demo,具有很好的參考價值,希望對大家有所幫助
    2017-11-11
  • ElasticSearch之索引模板滾動索引實現(xiàn)詳解

    ElasticSearch之索引模板滾動索引實現(xiàn)詳解

    這篇文章主要為大家介紹了ElasticSearch之索引模板滾動索引實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • 基于SSM框架之個人相冊示例代碼

    基于SSM框架之個人相冊示例代碼

    本篇文章主要介紹了基于SSM框架之個人相冊示例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2017-03-03
  • Spring Boot打war包的實例教程

    Spring Boot打war包的實例教程

    本篇文章主要介紹了Spring Boot打war包的實例教程,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-02

最新評論