參考: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