2019/11/05日对项目压测时出现服务内存激增导致OOM。
压测线程是100个,瞬间服务的内存占用就跑到了4个G。对服务的堆进行dump
jmap -dump:format=b,file=heap.hprof <pid>
发现主要是byte[]占用了88.2%的内存。
那么大的一个数据,考虑查找最大的对象来评判是否存在异常。
对相关对象进行检索发现,该类对应的实例就直接占用了1个多G的内存。
通过后续的搜索发现是spring 中的配置信息将max-http-header-size设置为了10M,正好与每一个headbuffersize匹配。此处就应该知道是由于不正确的参数配置导致了并发情况下的内存激增。
检索tomcat的文档,发现该参数的默认值是4KB。
后续调整该参数后问题得到解决。因为使用token做认证,默认设置的头大小放不下,后续往上涨了4K,变为8k后能够解决token过长无法存储以及内存激增问题