Sentinel整合Feign流程詳細講解
修改84模塊
84消費者調用提供者9003
Feign組件一般是消費側
重點依賴
<!--SpringCloud openfeign --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency>
激活Sentinel對Feign的支持
spring:
application:
name: nacos-order-consumer
cloud:
nacos:
discovery:
#Nacos服務注冊中心地址
server-addr: localhost:8848
sentinel:
transport:
#配置Sentinel dashboard地址
dashboard: localhost:8080
#默認8719端口,假如被占用會自動從8719開始依次+1掃描,直至找到未被占用的端口
port: 8719
management:
endpoints:
web:
exposure:
include: '*'
# 激活Sentinel對Feign的支持
feign:
sentinel:
enabled: true
# 激活Sentinel對Feign的支持
feign:
sentinel:
enabled: true
增加業(yè)務類接口
@FeignClient(value = "nacos-payment-provider",fallback = PaymentFallbackService.class)//調用中關閉9003服務提供者 public interface PaymentService { @GetMapping(value = "/paymentSQL/{id}") public CommonResult<Payment> paymentSQL(@PathVariable("id") Long id); }
@FeignClient(value = "nacos-payment-provider",fallback =PaymentFallbackService.class)//調用中關閉9003服務提供者
@Component public class PaymentFallbackService implements PaymentService { @Override public CommonResult<Payment> paymentSQL(Long id) { return new CommonResult<>(444,"服務降級返回,沒有該流水信息",new Payment(id, "errorSerial......")); } }
調用失敗的時候,就會調用重寫的方法
修改控制類
//==================OpenFeign @Resource private PaymentService paymentService; @GetMapping(value = "/consumer/openfeign/{id}") public CommonResult<Payment> paymentSQL(@PathVariable("id") Long id) { if(id == 4) { throw new RuntimeException("沒有該id"); } return paymentService.paymentSQL(id); }
添加@EnableFeignClients啟動Feign的功能
@EnableDiscoveryClient @SpringBootApplication @EnableFeignClients public class OrderNacosMain84 { public static void main(String[] args) { SpringApplication.run(OrderNacosMain84.class, args); } }
測試
啟動9003 9004 84 端口
訪問:http://localhost:84/consumer/paymentSQL/1
測試84調用9003,此時故意關閉9003微服務提供者,看84消費側自動降級,不會被耗死
熔斷框架比較
業(yè)務降級,是指犧牲非核心的業(yè)務功能,保證核心功能的穩(wěn)定運行。簡單來說,要實現優(yōu)雅的業(yè)務降級,需要將功能實現拆分到相對獨立的不同代碼單元,分優(yōu)先級進行隔離。在后臺通過開關控制,降級部分非主流程的業(yè)務功能,減輕系統(tǒng)依賴和性能損耗,從而提升集群的整體吞吐率。
降級的重點是:業(yè)務之間有優(yōu)先級之分。降級的典型應用是:電商活動期間關閉非核心服務,保證核心買買買業(yè)務的正常運行。
到此這篇關于Sentinel整合Feign流程詳細講解的文章就介紹到這了,更多相關Sentinel整合Feign內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
SpringCache常用注解及key中參數值為null問題解析
這篇文章主要介紹了SpringCache常用注解及key中參數值為null的問題解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-09-09Java異常處理UncaughtExceptionHandler使用實例代碼詳解
當一個線程由于未捕獲異常即將終止時,Java虛擬機將使用thread . getuncaughtexceptionhandler()查詢線程的uncaughtException處理程序,并調用處理程序的uncaughtException方法,將線程和異常作為參數傳遞2023-03-03Spring Boot Admin(監(jiān)控工具)的使用
今天我們將會講解一個優(yōu)秀的監(jiān)控工具Spring Boot Admin。 它采用圖形化的界面,讓我們的Spring Boot管理更加簡單,需要的朋友可以參考下2020-02-02