一、背景介绍
师范学院钥匙用体测项目,体测项目使用之前需要把学生的信息导入到系统当中。但是由于学生比较多excel表格中有1.5w人的信息。文件比较到导致在上传的过程中上传失败,因为nginx限制了文件上传的大小。一开始想到的解决方案是调整nginx的配置把限制调整到可以一次性传入1.5w学生信息的配置。
二、Nginx上传文件大小配置
1.参数说明
Syntax: client_max_body_size size; Default: client_max_body_size 1m;
①client_max_body_size 用来修改允许客户端上传文件的大小。默认为1m,如果设置为0,表示上传文件大小不受限制。
Context: http, server, location
②可以在以下模块设置: http, server, location
2.参数使用:server模块
server { listen 80; server_name localhost; #charset koi8-r; # client_max_body_size 用来修改允许客户端上传文件的大小。默认为1m,如果设置为0,表示上传文件大小不受限制。 # 可以在以下模块设置: http, server, location client_max_body_size 10m; # 访问 / 网站跟目录返回的内容 location / { root /usr/share/nginx/html; index index.html index.htm; } ...
3.参数使用:http模块
http { include /etc/nginx/mime.types; default_type application/octet-stream; log_format main '$remote_addr - $remote_user [$time_local] "$request" ' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" "$http_x_forwarded_for"'; access_log /var/log/nginx/access.log main; sendfile on; #tcp_nopush on; keepalive_timeout 65; # 是否开启压缩功能 #gzip on; # client_max_body_size 用来修改允许客户端上传文件的大小。默认为1m,如果设置为0,表示上传文件大小不受限制。 # 可以在以下模块设置: http, server, location client_max_body_size 10m; # 引用配置文件 include /etc/nginx/conf.d/*.conf; }
三、问题分析
对于调整nginx上传文件大小的方案是一个非常危险的方案,因为是在生产环境很有可能有用户在使用,如果我们没有改成功的话,就会导致配置文件读取失败用户无法使用的问题。静止的思考问题,只想当下如何解决这个问题。没有从根本上解决问题。以后还可能有其他的情况,如果直接改参数那每次都需要改。改完之后有什么风险也不清楚。我们要去适应别人(服务器上的配置),而不是每次都让比人适应我们。
四、总结提升
解决问题要想出至少三种方案,在多种方案中选取一个最优的风险最小的。不要有一种方案就直接去做。
对于问题的解决可以编写一个批量导入excel表格的入口,也可以使用多线程的方式把一个大的excel拆分成多个请求进行导入