Почему размер моей кучи JVM колеблется от 2 до 8 гигов? - PullRequest
4 голосов
/ 22 сентября 2010

Объем памяти кучи колеблется между 2 гигабайтами и ~ 8 гигабайтами примерно раз в минуту (см. Рисунок).

Соответствующие сведения:

  • Сайт с высоким трафиком
  • Многофизическая память
  • Redhat 5.5
  • Java 1.6.0_07
  • Glassfish 2.2.1 (да, я знаю, что он старый. нет, мы не можем обновить. да, я знаюэто необычно для использования в качестве сервера производственных приложений).
  • -XX: MaxPermSize = 192m -XX: + AggressiveHeap -Xms14336m -Xmx14336m

У меня мало опыта с настройкой памяти, нокажется, что MaxPermSize не в порядке с Xms и Xmx.Или это нормально?

jConsole heap thrashing

Ответы [ 2 ]

14 голосов
/ 22 сентября 2010

Почему размер кучи JVM увеличивается от 2 до 8 ГБ?

Нет доказательств того, что система бьется в обычном (вредном) смысле. Пилообразная схема указывает, что объекты распределяются (наклон вверх), и ГХ затем восстанавливает их. Скорость выделения кажется немного высокой, но есть все признаки того, что GC работает эффективно. Действительно, тот факт, что размер кучи всегда уменьшается до ~ 2 ГБ, является хорошим признаком, а также тот факт, что процент использования ЦП низок.

У меня мало опыта в настройке памяти, но кажется, что MaxPermSize не в порядке с Xms и Xmx. Или это нормально?

Это выглядит нормально.

Конечно, нет необходимости увеличивать размер permGen. (PermGen используется для объектов, которые, как ожидается, никогда не будут собирать мусор; как правило, intern'd строки 1 и сегменты кода. Обычные объекты приложения никогда не размещаются и не перемещаются в пространство permgen.)

Гипотетически, если у вас не было много памяти, высокая скорость выделения может быть причиной для беспокойства. Однако вы не можете решить эту проблему путем настройки параметров GC. Вам нужно выполнить некоторое профилирование, чтобы увидеть, что создает столько объектов, и посмотреть, имеет ли смысл попытаться уменьшить скорость создания. В зависимости от приложения, это может быть даже нецелесообразно.


1 - На самом деле, начиная с Java 7 строки intern'd живут в обычной куче, а не permgen.

0 голосов
/ 23 сентября 2010

очень нормально. у всех программ Java есть образец памяти как это.

...