Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Why reduce the size of the Java JVM thread stack?

I was reading an article on handling Out Of Memory error conditions in Java (and on JBoss platform) and I saw this suggestion to reduce the size of the threadstack.

How would reducing the size of the threadstack help with a max memory error condition?

like image 968
djangofan Avatar asked Apr 12 '10 16:04

djangofan


People also ask

What is stack size in JVM?

The default value for the stack size in the JVM is 1024K. Therefore, you must increase the stack size for the JVM to 4M depending on the recursive logic defined in the workflow.

What is thread stack size?

The default thread stack size is 160KB in 32-bit mode and 320KB in 64-bit mode. If you create a lot of threads, you might run out of stack space.

Why does JVM use a stack?

JVM uses operand stack as workspace like rough work or we can say for storing intermediate calculation's result. The operand stack is organized as an array of words like a local variable array.

How many threads JVM can handle?

Each JVM server can have a maximum of 256 threads to run Java applications. In a CICS region you can have a maximum of 2000 threads. If you have many JVM servers running in the CICS region (for example, more than seven), you cannot set the maximum value for every JVM server.


2 Answers

When Java creates a new thread, it pre-allocates a fixed-size block of memory for that thread's stack. By reducing the size of that memory block, you can avoid running out of memory, especially if you have lots of threads - the memory saving is the reduction in stack size times the number of threads.

The downside of doing this is that you increase the chance of a Stack Overflow error.

Note that the thread stacks are created outside of the JVM heap, so even if there's plenty of memory available in the heap, you can still fail to create a thread stack due to running out of memory (or running out of address space, as Tom Hawtin correctly points out).

like image 109
RichieHindle Avatar answered Sep 21 '22 16:09

RichieHindle


The problem exists on 32-bit JVMs were address space can get exhausted. Reducing the maximum stack size will not normally decrease the amount of memory actually allocated. Consider 8k threads with 256kB reserved for stack of 1k of 2MB, that's 31 bits of address space (2GB) gone there.

The problem all but disappears with 64-bit JVMs (although the actual amount of memory will increase a bit because references are twice as big). Alternatively, use of non-blocking APIs can remove the need for quite so many threads.

like image 24
Tom Hawtin - tackline Avatar answered Sep 20 '22 16:09

Tom Hawtin - tackline