Я запускаю сервер приложений, который использует довольно немного памяти (их довольно много). Он работает на экземпляре EC2 объемом 18 ГБ.Java GC: PSYoungGen растет на 4 ГБ после Full GC
я прохожу эти параметры ГХ к ВМ:
-server -XX:GCTimeRatio=19 -Xmx12g -XX:+PrintGCDetails -XX:+PrintGCTimeStamps
Сервер работает отлично на некоторое время (а также, как вы бы expecte без параллельного GC), но через несколько дней, он вдруг вырос ворох на огромное количество, и взял нас в своп, который уничтожил производительность сервера и требуется перезагрузка:
217408.525: [Full GC [PSYoungGen: 12935K->0K(530944K)] [PSOldGen: 5668446K->4551217K(5431168K)] 5681382K->4551217K(5962112K) [PSPermGen: 50534K->50480K(50816K)], 11.8155060 secs] [Times: user=9.73 sys=2.08, real=11.81 secs]
217963.521: [Full GC [PSYoungGen: 13247K->0K(635776K)] [PSOldGen: 5422640K->4884067K(5741120K)] 5435887K->4884067K(6376896K) [PSPermGen: 50489K->50489K(50816K)], 8.4219030 secs] [Times: user=8.38 sys=0.05, real=8.43 secs]
218452.573: [Full GC [PSYoungGen: 20879K->0K(877504K)] [PSOldGen: 5720236K->4873397K(5788544K)] 5741115K->4873397K(6666048K) [PSPermGen: 50502K->50502K(50816K)], 10.9450630 secs] [Times: user=9.13 sys=1.84, real=10.95 secs]
219061.305: [Full GC [PSYoungGen: 73587K->0K(4073600K)] [PSOldGen: 5790501K->5022476K(6031040K)] 5864088K->5022476K(10104640K) [PSPermGen: 50518K->50518K(50816K)], 11.1695740 secs] [Times: user=8.80 sys=1.81, real=11.17 secs]
Это последняя линия кажется очень много из шага. Почему быстрая молочная генерация PS внезапно выросла до 4 ГБ?
Запуск этой VM на Ubuntu:
java version "1.6.0_20"
Java(TM) SE Runtime Environment (build 1.6.0_20-b02)
Java HotSpot(TM) 64-Bit Server VM (build 16.3-b01, mixed mode)
EDIT: Бывало второй раз сегодня вечером.
101017.205: [Full GC [PSYoungGen: 73185K->0K(4095616K)] [PSOldGen: 6373373K->5318013K(6638016K)] 6446559K->5318013K(10733632K) [PSPermGen: 46183K->46183K(46272K)], 221.1337460 secs] [Times: user=8.13 sys=1.26, real=221.08 secs]
EDIT: Вот график последних 3 часов на нашем производственном сервере.
С вашей максимальной кучей и властью, не превышающей вашу первичную память, как именно вы в конечном итоге попали на своп? Другие прогги? – Xailor
Не уверен. Top показывает, что java занимает 15-граммовое место, а все остальное - стандартные системные процессы, которые занимают несколько мегабайт. См. Мой отредактированный пост, где это произошло снова, но завершил GC (что заняло 221 секунд). – sehugg
Дополнительный GB может быть потоком. У нас много потоков. – sehugg