我正在使用Azure Media Services和Node.js構建視頻服務 到現在爲止,一切都很順利,但是當我嘗試將應用程序部署到Azure Web Apps進行託管時,任何大型文件都會因404.13錯誤而失敗。如何通過Azure網站上的Node.js應用程序將大文件流上傳到Azure Blob存儲?
是的,我知道maxAllowedContentLength
而不是,這不是一個解決方案。它只能達到4GB,這是可悲的 - 即使HDR環境地圖現在也很容易超過這個數量。我需要讓用戶上傳最大150GB的文件。然而,當azure網絡應用程序接收到多部分請求時,它似乎將其緩衝到內存中,直到達到某個字節或幾秒的閾值(如果我的連接速度較慢,則返回給我一個404.13或502)在運行我的任何一個服務器邏輯。
我在服務器代碼中嘗試了Transfer-Encoding: chunked
標題,但即使這樣做會有所幫助,因爲Web Apps不會讓代碼運行,但實際上並不重要。
備案:我在後端使用Sails.js,Skipper正在處理到Azure Blob服務的流管道。無論文件大小如何,Localhost顯然都能正常工作。我在MSDN論壇上重複了這個問題,但這些問題一直很慢。你可以去那裏看看我迄今發現:enter link description here
客戶方我使用Ajax FormData
序列化的字段(一個文本字段和一個文件),並將它們發送,使用progress
甚至跟蹤上傳進度。
有什麼辦法可以使這項工作?我只是希望它能讓我的服務器端邏輯處理數據流,而不會緩衝流血的事情。
似乎是目前唯一的解決方案,但是我想看看是否有任何微軟員工對此有任何說法。而這對於Web Apps來說是否可能。作爲無緩衝流的整個數據真的是2015年的基本功能,看到Web應用程序不支持這一點非常令人失望。所以,如果它以某種方式做,我只是做錯了,我想看到的解決方案,我相信也有很多其他人。與此同時,我會按照自己的方式構建它(這意味着我的代碼中的30%也會報廢)。我永遠不會推薦Azure作爲節點主機。 – Megakoresh
(正如,來自Web應用部門XD的Microsoft員工) – Megakoresh
好的我已經實現了這個解決方案。它的工作原理,儘管我不得不放棄了以前的許多工作。我想這是一個學習經驗...... – Megakoresh