背景:
最近项目进入尾声,需要做交付测试,发现CMS生成页面在反复修改保存多次后,由于页面存在动态加载js的缘故,使得页面的内容越来越大,最终出现页面没有办法保存(ajax post将页面的内容发送给后端服务器)
系统的架构如下图:
即: 前端页面上用户修改了页面内容,点击保存按钮,通过ajax的post将页面的内容传递到后台的tomcat进行存数据库,浏览器上爆出错误net::ERR_CONTENT_LENGTH_MISMATCH
查阅了很多相关的帖子,都说是nginx的用户权限的问题,因为大文件,nginx会做缓存,nginx的主进程没有权限去读取proxy_temp目录下的内容,但是,我的情况是,nginx的配置中user用的是root,所以,这个网上多数人说的解决方案不适合我这个情况。
在nginx所在的机器上tcpdump查看包内容,其实能看到,内容是很多的,应该不是nginx丢包。
接下来,去分析tomcat的问题,接着查阅各种大师的建议,说是tomcat的配置中默认对于post的最大包门限是2M,这个倒是非常像我这个错误的情况,因为重复修改保存页面之前,保存是可以的,反复操作,由于另外的问题导致页面的内容不断变多,所以post的内容也就大于2M了,这个时候就爆出问题了。
修改tomcat的配置,将server.xml文件中的connector节点的属性中添加maxPostSize=“0”,注意,默认的tomcat是没有这个属性配置的,此处修改为0表示不限制。
1 <Service name="Catalina"> 2 3 <!--The connectors can use a shared executor, you can define one or more named thread pools--> 4 <Executor name="tomcatThreadPool" namePrefix="catalina-exec-" 5 maxThreads="1000" minSpareThreads="100"/> 6 7 8 <!-- A "Connector" represents an endpoint by which requests are received 9 and responses are returned. Documentation at : 10 Java HTTP Connector: /docs/config/http.html (blocking & non-blocking) 11 Java AJP Connector: /docs/config/ajp.html 12 APR (HTTP/AJP) Connector: /docs/apr.html 13 Define a non-SSL HTTP/1.1 Connector on port 8080 14 --> 15 16 <Connector port="8082" protocol="HTTP/1.1" 17 connectionTimeout="20000" 18 redirectPort="8443" 19 maxPostSize="0" 20 URIEncoding="UTF-8"/> 21 ..............
这么修改后,重新启动tomcat,再次测试,发现就ok了,可以保存刚才那个大文件了。