हम मध्यम भार के तहत जावा प्रक्रिया के मेमोरी उपयोग की जांच करने की कोशिश कर रहे हैं।
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
जैसा कि आप देख सकते हैं कि हमारे पास 6 जीबी पर निवासी मेमोरी है। अब दिलचस्प हिस्सा यह है: इस प्रक्रिया को इन पारमों के साथ निष्पादित किया जाता है:
- -Xmx2048m
- -Xms2048m
- -XX: NewSize = 512 एम
- -XX: MaxDirectMemorySize = 256M
- ... जीसी और सामान के लिए कुछ अन्य
इन सेटिंग्स को देखते हुए और वास्तविक स्मृति उपयोग पर हम इस प्रक्रिया का उपयोग करने के लिए क्या उम्मीद करते हैं और वास्तव में इसका उपयोग करते हैं, इसका अंतर देखने के लिए हम लड़खड़ा गए हैं।
आमतौर पर हमारी मेमोरी प्रॉब्लम हीप डंप का विश्लेषण करके हल की जाती है लेकिन इस मामले में हमारी मेमोरी का इस्तेमाल कहीं न कहीं बाहर ही किया जाता है।
प्रश्न: ऐसे उच्च मेमोरी उपयोग के कारण को खोजने और जानने के लिए क्या कदम होंगे? उस प्रक्रिया में मेमोरी का उपयोग करने वाले उपकरणों को पहचानने में हमारी क्या मदद कर सकती है?
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
EDIT 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 ?
तो कैसे पता करें कि वो 64Mb चंक कौन से हैं? उनका क्या उपयोग है? उनमें किस तरह का डेटा है?
धन्यवाद