Из-за взаимодействия программного компонента Java с разработанными продуктами могут возникать ошибки, решение которых лежит на плечах пользователя. Оно достигается двумя путями: переустановкой модуля и выделением дополнительной памяти Java. С каждой ситуацией стоит разобраться отдельно.
Задачу по увеличению Java памяти пользователи ставят перед собой в следующих случаях:
- Не запускается игра Minecraft. Геймер получает сообщение, что для запуска не хватает виртуальной памяти, хотя минимальные требования по оперативке соблюдены.
- Проблема с памятью кучи Java. Написанное серверное приложение не запускается. Для его полноценной работы требуется 512 Мб оперативки на компьютере, но трудности с запуском возникают даже при имеющихся 4 Гб.
Исправить проблему можно двумя способами.
Как выделить память Java
Выделить Джава-модулю больше оперативной памяти возможно через «Панель управления». Способ удобнее рассмотреть на примере проблем с запуском игры Minecraft.
Инструкция:
- Открывается «Панель управления».
- В поиске нужно найти Java-модуль.
- После запуска ПО в шапке выбирается раздел Java.
- В запустившемся окне открывается View.
- Для корректной работы модуля удалите лишние строки, если они есть. Должна остаться только одна, где указана последняя версия ПО. Важно обратить внимание на разрядность.
- Для увеличения памяти производится изменение столбца Runtime Parameters. При этом параметры записываются в следующем виде: -Xincgc-Xmx2048M, где 2048 – 2 Гб выделяемой оперативки. Важно писать без пробелов. В 32-битной ОС рекомендуется выделение 768 Мб.
- Нажимается ОК, ОС перезагружается.
Расшифровка используемых команд:
- Xincgc – освобождает неиспользуемые объекты из памяти;
- Xmx – максимальный объем оперативки;
- Xms – минимальный объем.
Если это не помогло запустить Minecraft, переустановите модуль Java и игру. После удаления очистите реестр с помощью CCleaner.
Увеличение памяти с помощью переменных среды
Увеличить оперативную память в Джаве можно с помощью переменных системной среды. В виртуальной машине прописываются два аргумента, упомянутых ранее: -Xms и -Xmx.
Чтобы система воспринимала написанные аргументы, нужно добавить переменную с названием «_JAVA_OPTIONS».
Если количество памяти, отведенной для работы Java, в два раза меньше имеющейся оперативки, то команды прописываются по следующей инструкции:
- Открываются «Свойства» на ярлыке «Мой компьютер».
- Из левой части выбираются «Дополнительные параметры системы».
- На вкладке «Дополнительно» производится одиночный клик по «Переменные среды».
- Нажимается кнопка «Создать».
- Имя переменной: «_JAVA_OPTIONS», аргументы: «-Xms512m -Xmx1024m».
В примере объем оперативки составлял 1 Гб.
Видео: 3 способа выделить больше памяти Java.
Таким образом в статье рассмотрено два метода увеличения оперативной памяти, выделяемой для работы Java-модуля.
Загрузка…
Автор статьи
Программист, фрилансер, пишу на Java. Открыт к общению и готов ответить на ваши вопросы.
I am working on a Windows 2003 server (64-bit) with 8 GB RAM. How can I increase the heap memory maximum? I am using the -Xmx1500m
flag to increase the heap size to 1500 Mb. Can I increase the heap memory to 75% of physical memory (6 GB Heap)?
Joachim Sauer
299k57 gold badges552 silver badges611 bronze badges
asked Oct 14, 2009 at 10:12
4
You can increase to 2GB
on a 32
bit system. If you’re on a 64 bit system you can go higher. No need to worry if you’ve chosen incorrectly, if you ask for 5g on a 32 bit system java will complain about an invalid value and quit.
As others have posted, use the cmd-line flags — e.g.
java -Xmx6g myprogram
You can get a full list (or a nearly full list, anyway) by typing java -X.
Manuel Jordan
14.6k19 gold badges89 silver badges148 bronze badges
answered Oct 14, 2009 at 12:48
Steve B.Steve B.
54.3k12 gold badges93 silver badges129 bronze badges
13
It is possible to increase heap size allocated by the JVM by using these command line options:
-Xms<size> set initial Java heap size
-Xmx<size> set maximum Java heap size
-Xss<size> set java thread stack size
In the following example, minimum heap size is set to 16mb, and the maximum to 64mb:
java -Xms16m -Xmx64m ClassName
Lee Goddard
10.1k3 gold badges46 silver badges60 bronze badges
answered Mar 20, 2013 at 7:10
Karthik ReddyKarthik Reddy
2,8621 gold badge18 silver badges8 bronze badges
0
On a 32-bit JVM, the largest heap size you can theoretically set is 4gb. To use a larger heap size, you need to use a 64-bit JVM. Try the following:
java -Xmx6144M -d64
The -d64 flag is important as this tells the JVM to run in 64-bit mode.
answered Oct 14, 2009 at 12:59
KevinKevin
30k9 gold badges76 silver badges83 bronze badges
2
You can increase the Heap Size by passing JVM parameters -Xms and -Xmx like below:
For Jar Files:
java -jar -Xms4096M -Xmx6144M jarFilePath.jar
For Java Files:
java -Xms4096M -Xmx6144M ClassName
The above parameters increase the InitialHeapSize (-Xms) to 4GB (4096 MB) and MaxHeapSize(-Xmx) to 6GB (6144 MB).
But, the Young Generation Heap Size will remain same and the additional HeapSize will be added to the Old Generation Heap Size. To equalize the size of Young Gen Heap and Old Gen Heap, use -XX:NewRatio=1 -XX:-UseAdaptiveSizePolicy params.
java -jar -Xms4096M -Xmx6144M -XX:NewRatio=1 -XX:-UseAdaptiveSizePolicy pathToJarFile.jar
-XX:NewRatio = Old Gen Heap Size : Young Gen HeapSize (You can play with this ratio to get your desired ratio).
answered Nov 20, 2017 at 8:47
Sahil ChhabraSahil Chhabra
10.9k4 gold badges63 silver badges63 bronze badges
It is possible to increase heap size allocated by the JVM in eclipse directly
In eclipse IDE goto
Run—->Run Configurations—->Arguments
Enter -Xmx1g(It is used to set the max size like Xmx256m or Xmx1g…… m—>mb g—>gb)
Maks3w
5,7996 gold badges37 silver badges42 bronze badges
answered Mar 20, 2013 at 7:47
Karthik ReddyKarthik Reddy
2,8621 gold badge18 silver badges8 bronze badges
1
java -d64 -Xms512m -Xmx4g HelloWorld
where,
-d64: Will enable 64-bit JVM
-Xms512m: Will set initial heap size as 512 MB
-Xmx4g: Will set maximum heap size as 4 GB
(here java file name is : HelloWorld.java)
answered Jul 12, 2013 at 7:03
Please use below command to change heap size to 6GB
export JAVA_OPTS="-Xms6144m -Xmx6144m -XX:NewSize=256m -XX:MaxNewSize=356m -XX:PermSize=256m -XX:MaxPermSize=356m"
answered Jan 17, 2017 at 7:10
3
Can I increase the heap memory to 75%
of physical memory(6GB Heap).
Yes you can. In fact, you can increase to more than the amount of physical memory, if you want to.
Whether it is a good idea to do this depends on how much else is running on your system. In particular, if the «working set» of the applications and services that are currently running significantly exceeds the available physical memory, your system is liable to «thrash», spending a lot of time moving virtual memory pages to and from disk. The net effect is that the system gets horribly slow.
answered Oct 14, 2009 at 10:16
Stephen CStephen C
688k94 gold badges790 silver badges1200 bronze badges
3
Several people pointed out the specific answers for heap size with the jvm options of -Xms
and -Xms
. I want to point out that this is not the only type of memory options for the jvm. Specifically if you are get stack over flows, then you’ll want to increase the size of the stack by adding an additional option like -Xss8m
.
For this problem, the jvm options of something like -Xms2g -Xmx6g -Xss8m
would be a solution.
I’m sharing this information as my google searches on how to increase jvm memory took me to this solution, and the solutions didn’t work with high amounts of memory allocation. Once I figured out what the specific settings were for, I was able to google how to increase the stack size and found the missing param. Hope this saves others time, as it would of saved me a ton of time.
answered May 30, 2017 at 3:53
James OravecJames Oravec
19.1k26 gold badges92 silver badges155 bronze badges
This only works with 64 bit version of Java. Go to Control Panel and click on the Java icon. On the small window of Java Control Panel, click on the Java menu bar and then click on view
button.
If you have two Java platforms, disable the previous version of Java, then click on Runtime parameters text field and write -Xmx1024m
or less than RAM size. Don’t increase heap size equal to RAM otherwise your system will crash.
Eldelshell
6,5057 gold badges43 silver badges62 bronze badges
answered May 28, 2014 at 12:45
madhumadhu
531 bronze badge
1
Yes. You Can.
You can increase your heap memory to 75% of physical memory (6 GB Heap) or higher.
Since You are using 64bit you can increase your heap size to your desired amount. In Case you are using 32bit it is limited to 4GB.
$ java -Xms512m -Xmx6144m JavaApplication
Sets you with initial heap size to 512mb and maximum heapsize to 6GB.
Hope it Helps..
answered Apr 12, 2017 at 11:23
1
I have problem running the py files in my java code using eclipse/STS, getting PyException due to insufficient jvm heap memory. I have done the changes as mentioned below and I’m able to resolve this issue. Below is my System configuration.
And these are the changes I did in my workspace and voila it runs perfect now.
answered Mar 10, 2020 at 4:33
SureshSuresh
1,3072 gold badges20 silver badges26 bronze badges
Here are the steps if someone wants to know how to do this in windows.
answered Sep 8, 2021 at 7:36
Jagath01234Jagath01234
1391 silver badge10 bronze badges
I am working on a Windows 2003 server (64-bit) with 8 GB RAM. How can I increase the heap memory maximum? I am using the -Xmx1500m
flag to increase the heap size to 1500 Mb. Can I increase the heap memory to 75% of physical memory (6 GB Heap)?
Joachim Sauer
299k57 gold badges552 silver badges611 bronze badges
asked Oct 14, 2009 at 10:12
4
You can increase to 2GB
on a 32
bit system. If you’re on a 64 bit system you can go higher. No need to worry if you’ve chosen incorrectly, if you ask for 5g on a 32 bit system java will complain about an invalid value and quit.
As others have posted, use the cmd-line flags — e.g.
java -Xmx6g myprogram
You can get a full list (or a nearly full list, anyway) by typing java -X.
Manuel Jordan
14.6k19 gold badges89 silver badges148 bronze badges
answered Oct 14, 2009 at 12:48
Steve B.Steve B.
54.3k12 gold badges93 silver badges129 bronze badges
13
It is possible to increase heap size allocated by the JVM by using these command line options:
-Xms<size> set initial Java heap size
-Xmx<size> set maximum Java heap size
-Xss<size> set java thread stack size
In the following example, minimum heap size is set to 16mb, and the maximum to 64mb:
java -Xms16m -Xmx64m ClassName
Lee Goddard
10.1k3 gold badges46 silver badges60 bronze badges
answered Mar 20, 2013 at 7:10
Karthik ReddyKarthik Reddy
2,8621 gold badge18 silver badges8 bronze badges
0
On a 32-bit JVM, the largest heap size you can theoretically set is 4gb. To use a larger heap size, you need to use a 64-bit JVM. Try the following:
java -Xmx6144M -d64
The -d64 flag is important as this tells the JVM to run in 64-bit mode.
answered Oct 14, 2009 at 12:59
KevinKevin
30k9 gold badges76 silver badges83 bronze badges
2
You can increase the Heap Size by passing JVM parameters -Xms and -Xmx like below:
For Jar Files:
java -jar -Xms4096M -Xmx6144M jarFilePath.jar
For Java Files:
java -Xms4096M -Xmx6144M ClassName
The above parameters increase the InitialHeapSize (-Xms) to 4GB (4096 MB) and MaxHeapSize(-Xmx) to 6GB (6144 MB).
But, the Young Generation Heap Size will remain same and the additional HeapSize will be added to the Old Generation Heap Size. To equalize the size of Young Gen Heap and Old Gen Heap, use -XX:NewRatio=1 -XX:-UseAdaptiveSizePolicy params.
java -jar -Xms4096M -Xmx6144M -XX:NewRatio=1 -XX:-UseAdaptiveSizePolicy pathToJarFile.jar
-XX:NewRatio = Old Gen Heap Size : Young Gen HeapSize (You can play with this ratio to get your desired ratio).
answered Nov 20, 2017 at 8:47
Sahil ChhabraSahil Chhabra
10.9k4 gold badges63 silver badges63 bronze badges
It is possible to increase heap size allocated by the JVM in eclipse directly
In eclipse IDE goto
Run—->Run Configurations—->Arguments
Enter -Xmx1g(It is used to set the max size like Xmx256m or Xmx1g…… m—>mb g—>gb)
Maks3w
5,7996 gold badges37 silver badges42 bronze badges
answered Mar 20, 2013 at 7:47
Karthik ReddyKarthik Reddy
2,8621 gold badge18 silver badges8 bronze badges
1
java -d64 -Xms512m -Xmx4g HelloWorld
where,
-d64: Will enable 64-bit JVM
-Xms512m: Will set initial heap size as 512 MB
-Xmx4g: Will set maximum heap size as 4 GB
(here java file name is : HelloWorld.java)
answered Jul 12, 2013 at 7:03
Please use below command to change heap size to 6GB
export JAVA_OPTS="-Xms6144m -Xmx6144m -XX:NewSize=256m -XX:MaxNewSize=356m -XX:PermSize=256m -XX:MaxPermSize=356m"
answered Jan 17, 2017 at 7:10
3
Can I increase the heap memory to 75%
of physical memory(6GB Heap).
Yes you can. In fact, you can increase to more than the amount of physical memory, if you want to.
Whether it is a good idea to do this depends on how much else is running on your system. In particular, if the «working set» of the applications and services that are currently running significantly exceeds the available physical memory, your system is liable to «thrash», spending a lot of time moving virtual memory pages to and from disk. The net effect is that the system gets horribly slow.
answered Oct 14, 2009 at 10:16
Stephen CStephen C
688k94 gold badges790 silver badges1200 bronze badges
3
Several people pointed out the specific answers for heap size with the jvm options of -Xms
and -Xms
. I want to point out that this is not the only type of memory options for the jvm. Specifically if you are get stack over flows, then you’ll want to increase the size of the stack by adding an additional option like -Xss8m
.
For this problem, the jvm options of something like -Xms2g -Xmx6g -Xss8m
would be a solution.
I’m sharing this information as my google searches on how to increase jvm memory took me to this solution, and the solutions didn’t work with high amounts of memory allocation. Once I figured out what the specific settings were for, I was able to google how to increase the stack size and found the missing param. Hope this saves others time, as it would of saved me a ton of time.
answered May 30, 2017 at 3:53
James OravecJames Oravec
19.1k26 gold badges92 silver badges155 bronze badges
This only works with 64 bit version of Java. Go to Control Panel and click on the Java icon. On the small window of Java Control Panel, click on the Java menu bar and then click on view
button.
If you have two Java platforms, disable the previous version of Java, then click on Runtime parameters text field and write -Xmx1024m
or less than RAM size. Don’t increase heap size equal to RAM otherwise your system will crash.
Eldelshell
6,5057 gold badges43 silver badges62 bronze badges
answered May 28, 2014 at 12:45
madhumadhu
531 bronze badge
1
Yes. You Can.
You can increase your heap memory to 75% of physical memory (6 GB Heap) or higher.
Since You are using 64bit you can increase your heap size to your desired amount. In Case you are using 32bit it is limited to 4GB.
$ java -Xms512m -Xmx6144m JavaApplication
Sets you with initial heap size to 512mb and maximum heapsize to 6GB.
Hope it Helps..
answered Apr 12, 2017 at 11:23
1
I have problem running the py files in my java code using eclipse/STS, getting PyException due to insufficient jvm heap memory. I have done the changes as mentioned below and I’m able to resolve this issue. Below is my System configuration.
And these are the changes I did in my workspace and voila it runs perfect now.
answered Mar 10, 2020 at 4:33
SureshSuresh
1,3072 gold badges20 silver badges26 bronze badges
Here are the steps if someone wants to know how to do this in windows.
answered Sep 8, 2021 at 7:36
Jagath01234Jagath01234
1391 silver badge10 bronze badges
Загрузить PDF
Загрузить PDF
В этой статье мы расскажем вам, как в Windows 7 увеличить объем оперативной памяти (ОЗУ), который может использоваться Java-программой. Увеличение объема ОЗУ позволит Java-программам работать быстрее и потреблять больше системных ресурсов — таким образом, Java-процессы будут быстрее завершаться.
Шаги
-
1
Обновите Java (если необходимо). Если вы используете не самую последнюю версию Java, обновите ее, выполнив следующие действия:
- Перейдите на страницу https://www.java.com/ru/download/ в веб-браузере компьютера.
- Нажмите «Загрузить Java бесплатно» посередине страницы.
- Нажмите «Согласиться и начать бесплатную загрузку» в верхней части страницы.
- Дважды щелкните по скачанному файлу.
- Следуйте инструкциям на экране.
-
2
Откройте меню «Пуск»
. Нажмите на логотип Windows в нижнем левом углу экрана.
-
3
Щелкните по Панель управления. Эта опция находится в правой части меню «Пуск». Откроется Панель управления.
-
4
Откройте меню «Просмотр». Оно находится в верхней правой части страницы.
-
5
Щелкните по Крупные значки. Эта опция находится в меню. Содержимое Панели управления отобразится в виде отдельных значков, а не ссылок.
-
6
Нажмите Java. Эта опция находится в окне Панели управления. Откроется окно «Java».
- В некоторых случаях нужно нажать «Java (32-bit)».
-
7
Щелкните по вкладке Java. Она находится в верхней части окна Java. Затем нажмите View (Вид).
-
8
Дважды щелкните по текстовому полю «Runtime Parameters» (Параметры времени выполнения). Это пустое текстовое поле справа от номера версии Java. Курсор мыши отобразится в текстовом поле.
-
9
Введите значение памяти. Введите -Xms, объем (в мегабайтах) памяти, которое вы хотите использовать, и букву «m» (например, введите -Xms512m, чтобы разрешить Java использовать 512 МБ ОЗУ). Другими распространенными значениями являются:
- -Xms1024m: Java будет использовать 1 ГБ ОЗУ.
- -Xms2048m: Java будет использовать 2 ГБ ОЗУ.
- -Xms3072m: Java будет использовать 3 ГБ ОЗУ.
-
10
Нажмите ↵ Enter. Введенное значение будет добавлено в текстовое поле.
-
11
Нажмите Apply (Применить). Эта кнопка находится в нижней части окна. Изменения вступят в силу.
-
12
Щелкните по OK. Эта кнопка находится в нижней части окна. Окно «Java» закроется. Теперь программы Java будут использовать заданный объем ОЗУ.
Реклама
Советы
- Чтобы выяснить, какой максимальный объем оперативной памяти доступен на компьютере, щелкните правой кнопкой по значку «Компьютер», в меню выберите «Свойства» и найдите строку «Установленная память (ОЗУ)».[1]
Реклама
Предупреждения
- Если запустить Java-программу с измененными параметрами памяти, это может привести к замедлению работы компьютера при попытке использовать другие программы (например, веб-браузер).
Реклама
Об этой статье
Эту страницу просматривали 62 542 раза.
Была ли эта статья полезной?
I am working on a Windows 2003 server (64-bit) with 8 GB RAM. How can I increase the heap memory maximum? I am using the -Xmx1500m
flag to increase the heap size to 1500 Mb. Can I increase the heap memory to 75% of physical memory (6 GB Heap)?
Joachim Sauer
299k57 gold badges552 silver badges611 bronze badges
asked Oct 14, 2009 at 10:12
4
You can increase to 2GB
on a 32
bit system. If you’re on a 64 bit system you can go higher. No need to worry if you’ve chosen incorrectly, if you ask for 5g on a 32 bit system java will complain about an invalid value and quit.
As others have posted, use the cmd-line flags — e.g.
java -Xmx6g myprogram
You can get a full list (or a nearly full list, anyway) by typing java -X.
Manuel Jordan
14.6k19 gold badges89 silver badges148 bronze badges
answered Oct 14, 2009 at 12:48
Steve B.Steve B.
54.3k12 gold badges93 silver badges129 bronze badges
13
It is possible to increase heap size allocated by the JVM by using these command line options:
-Xms<size> set initial Java heap size
-Xmx<size> set maximum Java heap size
-Xss<size> set java thread stack size
In the following example, minimum heap size is set to 16mb, and the maximum to 64mb:
java -Xms16m -Xmx64m ClassName
Lee Goddard
10.1k3 gold badges46 silver badges60 bronze badges
answered Mar 20, 2013 at 7:10
Karthik ReddyKarthik Reddy
2,8621 gold badge18 silver badges8 bronze badges
0
On a 32-bit JVM, the largest heap size you can theoretically set is 4gb. To use a larger heap size, you need to use a 64-bit JVM. Try the following:
java -Xmx6144M -d64
The -d64 flag is important as this tells the JVM to run in 64-bit mode.
answered Oct 14, 2009 at 12:59
KevinKevin
30k9 gold badges76 silver badges83 bronze badges
2
You can increase the Heap Size by passing JVM parameters -Xms and -Xmx like below:
For Jar Files:
java -jar -Xms4096M -Xmx6144M jarFilePath.jar
For Java Files:
java -Xms4096M -Xmx6144M ClassName
The above parameters increase the InitialHeapSize (-Xms) to 4GB (4096 MB) and MaxHeapSize(-Xmx) to 6GB (6144 MB).
But, the Young Generation Heap Size will remain same and the additional HeapSize will be added to the Old Generation Heap Size. To equalize the size of Young Gen Heap and Old Gen Heap, use -XX:NewRatio=1 -XX:-UseAdaptiveSizePolicy params.
java -jar -Xms4096M -Xmx6144M -XX:NewRatio=1 -XX:-UseAdaptiveSizePolicy pathToJarFile.jar
-XX:NewRatio = Old Gen Heap Size : Young Gen HeapSize (You can play with this ratio to get your desired ratio).
answered Nov 20, 2017 at 8:47
Sahil ChhabraSahil Chhabra
10.9k4 gold badges63 silver badges63 bronze badges
It is possible to increase heap size allocated by the JVM in eclipse directly
In eclipse IDE goto
Run—->Run Configurations—->Arguments
Enter -Xmx1g(It is used to set the max size like Xmx256m or Xmx1g…… m—>mb g—>gb)
Maks3w
5,7996 gold badges37 silver badges42 bronze badges
answered Mar 20, 2013 at 7:47
Karthik ReddyKarthik Reddy
2,8621 gold badge18 silver badges8 bronze badges
1
java -d64 -Xms512m -Xmx4g HelloWorld
where,
-d64: Will enable 64-bit JVM
-Xms512m: Will set initial heap size as 512 MB
-Xmx4g: Will set maximum heap size as 4 GB
(here java file name is : HelloWorld.java)
answered Jul 12, 2013 at 7:03
Please use below command to change heap size to 6GB
export JAVA_OPTS="-Xms6144m -Xmx6144m -XX:NewSize=256m -XX:MaxNewSize=356m -XX:PermSize=256m -XX:MaxPermSize=356m"
answered Jan 17, 2017 at 7:10
3
Can I increase the heap memory to 75%
of physical memory(6GB Heap).
Yes you can. In fact, you can increase to more than the amount of physical memory, if you want to.
Whether it is a good idea to do this depends on how much else is running on your system. In particular, if the «working set» of the applications and services that are currently running significantly exceeds the available physical memory, your system is liable to «thrash», spending a lot of time moving virtual memory pages to and from disk. The net effect is that the system gets horribly slow.
answered Oct 14, 2009 at 10:16
Stephen CStephen C
688k94 gold badges790 silver badges1200 bronze badges
3
Several people pointed out the specific answers for heap size with the jvm options of -Xms
and -Xms
. I want to point out that this is not the only type of memory options for the jvm. Specifically if you are get stack over flows, then you’ll want to increase the size of the stack by adding an additional option like -Xss8m
.
For this problem, the jvm options of something like -Xms2g -Xmx6g -Xss8m
would be a solution.
I’m sharing this information as my google searches on how to increase jvm memory took me to this solution, and the solutions didn’t work with high amounts of memory allocation. Once I figured out what the specific settings were for, I was able to google how to increase the stack size and found the missing param. Hope this saves others time, as it would of saved me a ton of time.
answered May 30, 2017 at 3:53
James OravecJames Oravec
19.1k26 gold badges92 silver badges155 bronze badges
This only works with 64 bit version of Java. Go to Control Panel and click on the Java icon. On the small window of Java Control Panel, click on the Java menu bar and then click on view
button.
If you have two Java platforms, disable the previous version of Java, then click on Runtime parameters text field and write -Xmx1024m
or less than RAM size. Don’t increase heap size equal to RAM otherwise your system will crash.
Eldelshell
6,5057 gold badges43 silver badges62 bronze badges
answered May 28, 2014 at 12:45
madhumadhu
531 bronze badge
1
Yes. You Can.
You can increase your heap memory to 75% of physical memory (6 GB Heap) or higher.
Since You are using 64bit you can increase your heap size to your desired amount. In Case you are using 32bit it is limited to 4GB.
$ java -Xms512m -Xmx6144m JavaApplication
Sets you with initial heap size to 512mb and maximum heapsize to 6GB.
Hope it Helps..
answered Apr 12, 2017 at 11:23
1
I have problem running the py files in my java code using eclipse/STS, getting PyException due to insufficient jvm heap memory. I have done the changes as mentioned below and I’m able to resolve this issue. Below is my System configuration.
And these are the changes I did in my workspace and voila it runs perfect now.
answered Mar 10, 2020 at 4:33
SureshSuresh
1,3072 gold badges20 silver badges26 bronze badges
Here are the steps if someone wants to know how to do this in windows.
answered Sep 8, 2021 at 7:36
Jagath01234Jagath01234
1391 silver badge10 bronze badges
Время прочтения
11 мин
Просмотры 5.8K
1. Введение
Возможно, вы замечали, что Java-приложение может превышать лимит памяти, указанный в параметре -Xmx (максимальный размер кучи). Дело в том, что JVM помимо кучи использует и другие области памяти.
Давайте начнем со структуры памяти Java-приложения и источников потребления памяти.
2. Структура памяти Java-процесса
Память JVM состоит из двух основных частей: память кучи (heap) и память вне кучи (non-heap).
Куча (heap) — весьма известная область памяти. JVM инициализирует кучу при старте и размещает в ней объекты, создаваемые приложением. Когда объект становится не нужен, сборщик мусора (garbage collector, GC) освобождает занимаемую им память. Таким образом, при работе приложения размер кучи изменяется. Ее максимальный размер устанавливается с помощью параметра -Xmx.
Вся остальная используемая память — это память за пределами кучи. В ней и кроется причина использования приложением большего объема памяти, чем указывается в -Xmx. Память вне кучи разделена на несколько областей: код JVM, внутренние структуры, код агента профилировщика, структуры классов, такие как пул констант, метаданные полей и методов, а также код методов, конструкторов и интернированные строки.
Стоит отметить, что некоторые области памяти вне кучи настраиваются через параметры -XX, например, -XX:MaxMetaspaceSize (эквивалентно -XX:MaxPermSize в Java 7 и более ранних версиях). Об этом параметре и других мы поговорим далее.
Память вне кучи может потребляться не только JVM — мы сами можем выделить вне кучи прямые буферы ByteBuffers, которые не будут находиться под контролем сборщика мусора. Также память вне кучи могут использовать нативные библиотеки.
3. Области памяти JVM вне кучи
3.1. Metaspace
Metaspace — это нативная область памяти, в которой хранятся метаданные классов. Когда загрузчик классов (class loader) и все загруженные им классы удаляются из кучи, тогда сборщик мусора может удалить их данные из Metaspace.
Однако освобожденное в Metaspace пространство не обязательно возвращается в операционную систему. JVM может удерживать всю или часть этой памяти для повторного использования.
До Java 8 область Metaspace называлась Permanent Generation (PermGen), но в отличие от Metaspace, PermGen располагалась в куче.
3.2. Кэш кода (Code Cache)
Just-In-Time (JIT) компилятор сохраняет результаты своей работы в области кэша кода. Часто выполняемые участки («горячие точки», Hotspots) компилируются JIT-компилятором в машинный код. При многоуровневой компиляции, появившийся в Java 7, используется два компилятора: сначала клиентский компилятор (C1) компилирует код с профилированием, а затем серверный компилятор (C2) использует данные профилирования для оптимизированной компиляции.
Цель многоуровневой компиляции — совместное использование компиляторов C1 и C2 для обеспечения как быстрого запуска программы, так и хорошей производительности при длительной работе. Многоуровневая компиляция увеличивает объем кода, который необходимо кэшировать в памяти, до четырех раз. Начиная с Java 8, многоуровневая компиляция включена по умолчанию, но ее можно отключить.
3.3. Потоки (Thread)
Стек потока содержит локальные переменные каждого выполняемого метода и методов, вызванных в этом потоке для достижения текущей точки выполнения. Стек потока доступен только потоку, который его создал.
Теоретически, поскольку память стека потоков зависит от количества потоков, а количество потоков может быть любым, размер этой области не ограничен. В реальности операционная система ограничивает количество потоков, а в JVM есть значение по умолчанию для размера памяти стека потока, которое зависит от платформы.
3.4. Сборщик мусора (Garbage Collection)
JVM поставляется с разными сборщиками мусора, и, в зависимости от типа нагрузки, можно выбрать наиболее подходящий вариант. Любой сборщик мусора использует нативную память, размер которой зависит от конкретного сборщика мусора.
3.5. Символы (Symbol)
JVM использует область Symbol для хранения символов, таких как имена полей, сигнатуры методов и интернированные строки. В JDK символы хранятся в трех разных таблицах:
-
System Dictionary (системный словарь) содержит информацию о загруженных типах, таких как классы.
-
Constant Pool (пул констант) использует Symbol Table (таблицу символов) для хранения загруженных символов классов, методов, полей и перечислений. JVM поддерживает для каждого типа Run-Time Constant Pool, содержащий несколько видов констант начиная от числовых литералов времени компиляции до методов в рантайме и ссылок на поля.
-
String Table (таблица строк) содержит ссылки на все константные строки, которые также называются интернированными строками.
Чтобы разобраться с таблицей строк (String Table) сначала поговорим о пуле строк (String Pool). Пул строк — это оптимизация использования памяти объектами String, когда сохраняется только одна копия каждой литеральной строки в пуле с помощью механизма, называемого интернированием. Пул строк состоит из двух частей:
-
Содержимое интернированных строк, хранящихся в куче как обычные объекты String.
-
Хеш-таблица, также называемая «таблицей строк» (String Table), размещенная вне кучи и содержащая ссылки на интернированные строки.
Другими словами, пул строк использует память как в куче, так и вне кучи. Память вне кучи — это String Table. Таблица строк обычно небольшая, но все же может занять значительный объем, когда у вас много интернированных строк.
3.6. Arena
Arena — это реализация в JVM управления памятью на основе регионов (Arena), которая отличается от реализации в glibc. Она используется некоторыми подсистемами JVM, такими как компилятор и символы, а также при использовании нативным кодом внутренних объектов, полагающихся на арены JVM.
3.7. Прочее
Все другие виды использования памяти, не попадающие в указанные выше категории, относятся к этому разделу. Например, использование DirectByteBuffer.
4. Инструменты мониторинга памяти
Теперь, когда мы разобрались с тем, что использование памяти в Java не ограничивается кучей, посмотрим на инструменты анализа памяти и параметры JVM.
Из коробки в JDK есть следующие инструменты для мониторинга памяти:
-
jmap — утилита командной строки для анализа распределения памяти (memory map) java-процесса. jmap также позволяет подключаться к процессу на удаленной машине. Однако после появления jcmd в JDK8 рекомендуется использовать именно jcmd вместо jmap из-за лучшей диагностики и меньших накладных расходов.
-
jcmd используется для отправки диагностических команд в JVM, в том числе для управления Java Flight Recorder, траблшутинга, диагностики JVM и приложений. Но jcmd не работает с удаленными процессами. Далее мы посмотрим на некоторые примеры использования jcmd.
-
jhat визуализирует файл дампа кучи. Создать дамп можно несколькими способами, например, с помощью jmap -dump или jcmd GC.heap_dump filename.
-
hprof (Heap/CPU Profiling Tool) предоставляет данные об использовании процессора, статистике выделения памяти в куче и др. В зависимости от типа профилирования, hprof инструктирует виртуальную машину собирать соответствующие события JVM Tool Interface (JVM TI) и преобразует собранные данные в форму, доступную для дальнейшего анализа.
Помимо инструментов, поставляемых с JVM, в операционных системах есть свои инструменты для анализа памяти. Например, pmap в Linux предоставляет полную информацию о памяти процесса.
5. Native Memory Tracking
Native Memory Tracking (NMT) позволяет анализировать внутреннее использование памяти JVM. Несмотря на то что NMT не способен отследить абсолютно всю используемую память, например, он не увидит выделение памяти в нативном стороннем коде, его функциональности достаточно для большинства типичных приложений.
NMT необходимо включить при запуске приложения:
java -XX:NativeMemoryTracking=summary -jar app.jar
Для параметра -XX:NativeMemoryTracking доступны также значения off и detail. Имейте в виду, что включение NMT связано с накладными расходами, влияющими на производительность. Также увеличивается потребляемая память: добавляется по два машинных слова на каждый malloc.
Найти идентификатор процесса (pid) java-приложения можно с помощью jps или jcmd без аргументов:
jcmd
<pid> <our.app.main.Class>
Доступные команды jcmd посмотрим с помощью help:
jcmd <pid> help
Из вывода мы видим, что в jcmd доступны различные категории команд, такие как Compiler, GC, JFR, JVMTI, ManagementAgent и VM. Некоторые команды, такие как VM.metaspace, VM.native_memory, могут помочь нам с анализом памяти.
5.1. Сводка об использовании внутренней памяти
Для получения сводной информации об используемой внутренней нативной памяти предназначена команда VM.native_memory:
jcmd <pid> VM.native_memory summary
<pid>:
Native Memory Tracking:
Total: reserved=1779287KB, committed=503683KB
- Java Heap (reserved=307200KB, committed=307200KB)
...
- Class (reserved=1089000KB, committed=44824KB)
...
- Thread (reserved=41139KB, committed=41139KB)
...
- Code (reserved=248600KB, committed=17172KB)
...
- GC (reserved=62198KB, committed=62198KB)
...
- Compiler (reserved=175KB, committed=175KB)
...
- Internal (reserved=691KB, committed=691KB)
...
- Other (reserved=16KB, committed=16KB)
...
- Symbol (reserved=9704KB, committed=9704KB)
...
- Native Memory Tracking (reserved=4812KB, committed=4812KB)
...
- Shared class space (reserved=11136KB, committed=11136KB)
...
- Arena Chunk (reserved=176KB, committed=176KB)
...
- Logging (reserved=4KB, committed=4KB)
...
- Arguments (reserved=18KB, committed=18KB)
...
- Module (reserved=175KB, committed=175KB)
...
- Safepoint (reserved=8KB, committed=8KB)
...
- Synchronization (reserved=4235KB, committed=4235KB)
...
В выводе jcmd мы видим сводку по областям памяти JVM, таким как Java Heap (куча), GC (сборщик мусора), Thread (поток) и т.д. Зарезервированная память (reserved) — это общий диапазон адресов, предварительно отображенный (pre-mapped) с помощью malloc или mmap, — это максимальная адресуемая память для данной области. Выделенная память (commited) — это активно используемая память.
Более подробное объяснение вывода вы можете найти здесь. Чтобы увидеть изменения в использовании памяти, можно последовательно использовать VM.native_memory baseline и VM.native_memory summary.diff.
5.2. Metaspace и String Table
Другие области памяти, например, Metaspace, символы и интернированные строки, также доступны для анализа.
Давайте взглянем на Metaspace:
jcmd <pid> VM.metaspace
Результат выглядит следующим образом:
<pid>:
Total Usage - 1072 loaders, 9474 classes (1176 shared):
...
Virtual space:
Non-class space: 38.00 MB reserved, 36.67 MB ( 97%) committed
Class space: 1.00 GB reserved, 5.62 MB ( <1%) committed
Both: 1.04 GB reserved, 42.30 MB ( 4%) committed
Chunk freelists:
Non-Class: ...
Class: ...
Waste (percentages refer to total committed size 42.30 MB):
Committed unused: 192.00 KB ( <1%)
Waste in chunks in use: 2.98 KB ( <1%)
Free in chunks in use: 1.05 MB ( 2%)
Overhead in chunks in use: 232.12 KB ( <1%)
In free chunks: 77.00 KB ( <1%)
Deallocated from chunks in use: 191.62 KB ( <1%) (890 blocks)
-total-: 1.73 MB ( 4%)
MaxMetaspaceSize: unlimited
CompressedClassSpaceSize: 1.00 GB
InitialBootClassLoaderMetaspaceSize: 4.00 MB
Далее таблица строк (String Table):
jcmd <pid> VM.stringtable
Результат:
<pid>:
StringTable statistics:
Number of buckets : 65536 = 524288 bytes, each 8
Number of entries : 20046 = 320736 bytes, each 16
Number of literals : 20046 = 1507448 bytes, avg 75.000
Total footprint : = 2352472 bytes
Average bucket size : 0.306
Variance of bucket size : 0.307
Std. dev. of bucket size: 0.554
Maximum bucket size : 4
6. Настройка памяти JVM
Итак, общее потребление памяти складывается из размера кучи и памяти вне кучи, выделяемой компонентами JVM или сторонними библиотеками.
В процессе работы приложения память вне кучи изменяется незначительно. Обычно ее размер стабилизируется после загрузки всех используемых классов и полного прогрева JIT. Для настройки областей памяти JVM есть различные параметры JVM.
Параметры, с которыми был запущен Java-процесс (включая значения по умолчанию) можно посмотреть с помощью VM.flags:
jcmd <pid> VM.flags
В результате выводятся параметры и их значения:
<pid>:
-XX:CICompilerCount=4
-XX:ConcGCThreads=2
-XX:G1ConcRefinementThreads=8
-XX:G1HeapRegionSize=1048576
-XX:InitialHeapSize=314572800
...
Далее рассмотрим некоторые параметры виртуальной машины для настройки памяти.
6.1. Куча (Heap)
Для настройки кучи есть множество параметров JVM. Первоначальный и максимальный размер задаются параметрами -Xms (-XX:InitialHeapSize) и -Xmx (-XX:MaxHeapSize). Для задания размера кучи в процентах от физической памяти используются параметры -XX:MinRAMPercentage и -XX:MaxRAMPercentage. Имейте в виду, что JVM игнорирует эти два параметра, если заданы -Xms и -Xmx.
Еще один параметр, влияющий на распределение памяти, — XX:+AlwaysPreTouch. По умолчанию куча с заданным максимальным размером выделяется в виртуальной памяти, а не в физической. Операционная система может решить не выделять память до тех пор, пока не будет операций записи. Для обхода этого (особенно при использовании огромных DirectByteBuffers, когда перераспределение страниц памяти может занять существенное время), можно включить -XX:+AlwaysPreTouch. Pretouching записывает «0» на все страницы и заставляет операционную систему выделять память, а не просто резервировать. Pretouching также приводит к более долгому запуску JVM, так как работает в одном потоке.
6.2. Стек потока (Thread stack)
Стек потока — это индивидуальное, на каждый поток, хранилище локальных переменных метода. Для настройки размера используются параметры -Xss или XX:ThreadStackSize. Размер стека потока по умолчанию зависит от платформы, но в большинстве современных 64-битных операционных систем составляет до 1 МБ.
6.3. Сборщик мусора (Garbage Collector)
Для выбора сборщика мусора предназначены параметры: -XX:+UseSerialGC, -XX:+UseParallelGC, -XX:+UseParallelOldGC, -XX:+UseConcMarkSweepGC или -XX:+UseG1GC.
Для сборщика мусора G1 можно дополнительно включить дедупликацию строк с помощью -XX:+UseStringDeduplication, что может сэкономить значительный процент памяти. Дедупликация строк применяется только к долгоживущим экземплярам. Порог возраста экземпляров в виде количества пережитых циклов сборки мусора указывается в параметре -XX:StringDeduplicationAgeThreshold.
6.4. Кэш кода (Code Cache)
Начиная с Java 9, кэш кода состоит из трех сегментов, размер которых настраивается следующими опциями JVM:
-
-XX:NonNMethodCodeHeapSize — размер non-method сегмента, содержащего внутренний код JVM. По умолчанию около 5 МБ.
-
-XX:ProfiledCodeHeapSize — размер profiled сегмента с потенциально коротким временем жизни, который представляет собой скомпилированный код C1. По умолчанию около 122 МБ.
-
—XX:NonProfiledCodeHeapSize — размер non-profiled сегмента с потенциально длительным временем жизни, который представляет собой скомпилированный код C2. По умолчанию около 122 МБ.
6.5. Аллокаторы памяти
JVM при старте резервирует память, которая затем становится доступной через изменение отображения памяти, используя malloc и mmap из glibc. Резервирование и освобождение фрагментов памяти может приводить к фрагментации. Следствие фрагментации — образование большого количества неиспользуемых областей памяти.
Помимо malloc, доступны другие аллокаторы, например, jemalloc или tcmalloc. В аллокаторе jemalloc особое внимание уделяется предотвращению фрагментации и поддержке масштабируемой конкурентности, поэтому он часто эффективнее, чем стандартный malloc из glibc. Кроме того, jemalloc также можно использовать для анализа утечек памяти и профилирования кучи.
6.6. Metaspace
Для настройки нижней и верхней границы размера Metaspace используются параметры -XX:MetaspaceSize и -XX:MaxMetaspaceSize соответственно.
Также полезен параметр -XX:InitialBootClassLoaderMetaspaceSize для настройки первоначального размера области памяти загрузчика классов.
Параметры -XX:MinMetaspaceFreeRatio и -XX:MaxMetaspaceFreeRatio задают минимальный и максимальный процент свободной памяти для метаданных классов после сборки мусора.
Мы также можем настроить максимальный размер расширения Metaspace без полной сборки мусора с помощью -XX:MaxMetaspaceExpansion.
6.7. Другие области памяти вне кучи
Размер пула строк задается с помощью параметра -XX:StringTableSize. В этом параметре указывается максимальное количество различных интернированных строк. Для JDK7+ значение по умолчанию 60013.
Для контроля использования DirectByteBuffers предназначен параметр -XX:MaxDirectMemorySize. С помощью него мы ограничиваем объем памяти, который может быть зарезервирован для всех DirectByteBuffers.
Для приложений, которым необходимо загрузить большое количество классов, можно использовать опцию -XX:PredictedLoadedClassCount. Этот параметр доступен с JDK8 и позволяет установить размер бакета системного словаря (System Dictionary).
7. Заключение
В этой статье мы рассмотрели области памяти Java-процесса и несколько инструментов для мониторинга использования памяти. С помощью jcmd мы увидели, что память Java-приложения не ограничивается кучей, и поговорили о некоторых параметрах JVM для настройки использования памяти.
Перевод статьи подготовлен в преддверии старта курса «Java Developer. Professional». Приглашаю всех на бесплатный урок курса, где поговорим о том, как кэширование помогает улучшить производительность Java-приложений. Рассмотрим самые простые реализации на базе HashMap и популярные решения Ehcache и Caffeine.
-
Зарегистрироваться на бесплатный урок
Редактирование параметров памяти при работе с Java.
-Xmn
определяет объём занятой памяти до которой сборщик мусора должен освобождать память (если это возможно);-Xms
определяет размер начальной выделенной памяти под объекты;-Xmx
определяет максимальный размер памяти, выше которого приложение не задействует;
Правило настроек запуска:
-Xmn < -Xms < -Xmx
А также:
Xms
примерно равно Xmx
;Xmn
примерно половина от Xms
;
Java «Heap» is a continous memory region where all Objects data will be stored (by data, we mean instance of class, primitive and references). It’s a big part of the process heap. It can be configured using the following parameters:
-Xmx
: max heap size (ex: -Xmx1024);-Xms
: min heap size. Having -Xms = 1.8GB (32bit) can be bad, because you don’t let memory for anything else;-Xmn
: the size of the heap for the young generation.
Young generation represents all the objects which have a short life of time. Young generation objects are in a specific location into the heap, where the garbage collector will pass often. All new objects are created into the young generation region (called «eden»). When an object survive is still «alive» after more than 2-3 gc cleaning, then it will be swap has an «old generation» : they are «survivor» .
Good size is 33%
-XX:NewRatio
: the same as Wmn, but using a % (dynamic fs static -Xmn option);-XX:NewRatio=3
means that the ratio between the old and young generation is 1:3;-XX:NewSize
— Size of the young generation at JVM init. Calculated automatically if you specify -XX:NewRatio
;-XX:MaxNewSize
— The largest size the young generation can grow to (unlimited if this value is not specified at command line);-XX:SurvivorRatio
: «old generation» called tenured generation, ratio, in %. For example, -XX:SurvivorRatio=6 sets the ratio between each survivor space and eden to be 1:6 (eden is where new objects are created);-XX:MinHeapFreeRatio:
default is 40%. JVM will allocate memory to always have as minimum 40% of free memory. When -Xmx = -Xms, it’s useless;-XX:MaxHeapFreeRatio:
default is 70%. The same as Min, to avoid unecessary memory allocation.