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

通過FeignClient如何獲取文件流steam?is?close問題

 更新時間:2022年06月16日 09:27:17   作者:localhost?:8080  
這篇文章主要介紹了通過FeignClient如何獲取文件流steam?is?close問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

FeignClient獲取文件流 steam is close問題

inputstream.read 報錯 steam is close

原因

idea debug啟動導致

解決辦法

直接啟動

FeignClient注解參數(shù)

  • name:指定FeignClient的名稱,如果項目使用了Ribbon,name屬性會作為微服務的名稱,用于服務發(fā)現(xiàn)
  • url: url一般用于調試,可以手動指定@FeignClient調用的地址
  • decode404:當發(fā)生http 404錯誤時,如果該字段位true,會調用decoder進行解碼,否則拋出FeignException
  • configuration: Feign配置類,可以自定義Feign的Encoder、Decoder、LogLevel、Contract
  • fallback: 定義容錯的處理類,當調用遠程接口失敗或超時時,會調用對應接口的容錯邏輯,fallback指定的類必須實現(xiàn)@FeignClient標記的接口
  • fallbackFactory: 工廠類,用于生成fallback類示例,通過這個屬性我們可以實現(xiàn)每個接口通用的容錯邏輯,減少重復的代碼
  • path: 定義當前FeignClient的統(tǒng)一前綴

日志級別配置

默認Feign是不打印任何日志的,下面我們來開啟Feign的日志,F(xiàn)eign有四種日志級別:

  • NONE【性能最佳,適用于生產(chǎn)】:不記錄任何日志(默認值)。
  • BASIC【適用于生產(chǎn)環(huán)境追蹤問題】:僅記錄請求方法、URL、響應狀態(tài)代碼以及執(zhí)行時間。
  • HEADERS:記錄BASIC級別的基礎上,記錄請求和響應的header。
  • FULL【比較適用于開發(fā)及測試環(huán)境定位問題】:記錄請求和響應的header、body和元數(shù)據(jù)。

在application.yml 中添加以下內(nèi)容,將該Feign接口的日志級別設置為DEBUG:

# 定義feign客戶端所在的路徑,需要設置日志級別為debug
logging.level: com.example.customer.service.CustomerService: debug
# user為服務名,單個配置客戶端日志級別設置,如果需要全局配置,把user更換為default
feign.client.config.user.loggerLevel: FULL

調用日志信息截圖

2020-06-07 14:06:27.671 DEBUG 24961 --- [nio-8081-exec-3] c.e.customer.service.CustomerService     : [CustomerService#getUser] ---> GET http://user/user HTTP/1.1
2020-06-07 14:06:27.671 DEBUG 24961 --- [nio-8081-exec-3] c.e.customer.service.CustomerService     : [CustomerService#getUser] ---> END HTTP (0-byte body)
2020-06-07 14:06:27.678 DEBUG 24961 --- [nio-8081-exec-3] c.e.customer.service.CustomerService     : [CustomerService#getUser] <--- HTTP/1.1 200  (7ms)
2020-06-07 14:06:27.679 DEBUG 24961 --- [nio-8081-exec-3] c.e.customer.service.CustomerService     : [CustomerService#getUser] connection: keep-alive
2020-06-07 14:06:27.679 DEBUG 24961 --- [nio-8081-exec-3] c.e.customer.service.CustomerService     : [CustomerService#getUser] content-type: application/json
2020-06-07 14:06:27.679 DEBUG 24961 --- [nio-8081-exec-3] c.e.customer.service.CustomerService     : [CustomerService#getUser] date: Sun, 07 Jun 2020 06:06:27 GMT
2020-06-07 14:06:27.679 DEBUG 24961 --- [nio-8081-exec-3] c.e.customer.service.CustomerService     : [CustomerService#getUser] keep-alive: timeout=60
2020-06-07 14:06:27.679 DEBUG 24961 --- [nio-8081-exec-3] c.e.customer.service.CustomerService     : [CustomerService#getUser] transfer-encoding: chunked
2020-06-07 14:06:27.679 DEBUG 24961 --- [nio-8081-exec-3] c.e.customer.service.CustomerService     : [CustomerService#getUser]
2020-06-07 14:06:27.679 DEBUG 24961 --- [nio-8081-exec-3] c.e.customer.service.CustomerService     : [CustomerService#getUser] {"id":1,"name":"test","phone":"119"}
2020-06-07 14:06:27.679 DEBUG 24961 --- [nio-8081-exec-3] c.e.customer.service.CustomerService     : [CustomerService#getUser] <--- END HTTP (36-byte body)

服務超時、重試、降級和熔斷

·超時 Feign接口調用分兩層,Ribbon(負載均衡)和Hystrix(熔斷器)的調用,因此Feign的超時時間就是ribbon的超時時間和Hystrix的超時時間的結合

·重試 使用Ribbon

設置Ribbon重試次數(shù)

ribbon:
  #連接超時時間
  ConnectTimeout: 1000
  #讀超時時間
  ReadTimeout: 1000
  ##同一臺實例最大重試次數(shù),不包括首次調用
  MaxAutoRetries: 0
  #重試負載均衡其他的實例最大重試次數(shù),不包括首次調用
  MaxAutoRetriesNextServer: 1
  #是否所有操作都重試,設置false時,只會對get請求進行重試;如果設置為true,便會對所有的請求進行重試,如果是put或post等寫操作,如果服務器接口沒做冪等性,慎用;
  OkToRetryOnAllOperations: false

負載均衡配置

#服務名
user:
  ribbon:
    #選擇隨機算法
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule

Ribbon Eager加載

默認情況下Ribbon是懶加載的——首次請求Ribbon相關類才會初始化,這會導致首次請求過慢的問題,你可以配置饑餓加載,讓Ribbon在應用啟動時就初始化。

ribbon:
  eager-load:
    enabled: true
    # 多個用,分隔
    clients: user

降級和熔斷使用hystrix

如果重試期間,調用時間超過了 Hystrix熔斷的超時時間,便會立即熔斷,進行FallBack

# 開啟hystrix
feign.hystrix.enabled: true 
# hystrix的超時時間 時間設置需要根據(jù)實際業(yè)務場景計算得出
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds: 10000

Fallback配置

@FeignClient(name = "user", fallback = CustomerFeignClientFallback.class)
public interface CustomerService {
 
  /**
   * 獲取用戶信息
   *
   * @return 用戶信息
   */
  @GetMapping("/user")
  UserDTO getUser ();
 
  @Component
  public class CustomerFeignClientFallback implements CustomerService {
 
    @Override
    public UserDTO getUser () {
     //todo 回退邏輯
      return new UserDTO().setName("服務降級");
    }
  }
}
@FeignClient(name = "user", fallbackFactory = CustomerFeignClientFallbackFactory.class)
public interface CustomerService {
 
  /**
   * 獲取用戶信息
   *
   * @return 用戶信息
   */
  @GetMapping("/user")
  UserDTO getUser ();
 
  @Component
  @Slf4j
  public class CustomerFeignClientFallbackFactory implements FallbackFactory<CustomerService> {
 
    @Override
    public CustomerService getUser () {
       //todo 回退邏輯
      return new UserDTO().setName("服務降級");
    }
  }
}

配置

logging:
  level:
    com.example.customer.service.CustomerService: debug
#全局配置,單個服務配置把default替換為需要設置的服務名
feign:
  client.config.default.loggerLevel: FULL
  okhttp.enabled: true
  #熔斷與回退
  hystrix.enabled: true
#重試機制
ribbon:
  #連接超時時間
  ConnectTimeout: 2000
  #讀超時時間
  ReadTimeout: 2000
  ##同一臺實例最大重試次數(shù),不包括首次調用
  MaxAutoRetries: 0
  #重試負載均衡其他的實例最大重試次數(shù),不包括首次調用
  MaxAutoRetriesNextServer: 1
  #是否所有操作都重試
  OkToRetryOnAllOperations: false
# Hystrix的超時時間
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds: 10000

有關Feign超時時間易混淆概念

Feign超時時間

feign.client.config.default.connectTimeout=10000 //Feign的連接建立超時時間,默認為10秒
feign.client.config.default.readTimeout=60000 //Feign的請求處理超時時間,默認為60

Ribbon 超時時間

ribbon.ReadTimeout=1000 //處理請求的超時時間,默認為1秒
ribbon.ConnectTimeout=1000 //連接建立的超時時長,默認1秒

Hystrix 超時時間

hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds=3000 #熔斷器的超時時長默認1秒

以上各種超時配置,如果都存在,則時間小的配置生效

小提示

  • Feign的底層是調用ribbon來實現(xiàn)負載均衡的,為了不和ribbon的重試機制沖突不需要配置feign超時時間和重試功能,只需配置ribbon和hystrix超時時間即可。
  • Ribbon超時時間必須小于hysrix超時設置,這樣才能觸發(fā)ribbon重試,ribbon重試分為兩種情況,同一實例重試和負載均衡的不同實例重試,默認為1次和0次
  • Feign的默認配置,是不啟用hystrix,需要開啟feign.hystrix.enabled=true,這樣hystrix的相關配置才可以在Feign中生效。
  • Hystrix的超時時間=Ribbon的重試次數(shù)(包含首次) * (ribbon.ReadTimeout + ribbon.ConnectTimeout)
  • Ribbon超時但Hystrix沒有超時的情況下,Ribbon便會采取重試機制;而重試期間如果時間超過了Hystrix的超時配置則會立即被熔斷(fallback)
  • 關系圖

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • java從mysql導出數(shù)據(jù)的具體實例

    java從mysql導出數(shù)據(jù)的具體實例

    這篇文章主要介紹了java從mysql導出數(shù)據(jù)的具體實例,有需要的朋友可以參考一下
    2013-12-12
  • 詳解Java中l(wèi)og4j.properties配置與加載應用

    詳解Java中l(wèi)og4j.properties配置與加載應用

    這篇文章主要介紹了 log4j.properties配置與加載應用的相關資料,需要的朋友可以參考下
    2018-02-02
  • Spring Cloud Gateway全局通用異常處理的實現(xiàn)

    Spring Cloud Gateway全局通用異常處理的實現(xiàn)

    這篇文章主要介紹了Spring Cloud Gateway全局通用異常處理的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-05-05
  • Servlet中/和/*的區(qū)別詳解

    Servlet中/和/*的區(qū)別詳解

    本文將分析/和/*的區(qū)別這個老生常談的問題,但是很多時候看完就忘了,關于此問題這一篇文章就夠了,它將成為你的永久記憶,感興趣的可以了解一下
    2021-07-07
  • 如何用struts調用支付寶接口

    如何用struts調用支付寶接口

    以下為大家介紹如何用struts調用支付寶接口的例子。
    2013-04-04
  • Java基礎第二篇方法與數(shù)據(jù)成員

    Java基礎第二篇方法與數(shù)據(jù)成員

    在上一篇文章中介紹了Java基礎 從HelloWorld到面向對象,我們初步了解了對象(object)。對象中的數(shù)據(jù)成員表示對象的狀態(tài)。對象可以執(zhí)行方法,表示特定的動作。這篇文章我們進一步深入到對象。了解Java中方法與數(shù)據(jù)成員的一些細節(jié)。
    2021-09-09
  • Java的堵塞隊列BlockingQueue詳解

    Java的堵塞隊列BlockingQueue詳解

    這篇文章主要介紹了Java的堵塞隊列BlockingQueue詳解,阻塞隊列常用于生產(chǎn)者和消費者的場景,生產(chǎn)者是向隊列里添加元素的線程,消費者是從隊列里取元素的線程,需要的朋友可以參考下
    2023-12-12
  • JAVA中通過Hibernate-Validation進行參數(shù)驗證

    JAVA中通過Hibernate-Validation進行參數(shù)驗證

    這篇文章主要介紹了JAVA中通過Hibernate-Validation進行參數(shù)驗證,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-04-04
  • 帶你了解Java Maven的打包操作

    帶你了解Java Maven的打包操作

    這篇文章主要介紹了Maven打包的相關知識,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09
  • SpringBoot整合RabbitMQ處理死信隊列和延遲隊列

    SpringBoot整合RabbitMQ處理死信隊列和延遲隊列

    這篇文章將通過示例為大家詳細介紹SpringBoot整合RabbitMQ時如何處理死信隊列和延遲隊列,文中的示例代碼講解詳細,需要的可以參考一下
    2022-05-05

最新評論