亚洲视频二区_亚洲欧洲日本天天堂在线观看_日韩一区二区在线观看_中文字幕不卡一区

公告:魔扣目錄網(wǎng)為廣大站長提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請做好本站友鏈:【 網(wǎng)站目錄:http://www.430618.com 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

目錄
  • 背景:
  • 問題:
  • 504從哪來:本文的場景下504是nginx返回的。
  • 兩種解決方案
  • 其他問題:
  • 總結(jié)

背景:

Nginx做反向代理,springboot為后端服務(wù)。

問題:

通過瀏覽器向后臺發(fā)起請求夠,由于后臺處理時間長,出現(xiàn)504 Gateway Time-out,實(shí)際后臺程序依然在執(zhí)行。如何解決?

504從哪來:本文的場景下504是nginx返回的。

nginx配置中控制該超時時間的屬性:

Syntax: proxy_read_timeout time;
Default:
proxy_read_timeout 60s;
Context: http, server, location

官方地址:Module ngx_http_proxy_module (nginx.org)

官方描述如下:Defines a timeout for reading a response from the proxied server. The timeout is set only between two successive read operations, not for the transmission of the whole response. If the proxied server does not transmit anything within this time, the connection is closed.

一個請求有三方參與:瀏覽器,nginx,后臺服務(wù)器。

504的錯誤碼是有nginx返回的。結(jié)合官網(wǎng)的解釋,我們可以得出結(jié)論:

當(dāng)nginx與后臺的鏈接兩次讀取有效數(shù)據(jù)之間超過配置的時間時,就會產(chǎn)生504超時。nginx會主動關(guān)閉與后臺服務(wù)器的鏈接。注意是兩次成功讀取的間隔,不是整個reponse的時間。

默認(rèn)情況下proxy_read_timeout時60s。

如果你百度或google,通常解決方式有兩種:提高后臺處理效率增大proxy_read_timeout

增大方法很簡單,proxy_read_timeout  [你期望的時間]。

But,后臺效率提升總是有極限的。而proxy_read_timeout是固定值。總會有些正常業(yè)務(wù)場景,超過了設(shè)置的timeout值。

兩種解決方案

本人解決的問題:上傳excel文件后,由于文件大小無法預(yù)計(jì),所以后臺處理時間也無法預(yù)計(jì)。同時還要支持大文件的上傳。上傳后由后臺解析處理。post請求,返回的是json。

一,關(guān)閉read-timout,可以實(shí)現(xiàn),但是生產(chǎn)環(huán)境下你敢不設(shè)置超時時間么?所以不建議。

二,既然nginx只要從reponse成功讀取數(shù)據(jù)兩次的間隔在proxy_read_timeout設(shè)置的時間內(nèi),就不會超時。那么我們是不是可以通過持續(xù)的向response中寫入數(shù)據(jù)來保證不超時呢。

答案是肯定的。

想通了這一點(diǎn),實(shí)現(xiàn)就十分簡單。

1,正常上傳文件。

2,新建一個線程。持有response的引用,含有標(biāo)志位,滿足條件時循環(huán)執(zhí)行,程序開始處理數(shù)據(jù)前,啟動線程。

3,線程的功能只有一個,以固定間隔向response中寫入數(shù)據(jù)。使nginx與后臺鏈接不超時。

4,這里就需要注意,我的方法是返回json,同時要持續(xù)向response寫入數(shù)據(jù),所以我手動拼裝json字符串。相當(dāng)于在之前返回的json中增加一個屬性,名稱隨意,我的叫pending,值隨意,非空即可。我是用英文半角的句號" . "。

5,數(shù)據(jù)處理完后,回調(diào)線程的stop方法,終止線程中的循環(huán)。

注意:如有雷同純屬巧合。如果已經(jīng)有大佬講過這種解決方式,請艾特我,我立即刪除本文。

保持線程代碼如下:

#上下文代碼
//獲取鮮橙池executor,具體方式看個人。不會的直接百度,有很多
response.setContentType(ContentType.APPLICATION_JSON.getMimeType());
ResponseKeeper responseKeeper = new ResponseKeeper(response);
executorService.execute(responseKeeper);
#上下文代碼
 
 
public class ResponseKeeper implements Runnable {
 
        /**
        * 循環(huán)標(biāo)志:true時停止循環(huán),終止線程
        */
        private boolean done = false;
        
        private HttpServletResponse response;
 
        public void stop(){
            done = true;
        }
 
        public ResponseKeeper(HttpServletResponse response) {
            this.response = response;
        }
 
        @Override
        public void run() {
            try {
                response.getWriter().write("{\"pending\":\"");
                while(!done){
                    response.getWriter().write(".");
                    response.getWriter().flush();
                    LOGGER.error("flush-{}", System.currentTimeMillis());
                    Thread.sleep(1000);
                }
                response.getWriter().write("\", \"status\": \"0\", \"msg\":\"success\"}");
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }

其他問題:

如果你遇到異常

IllegalStateException – if the getOutputStream method has already been called for this response object

那就說明你的程序中有地方調(diào)用過了,response.getOutputStream();

只需要與已有程序保持一致使用outputStream即可。

即將response.getWriter() 提換成 response.getOutputStream();

原因簡單來講就是這兩個方法互斥。調(diào)用了一個就不能調(diào)用另一個。

總結(jié)

分享到:
標(biāo)簽:nginx 兩種 最新 服務(wù)器 解決方案
用戶無頭像

網(wǎng)友整理

注冊時間:

網(wǎng)站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學(xué)四六

運(yùn)動步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績評定2018-06-03

通用課目體育訓(xùn)練成績評定