gpt4 book ai didi

java - 当太多并行上传(堆空间)时,JVM/Tomcat 崩溃?

转载 作者:行者123 更新时间:2023-12-01 14:12:05 24 4
gpt4 key购买 nike

我有一个在 Tomcat 7 上运行的 Servlet 应用程序。我在 setenv.sh 中设置了以下内容

CATALINA_OPTS="
-server
-Xms1G
-Xmx5G
-XX:MaxPermSize=512m
-Dfile.encoding=UTF-8";

该服务器在 Ubuntu 12.04LTS 上运行,具有 6 个内核和 8GB RAM。我的应用程序是一个 Grails/Spring/Java 应用程序,用户可以在其中上传图像。有时会出现 3-5 个用户同时开始上传图像的情况。在这些情况下,我的 Tomcat 由于以下错误而崩溃:

java.lang.OutOfMemoryError: Java heap space

我知道我必须增加我的Tomcat的Xmx参数来防止这个问题。但说真的,我的情况出了什么问题?

  1. 是否有像我的场景一样处理文件上传的最佳实践?

  2. 我可以如何预防这个问题吗?我的意思是,当 5GB 不足以进行 3-5 个并行上传时,我需要多少资源来进行数百个并行上传?

  3. 是我的应用太糟糕还是文件上传占用这么多资源是正常的吗?

注意:用户上传的文件大小为 2-8 MB。

这就是我在我看来上传的方式:

   <g:form method="post" action="save" enctype="multipart/form-data">
<input type="file" name="file"/>
<input type="submit"/>
</g:form>

在我的 Controller 中:

def file = request.getFile('image')
byte [] byteFile = file.getBytes()

在 config/spring/resource.groovy 中我做了:

beans = { 
multipartResolver(org.springframework.web.multipart.commons.CommonsMultipartResolver){

// Max in memory 100kbytes
maxInMemorySize=102400

}

}

上传的文件是图片。它们将被缩放并保存到磁盘。

图像将保存为:

bytes [] currentImage = // some image in bytes ...
def newFile = new FileOutputStream(fullPath)
newFile.write(currentImage)
newFile.close()

最佳答案

避免MultipartFile.getBytes() ,使用MultipartFile.getInputStream()而是避免将整个文件内容读入内存。

因此将您的代码更改为:

def file = request.getFile('image')
InputStream inputStream = file.inputStream

您还没有提到如何处理上传的文件,但请确保在应用程序的各个层中传递 InputStream 并且不会转换为 byte[] 如果你想最小化堆的使用。

关于java - 当太多并行上传(堆空间)时,JVM/Tomcat 崩溃?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18434930/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com