メモリ不足のため、OpenFireが時々クラッシュするという大きな問題があります。Javaログには次のエラーログがあります。ただし、問題は
- Openfire は 32 ビットなので、64 ビットとして実行することはできません。
- 32 ビットのみなので、OpenFire に割り当て可能な最大メモリは 4 GB です。
- 私のシステムは32GBのRAMを搭載しており非常に強力なので、これ以上増やすことはできません
- OpenFire を使用しているユーザーは最大 100 人だけですが、それでも処理できないようです。
- このサービスを監視するために5分ごとにcronジョブを実行し、時々再起動しています。
メモリ使用量に関して Open-Fire を最適化し、クラッシュを防ぐ方法に関する解決策はありますか?
エラーログは以下のとおり
#
# There is insufficient memory for the Java Runtime Environment to continue.
# Native memory allocation (malloc) failed to allocate 140 bytes for CHeapObj-new
# Possible reasons:
# The system is out of physical RAM or swap space
# In 32 bit mode, the process size limit was hit
# Possible solutions:
# Reduce memory load on the system
# Increase physical memory or swap space
# Check if swap backing store is full
# Use 64 bit Java on a 64 bit OS
# Decrease Java heap size (-Xmx/-Xms)
# Decrease number of Java threads
# Decrease Java thread stack sizes (-Xss)
# Set larger code cache with -XX:ReservedCodeCacheSize=
# This output file may be truncated or incomplete.
#
# Out of Memory Error (allocation.inline.hpp:44), pid=31239, tid=2735213424
#
# JRE version: 6.0_41-b02
# Java VM: Java HotSpot(TM) Server VM (20.14-b01 mixed mode linux-x86 )
--------------- T H R E A D ---------------
Current thread (0xad2c7000): JavaThread "Jetty-QTP-AdminConsole-16012" [_thread_in_vm, id=21077, stack(0xa3030000,0xa3081000)]
Stack: [0xa3030000,0xa3081000], sp=0xa307f3d4, free space=316k
Native frames: (J=compiled Java code, j=interpreted, Vv=VM code, C=native code)
V [libjvm.so+0x727990]
答え1
Openfire は Java で書かれており、32 ビットに特化していません。64 ビットの JVM を使用する場合は、64 ビット モードで実行され、必要なだけの RAM を割り当てることができます。64 ビットの JVM/JRE をインストールしてみてください。