- 工信部備案號 滇ICP備05000110號-1
- 滇公安備案 滇53010302000111
- 增值電信業務經營許可證 B1.B2-20181647、滇B1.B2-20190004
- 云南互聯網協會理事單位
- 安全聯盟認證網站身份V標記
- 域名注冊服務機構許可:滇D3-20230001
- 代理域名注冊服務機構:新網數碼
采用nginx作反向代理,出現了一個詭異的問題,小文件可以提交,大文件會報500內部錯誤。這個是什么原因導致的呢?
查wiki可知,上傳文件大小相關的有三個配置
client_body_buffer_size 配置請求體緩存區大小, 不配的話,
client_body_temp_path 設置臨時文件存放路徑。只有當上傳的請求體超出緩存區大小時,才會寫到臨時文件中
client_max_body_size 設置上傳文件的最大值
所以查出來,問題出現的原因是
1.文件大小超過了client_body_buffer_size
2.client_body_temp_path的臨時文件路徑居然沒有寫權限
以上兩個原因導致了返回500錯誤。
如果上?文件大小超過client_max_body_size時,會報413 entity too large的錯誤。
原因知道了,修正就簡單了。
1.client_body_buffer_size 盡量設置的大點,這是基于速度的考慮,如果因為設置的過小,導致上傳的文件老要寫磁盤,那速度就太慢了。
2.client_body_temp_path 路徑要有可寫權限,這個是明顯的錯誤了。改正了就好
3.client_max_body_size 設置上傳文件的最大值,這個是基于安全的考慮,我們認為正常用戶不會或者基本不會上傳太大的文件。
可以設置為client_max_body_size 100m; 或者按照自己的業務來設置這個值。
提交成功!非常感謝您的反饋,我們會繼續努力做到更好!
這條文檔是否有幫助解決問題?
售前咨詢
售后咨詢
備案咨詢
二維碼
TOP