Nginx 413 Request Entity Too Large,文件上傳過程中的問題

在上傳時nginx返回了413錯誤,查看log文件,顯示的錯誤信息是:”413 Request Entity Too Large”。
以下介紹處理辦法。

1 處理方式如下

1.打開nginx配置文件 nginx.conf, 路徑一般是:/etc/nginx/nginx.conf,或者/usr/local/nginx。
2.在http{}段中加入 client_max_body_size 20m; 20m爲允許最大上傳的大小。(設置超過20m可能無效)
3.同時,還需要設置client_body_buffer_size的值,要求client_body_buffer_size<=client_max_body_size 。可以直接設置兩者相等大小。
4.保存後重啓nginx,問題解決。nginx操作可以參考 nginx操作
設置值如下:

    client_max_body_size 20M;
    client_body_buffer_size 20M;

效果圖如下:
在這裏插入圖片描述

2 相關原理記錄如下:

1)client_max_body_size
client_max_body_size 默認 1M,表示 客戶端請求服務器最大允許大小,在“Content-Length”請求頭中指定。如果請求的正文數據大於client_max_body_size,HTTP協議會報錯 413 Request Entity Too Large。就是說如果請求的正文大於client_max_body_size,一定是失敗的。如果需要上傳大文件,一定要修改該值。
2)client_body_buffer_size
Nginx分配給請求數據的Buffer大小,如果請求的數據小於client_body_buffer_size直接將數據先在內存中存儲。如果請求的值大於client_body_buffer_size小於client_max_body_size,就會將數據先存儲到臨時文件中,在哪個臨時文件中呢?client_body_temp 指定的路徑中,默認該路徑值是/tmp/.
所以配置的client_body_temp地址,一定讓執行的Nginx的用戶組有讀寫權限。否則,當傳輸的數據大於client_body_buffer_size,寫進臨時文件失敗會報錯。

總結
傳輸的數據大於client_max_body_size,一定是傳不成功的。小於client_body_buffer_size直接在內存中高效存儲。如果大於client_body_buffer_size小於client_max_body_size會存儲臨時文件,臨時文件一定要有權限。
如果追求效率,就設置 client_max_body_size client_body_buffer_size相同的值,這樣就不會存儲臨時文件,直接存儲在內存了。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章