Spring Cloud Zuul使用和配置

參考:http://cloud.spring.io/spring-cloud-netflix/single/spring-cloud-netflix.html#_zuul_timeouts

1.Zuul超時配置

下面是Spring官方文檔描述:


Snipaste_2018-10-22_13-41-03.png

在配置zuul的超時機(jī)制時,可選的兩組參數(shù)包括:

ribbon.ReadTimeout
ribbon.SocketTimeout

以及

zuul.host.connect-timeout-millis
zuul.host.socket-timeout-millis

兩者作用的最大區(qū)別是,以服務(wù)名(可以是注冊中心發(fā)現(xiàn)或者自定義serviceId)進(jìn)行代理的那些服務(wù),它們的超時由ribbon控制; 對于指定url路由的服務(wù),超時則由zuul.host設(shè)定

2.Hystrix超時熔斷設(shè)置:

參考Spring官方文檔描述:

Snipaste_2018-10-22_15-10-15.png

當(dāng)設(shè)置好ribbon的timeout時,Hytrix的熔斷時間會有默認(rèn)值的,由上圖所述公式計算得出。
一旦單獨設(shè)置hystrix.command.xxx.execution.isolation.thread.timeoutInMilliseconds則會覆蓋default的設(shè)定.

  • 需要注意的是execution.isolation.thread.timeoutInMilliseconds參數(shù)的作用情況: 在THREAD模式下,達(dá)到超時時間,可以中斷;在SEMAPHORE模式下,會等待執(zhí)行完成后,再去判斷是否超時。

因此如果想要按照達(dá)到超時即中斷的目的,合理的配置如下:

hystrix:
  command:
    default:
      execution:
        isolation:
          thread:
            timeoutInMilliseconds: 6000
# zuul proxy configuration
zuul:
  ribbon-isolation-strategy: THREAD

更多關(guān)于hystrix的配置說明參考:https://blog.csdn.net/tongtong_use/article/details/78611225

3.Zuul大文件上傳配置

首先需要配置關(guān)閉spring自帶的multipart配置(因為Spring默認(rèn)提供的MultipartResolver會將文件緩存到磁盤以及內(nèi)存中,對于大文件而言,這種服務(wù)器緩存是不可接受):

spring:
  servlet:  
    multipart:  
      enabled: false

然后配置啟用Zuul servlet:

zuul:
  servletPath: /zuul

如果你的service之前的訪問地址是:

  • http://{{ServerPath}}/api/tcnbasicsystem/file
    那么之后的訪問地址就是:
  • http://{{ServerPath}}/zuul/api/tcnbasicsystem/file

需要注意的是,發(fā)送請求時,需要帶有請求頭:

Transfer-Encoding: chunked

詳情參考:uploading-files-through-zuul

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容