Question: What is
responsiveness and throughput parameter for any web application?
Responsiveness
|
Throughput
|
Refers to how quickly
an application or system responds with a requested piece of data.
|
Focuses on maximizing
the amount of work by an application in a specific period of time.
|
Long pause times are not
acceptable for applications that focus on throughput.
|
High pause times are
acceptable for applications that focus on throughput.
|
The focus is on
responding in short periods of time.
|
Since high throughput
applications focus on benchmarks over longer periods of time, quick response
time is not a consideration
|
E.g. how quickly UI
responds, how fast a website returns a page, how fast a database query is
returned etc.
|
The number of transactions/jobs/queries/etc
completed in a given time.
|
Question: Which things
are stored in Heap and in stack or diff between Heap Space and Stack Space?
Java Heap space
|
Java Stack space
|
It
is used by java runtime to allocate memory to objects and JRE classes.
(It
is used by all the parts of the application.)
|
It
is used for execution of a thread.
(It
is used only by single thread of execution.)
|
New
objects are created in Heap space.
(Stack
memory contains the references to it.)
|
It
stores Method specific vales, local primitives and references to other
objects in the heap that are getting refereed from the method.
|
Objects
stored in the heap are globally accessible.
|
Stored
values cannot be accessible by other threads.
|
GC
runs on the heap memory to free the memory used by objects that does not have
any references.
(Heap
memory lives from the start till the end of the application/freed by GC)
|
In
the end of the execution of the method, the unused memory becomes available
for next method.
(Stack
memory is short-lived)
|
Heap
space is bigger than stack space.
(Heap
memory is divided into parts like young generation, old generation and perm
gen.)
In
comparison with each other, access from Heap memory is slower than Stack
memory.
|
Stack
size is very small compared to Heap memory.
Because
of the simple design (LIFO) and less size, stack memory is faster than Heap.
|
When
Heap memory is exhausted, java runtime throws java.lang.OtOfMemoryError
|
When
stack memory is full, java runtime throws java.lang.StackOverFlowError
|
For
tuning, we can mainly use following parameters.
–Xms(define
the startup sizeof the Heap)
–Xmx(define
maximum size of the Heap)
|
For
tuning, we can mainly use following parameters.
- Xss(define the stack memory size)
|
Question: What is Automatic Garbage Collection? When does an object become eligible for garbage collection?
Unlike
other programming languages, process of deallocating memory in Java is not
manual. It is handled by Garbage Collector- a system thread. Automatic garbage
collection is the process of looking at heap memory, identifying which objects
are in use and which are not, and deleting the unused objects.
An
object becomes eligible for GC when there is no live reference for that object
or it can not be reached by any live thread. If two objects have cyclic
dependency on each other and both have no live reference then also both objects
are eligible for GC.
Question: What are Young (New) Generation,
Old
Generation, Permanent Generation, Eden memory, S0
Survivor memory, S1 Survivor memory, Minor Garbage collection, Major Garbage
Collection and “Stop the world” events? Which things are stored in these areas?
What is permanent Generation? What are the changes in JDK 1.8? What is
Metaspace?
Young Generation: Young generation is the place where
all the new objects are created. When young generation is filled completely,
garbage collection is performed. This garbage collection is known as Minor
GC. Young generation is also known as New Generation. Young Generation is divided into following sections: Eden
Memory and two Survivor Memory (S0 Survivor
memory and S1 Survivor memory) spaces.
Eden
Memory: Most of the newly created objects are
located in the Eden memory space. When it is filled with objects, minor GC is
performed and objects are moved to one of the survivor space.
Survivor Memory: Survivor memory has two sections S0 Memory space and S1 Memory space which are also known as From-space and To-space. Each
minor GC done in the young generation increments the age of objects in the
survivor spaces. When an object has survived a sufficient number of minor GCs
(Defaults vary but normally start at 15) it will then be promoted to the Old
Generation.
Old Generation: The Old Generation is usually much larger
than the New Generation and it contains the objects that are long lived and
survived after many rounds of Minor GC. Usually garbage collection is performed
in Old Generation memory when it’s full. Old Generation Garbage Collection is
called Major GC and usually takes longer time.
Stop the World events: All application threads are stopped
during the execution of GC. This event is known as Stop the World event. Minor GC and major GC both are this type of
events. Often a major collection is much slower because it involves all live
objects.
Permanent
generation (PermGen):
It contains metadata required by the JVM to describe the classes and methods
used in the application. Java SE classes and methods are also stored in it.
Runtime, it is populated by JVM, based on classes used in the application. The permanent generation is included in a full garbage collection.
Java 8: PermGen is no longer exists in Java
8. Java designers have redesigned the architecture and they removed PermGen and
introduced new area so called Metaspace.