Tomcat 8 and Java 8: High Memory usage - memory-management

Background:
Windows Server 2012 R2- 64 bit
16 GB RAM
Tomcat 8
Java 8
I am running a java application on Tomcat 8. I am facing high memory usage problem. The memory usage goes up to 95% and server crashes. No problem with CPU usage.
I am setting JAVA_OPTS in tomcat\bin\catalina.bat
set "JAVA_OPTS=%JAVA_OPTS% %LOGGING_CONFIG% -XX:+CMSClassUnloadingEnabled -XX:+CMSPermGenSweepingEnabled -XX:PermSize=512m -XX:+UseParallelGC"
NOTE: XMS and XMX is set from catalina UI.
I understand, there is no PermGen concept in Java 8 so I tried below JAVA_OPTS with -XX:MaxMetaspaceSize=512m too
set "JAVA_OPTS=%JAVA_OPTS% %LOGGING_CONFIG% -XX:+CMSClassUnloadingEnabled -XX:+CMSPermGenSweepingEnabled -XX:MaxMetaspaceSize=512m -XX:+UseParallelGC"
But no luck.
Interesting thing:
The memory used by tomcat process remain around 3.5 GB but memory usage goes up to 15 GB. All the remaining processes add up to 1 GB only. I have no clue which process is consuming remaining 9-10 GB.
The system memory goes up and here is the snap.
Any thoughts?
Thanks.

The problem was with the VM we were using. There were some update processes which use to keep the VM busy.

Related

Why does Elasticsearch use 9 GB of memory, with default settings?

I have just downloaded and run Elasticsearch on my Windows 10 PC. I have not changed any settings, everything is default. The software is running and I can access it on port 9200. However, it appears to be consuming about 9 GB RAM.
I have nothing stored in it, nothing is indexed, it's a default setup.
Why does Elasticsearch need so much memory by default?
EDIT: It's the latest version, 8.1.2.
Elasticsearch latest version(8.1.2 in your case), comes with the bundled JDK and default settings, Elasticsearch default heap settings is 50% of RAM allocated to the machine, it looks like your machine RAM is ~20 Gig, if you want to change this settings, you can follow the steps given in the official jvm options document.
Note: You should allocate 50% of machine RAM to Elasticsearch heap if you running it in Production but it shouldn't cross the ~30 GB in any case.

high virtual memory usage for the application after upgrading from Java 6 to Java 8

We have a Java application that fetches data from external system and creates a memory map of the data.
Earlier the application was built using Java 6. As part of compliance, we needed to upgrade to Java 8.
We just built the application using Java 8 compiler and started testing it.
We observed that there is increase in consumption of Virtual memory by the application.
With Java 6 it was consuming around 5 GB whereas with Java 8 it's at 38 GB.
I am looking for suggestions on how should I approach in finding the problem.
The resident memory of the application is 5 GB as before.

Can I use Oracle JDeveloper 12C with 4GB ram?

When am working with 4GB RAM, the JDK is consuming all the RAM and the Processing speed is very less and unable to proceed with the work. Even for saving a simple JSF page, it's consuming 5-8 minutes.
So is it mandatory to use a RAM >4GB or is there any optimising technique so that I can continue with 4GB RAM and obtain better performance?
4 GB is enough use,you should improve memory management.
java parameters like
set JAVA_OPTS=%JAVA_OPTS% -Xms256m -Xmx512m -XX:+UseParallelGC
set JAVA_OPTS=%JAVA_OPTS% -XX:PermSize=256m -XX:MaxPermSize=512m
for JDeveloper and for tomcat . You should find some JDeveloper config file and change memory management.
4GB should be enough - the slow performance you are seeing doesn't seem to be related to memory but rather something else - try disabling the antivirus on your machine.
Some anti viruses scan JAR files as they are uploaded slowing down Java software such as JDeveloper.

Where can I change allocated memory of JDeveloper?

Where can I change allocated memory of JDeveloper? Also Maximum and optimum memory for this IDE. My Machine has a 4GB RAM, I use SOA,BPEL frameworks in that.
Where can I change allocated memory of JDeveloper?
For JDeveloper 11.1.2.x, you can configure VM options in the JDeveloper configuration file at jdeveloper/jdev/bin/jdev.conf. For example, to set the maximum heap size to 2GB, add the following line to this file:
AddVMOption -Xmx2048M
Note that this only affects the IDE - to set memory limits for the internal Weblogic Server, you can set the USER_MEM_ARGS environment variable before launching the IDE, like
$ export USER_MEM_ARGS="-Xms256m -Xmx1024m"
Also Maximum and optimum memory for this IDE
The more, the better. There is no limit besides those imposed by the operating system or the Java virtual machine you are using (32 bit vs. 64 bit).
My Machine has a 4GB RAM, I use SOA,BPEL frameworks in that.
I really suggest that you add more memory. Use a 64 bit operating system and upgrade to at least 8 GB. You need to consider that it is not only the IDE which is consuming memory, but also the internal Weblogic Server, where you are running your application during development. The internal WLS is launched as a separate java process and also consumes a considerable amount of memory.

Does JVM memory management work the same on Windows and Linux?

My original question is that, is this technically rational to check the required heap-size of my Java program on Windows 7, via VisualVM, and come to this conclusion that the program will require the same amount of heap on Linux(RedHat) as well?
I don't know how the system(OS or even CPU and RAM), affect memory management of JVM.
well, the windows is my development system with 4GB of RAM and a Core 2 Due CPU, however the
Linux is the production system with 32GB of RAM and multiple powerfull processors,
Actually, my concern is that the program on Linux might need more memory. less is ok.

Resources