java - 增加java中单个工作线程的堆栈空间

标签 java jvm stack stack-overflow

在我的 java web 应用程序中,我有一个后台工作线程,它需要大量堆栈空间,因为它使用 activiti 工作流引擎和 groovy 脚本任务运行一个非常复杂的工作流。

目前我需要在 64 位 Java 和 Tomcat 上将 JVM Xss 设置设置为 16MB,以规避任何 StackOverflowErrors。如果发生错误,堆栈跟踪非常大(几百行长),但它都发生在引擎内部,所以我真的无能为力。

现在我的问题是:有没有办法在运行时增加单个线程的堆栈大小?

我想将应用程序中所有线程的 JVM 默认 Xss 设置降低到 512k,我知道这足够了,并且只运行 16M 的工作线程。

Java API 为 Thread 类的构造函数提供了有关此主题的一些信息:

public Thread(ThreadGroup group,
              Runnable target,
              String name,
              long stackSize)

但它提到,不能保证该行为 ([1]),而且我没有找到任何信息,它是否可以在 Windows 上运行。

另外,如果一个线程的堆栈空间不能增加,我必须指定 16MB 作为默认值,那么设置这么高会有什么后果?这是否意味着每个新线程在初始化时都会保留 16MB 的内存(即 200 个线程 * 16MB:3,2 GB)?

据我从 jconsole 和 taskmgr 可以看出,自从增加 Xss 设置以来,内存占用似乎没有太大变化,但也许我遗漏了什么。

如有任何帮助或说明,我们将不胜感激。

[1]: http://docs.oracle.com/javase/6/docs/api/java/lang/Thread.html#Thread(java.lang.ThreadGroup , java.lang.Runnable, java.lang.String, long)

最佳答案

HotSpot 上的 -Xss 指定了最大大小,而不是它将使用的大小。使用的大小基于使用情况,因此如果您将其指定得过大,则会浪费虚拟内存(这在 32 位 JVM 上可能是个问题),但不会浪费物理内存。如果您有一个 64 位 JVM,那么将任何线程设置为最大没有什么缺点。

Also, if the stack space of one thread cannot be increased and I have to specify 16MB as default value, what would be the consequences of having such a high setting? Would that mean that every new thread would reserve 16MB of memory upon initialization (i.e. 200 threads * 16MB: 3,2 GB)?

每个线程将使用这么多虚拟内存。在 32 位 JVM 上,即使您实际使用的内存很少,也会用完地址空间。在 64 位 JVM 上,您的限制是 TB,只有实际使用的堆栈才会使用主内存。

关于java - 增加java中单个工作线程的堆栈空间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11507133/

相关文章:

java - Spring中如何从外部jar导入资源?

java - 在java中跟踪读取日志

java - 将 Java ArrayList 修剪为具有最新日期的不同行

java - 我可以在方法入口处暂停 Java 运行时以便有时间通过​​调试器或分析器进行附加吗?

math - LaTeX:在数学模式下堆叠三行

java - 如何在 junit 中为 Jooq Select Query 编写单元测试

java - 在哪里可以定义 java 编译器选项,以便计算机上运行的任何 java 进程都可以看到它们?

java - 为什么变量的大小不随我们使用的 JVM 平台(64 位或 32 位)而改变?

c++ - 后续函数调用的相同内存地址

tcp - Linux TCP 堆栈数据包注入(inject)