500 Internal Server Error 原因及解决方案

2年前 (2022) 程序员胖胖胖虎阿
212 0 0

服务迁移之后接口响应变慢,而且还有报错:500 Internal Server Error,

端上请求报错日志:

500 Internal Server Error 原因及解决方案

原因初步分析:数据包比较大的时候,比如参数多,大的对象,或者图片base64等格式之间往服务端发送请求时:

1、前后端服务连接超时

2、数据包比较大的时候,读写超时

3、服务器配置对包的大小做了限制,配置大小小于现在数据包的大小。

解决方案:

proxy_connect_timeout :后端服务器连接的超时时间_发起握手等候响应超时时间

proxy_read_timeout:连接成功后_等候后端服务器响应时间_其实已经进入后端的排队之中等候处理(也可以说是后端服务器处理请求的时间)

proxy_send_timeout :后端服务器数据回传时间_就是在规定时间之内后端服务器必须传完所有的数据

数据包的大小设置,在业务代码里或者服务器上均可以设置:

1、java配置文件配置:

#配置文件传输
spring.servlet.multipart.enabled =true  
spring.servlet.multipart.file-size-threshold =0
#单个数据的大小
spring.servlet.multipart.max-file-size = 100Mb
#总数据的大小
spring.servlet.multipart.max-request-size=100Mb

如果没配置可能报错如下:

org.apache.tomcat.util.http.fileupload.FileUploadBase$FileSizeLimitExceededException: The field pic exceeds its maximum permitted size of 10485760 bytes.
 

2、nginx配置

client_max_body_size 1024M; 上传文件大小限制

sendfile on; 设置为on表示启动高效传输文件的模式

keepalive_timeout 1800;保持连接的时间,默认65s

当然如果使用其他服务器也是同理!

版权声明:程序员胖胖胖虎阿 发表于 2022年9月10日 上午10:32。
转载请注明:500 Internal Server Error 原因及解决方案 | 胖虎的工具箱-编程导航

相关文章

暂无评论

暂无评论...