ми намагаємось дослідити використання пам'яті Java-процесу при помірному навантаженні.
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
12663 test 20 0 8378m 6.0g 4492 S 43 8.4 162:29.95 java
Як ви бачите, у нас є пам'ять резидента на 6Gb. Тепер цікава частина така: процес виконується за допомогою цих парам:
- -Xmx2048m
- -Xms2048м
- -XX: NewSize = 512м
- -XX: MaxDirectMemorySize = 256м
- ... деякі інші для GC та ін
Дивлячись на ці налаштування та на фактичне використання пам’яті, ми стикаємось, щоб побачити різницю того, що ми очікуємо, що цей процес використовує і що він насправді використовує.
Зазвичай наші проблеми з пам'яттю вирішуються за допомогою аналізу звалища, але в цьому випадку наша пам’ять використовується десь поза купою.
Запитання: Якими були б кроки, щоб спробувати знайти причину такого високого використання пам'яті? Які інструменти можуть допомогти нам визначити, що використовує пам'ять у цьому процесі?
EDIT 0
Не схоже, що це проблема, пов’язана з купою, оскільки у нас все ще є достатньо місця:
jmap -heap 12663
результати в (відредаговано для економії місця)
Heap Configuration:
MinHeapFreeRatio = 40
MaxHeapFreeRatio = 70
MaxHeapSize = 2147483648 (2048.0MB)
NewSize = 536870912 (512.0MB)
MaxNewSize = 536870912 (512.0MB)
OldSize = 1610612736 (1536.0MB)
NewRatio = 7
SurvivorRatio = 8
PermSize = 21757952 (20.75MB)
MaxPermSize = 85983232 (82.0MB)
New Generation: 45.7% used
Eden Space: 46.3% used
From Space: 41.4% used
To Space: 0.0% used
concurrent mark-sweep generation: 63.7% used
Perm Generation: 82.5% used
ЗРІД 1
використовуючи pmap, ми можемо побачити, що існує досить деяка кількість асигнувань 64Mb:
pmap -x 12663 | grep rwx | sort -n -k3 | less
призводить до:
... a lot more of these 64Mb chunks
00007f32b8000000 0 65508 65508 rwx-- [ anon ] <- what are these?
00007f32ac000000 0 65512 65512 rwx-- [ anon ]
00007f3268000000 0 65516 65516 rwx-- [ anon ]
00007f3324000000 0 65516 65516 rwx-- [ anon ]
00007f32c0000000 0 65520 65520 rwx-- [ anon ]
00007f3314000000 0 65528 65528 rwx-- [ anon ]
00000000401cf000 0 241904 240980 rwx-- [ anon ] <- Direct memory ?
000000077ae00000 0 2139688 2139048 rwx-- [ anon ] <- Heap ?
Тож як дізнатися, що це за шматки 64 Мб? Що їх використовує? Які дані є в них?
Спасибі