Confluence 的備份和恢復是與數據庫中數據量的大小有關。這個操做可能會對 Confluence 的性能產生不少關鍵性的影響而且大量消耗內存。若是你在 Confluence 的系統備份和恢復過程當中遇到了 OutOfMemoryError
錯誤,咱們強烈推薦你使用 Production Backup Strategy 進行系統的備份和恢復。html
當你在 Confluence 系統備份和恢復的時候遇到了 OutOfMemoryError
錯誤,你但願經過增長內存的大小來修復這個錯誤的話。咱們應該增長多少內存呢?一個指導方針是,查看你備份中的 entities.xml
文件的大小。這個文件的大小是 Confluence 須要載入的全部數據的大小,同時這個大小也是最小的需求值。針對這個大小,添加 64 - 128MB 到 Confluence 的內存來保證 Confluence 在系統備份的時候有足夠可用的內存。有關增長可用內存的方法,請參考頁面 increasing available memory 中的內容。java
下面的一些內存的問題,咱們可能沒有辦法進行控制:數據庫
若是你在使用的時候遇到了比較嚴重的內存泄漏問題,請登陸 http://support.atlassian.com。咱們的內存屬性空間選擇的是 YourKit。這個工具可以幫助你向咱們提供你機器上存在有內存泄漏的地方。tomcat
一個致使 Confluence 忽然不響應的問題多是 Confluence 正在運行 JVM 垃圾清理。爲了肯定這個是否是正在發生的狀況,請詳細查看垃圾清理程序而後檢查 Java 花了多長時間才清空內存。若是臨時中止響應的時候與 Java 運行垃圾清理的世界相同的話,那麼就能夠證實是 Java 的垃圾清理致使了這個問題。工具
詳細的垃圾清理日誌將會告訴你 Java 的垃圾清理程序是何時開始的,在此次垃圾清理中花了多長時間,和多少垃圾被清理。性能
爲了肯定垃圾清理 gc 被爭取的日誌,在啓動 Confluence 的時候,添加下面的選項 -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -verbose:gc -Xloggc:gc.log。替換
gc.log
爲你 gc.log
文件的絕對路徑。ui
例如,若是你下 Windows 服務下的話,運行:日誌
tomcat5 //US//Confluence ++JvmOptions="-XX:+PrintGCDetails -XX:+PrintGCTimeStamps -verbose:gc -Xloggc:c:\confluence\logs\gc.log"
或者在 bin/setenv.sh
, 中設置:code
export CATALINA_OPTS="$CATALINA_OPTS -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -verbose:gc -Xloggc:${CATALINA_BASE}/logs/gc.log"
若是你修改了 bin/setenv.sh 文件,
你須要重啓 Confluence 來使配置生效。orm
有什麼辦法可讓 Java 的垃圾清理消耗最小的時間呢?請參考 http://java.sun.com/docs/hotspot/gc1.4.2/ 頁面中的內容來肯定 JVM 垃圾清理對正在運行的系統產生最小的影響。
https://www.cwiki.us/display/CONF6ZH/Memory+Usage+and+Requirements