2013-08-01 41 views
5

環境:Linux的/ Windows7中,Java的1.6.0.03/37或1.7詹金斯 - java.lang.OutOfMemoryError:PermGen的空間 -

我下載jenkins.war和使用下面的腳本/命令的初始設置後,我下載了一些插件(10-15),並試圖重新啓動詹金斯,它的工作。然後,我得到了更多的插件(總共30-40),我選擇安裝或下載+然後+安裝,詹金斯沒有出現。

即使用startJenkins.sh(僅限Linux)。注意:在Windows7上,Jenkins作爲Windows服務啓動。因爲我看到下面的錯誤消息參數,但只要,我試圖像五百一十二分之一百二十八/ 1024,2048,4096m等,沒各種值:

#!/bin/bash 
export JAVA_HOME=/production/jenkinsAKS/java/jdk1.6.0_03 
export JENKINS_HOME=/production/jenkinsAKS 
export PATH=${JAVA_HOME}/bin:${PATH} 
export JENKINS_HTTP_PORT=9040 
export JENKINS_AJP13_PORT=9949 
now=`date +%Y%m%d_%H%M%S` 

echo $0 begins ${now} 
echo " java-home=${JAVA_HOME}, jenkins-home=${JENKINS_HOME}, path=${PATH}" 
java -jar ${JENKINS_HOME}/lib/jenkins.war -XX:MaxPermSize=4096m --logfile=${JENKINS_HOME}/log/jenkins.log${now} --httpPort=${JENKINS_HTTP_PORT} --ajp13Port=${JENKINS_AJP13_PORT} & 

最初我沒有使用「MaxPermSize參數=4096米-XX」對錯誤沒有幫助。

INFO: Beginning extraction from war file 
Jenkins home directory: /production/jenkinsAKS found at: EnvVars.masterEnvVars.get("JENKINS_HOME") 
Aug 1, 2013 1:17:15 PM winstone.Logger logInternal 
INFO: HTTP Listener started: port=9040 
Aug 1, 2013 1:17:15 PM winstone.Logger logInternal 
INFO: AJP13 Listener started: port=9949 
Aug 1, 2013 1:17:15 PM winstone.Logger logInternal 
INFO: Winstone Servlet Engine v0.9.10 running: controlPort=disabled 
Aug 1, 2013 1:17:16 PM jenkins.InitReactorRunner$1 onAttained 
INFO: Started initialization 
Aug 1, 2013 1:17:16 PM jenkins.InitReactorRunner$1 onAttained 
INFO: Listed all plugins 
Aug 1, 2013 1:17:16 PM hudson.plugins.ansicolor.PluginImpl start 
INFO: AnsiColor: eliminating boring output (https://github.com/dblock/jenkins-ansicolor-plugin) 
Aug 1, 2013 1:17:16 PM org.jvnet.hudson.plugins.backup.BackupPluginImpl loadConfiguration 
INFO: Loading configuration... 
Aug 1, 2013 1:17:16 PM org.jvnet.hudson.plugins.backup.utils.BackupPersistence loadConfig 
INFO: Config file not found. 
Aug 1, 2013 1:17:18 PM ruby.RubyRuntimePlugin start 
INFO: Injecting JRuby into XStream 
Trying to load models from /production/jenkinsAKS/plugins/pathignore/WEB-INF/classes/models 
Loading /production/jenkinsAKS/plugins/pathignore/WEB-INF/classes/models/pathignore_wrapper.rb 
Aug 1, 2013 1:17:26 PM hudson.plugins.greenballs.PluginImpl start 
INFO: Green Balls! 
Aug 1, 2013 1:17:26 PM jenkins.InitReactorRunner$1 onAttained 
INFO: Prepared all plugins 
Aug 1, 2013 1:17:32 PM hudson.ExtensionFinder$GuiceFinder$FaultTolerantScope$1 error 
WARNING: Failed to instantiate optional component org.jfrog.hudson.ivy.ArtifactoryIvyConfigurator$DescriptorImpl; skipping 
Aug 1, 2013 1:17:32 PM jenkins.InitReactorRunner$1 onAttained 
INFO: Started all plugins 
Aug 1, 2013 1:17:32 PM jenkins.InitReactorRunner$1 onAttained 
INFO: Augmented all extensions 
Aug 1, 2013 1:17:32 PM jenkins.InitReactorRunner$1 onAttained 
INFO: Loaded all jobs 
Aug 1, 2013 1:17:32 PM hudson.plugins.scm_sync_configuration.ScmSyncConfigurationBusiness queueChangeSet 
INFO: Queue of changeset  A hudson.model.UpdateCenter.xml 
aborted (scm manipulator not settled !) 
Aug 1, 2013 1:17:32 PM org.jenkinsci.main.modules.sshd.SSHD start 
INFO: Started SSHD at port 36227 
Aug 1, 2013 1:17:32 PM jenkins.InitReactorRunner$1 onAttained 
INFO: Completed initialization 
Aug 1, 2013 1:17:32 PM hudson.TcpSlaveAgentListener <init> 
INFO: JNLP slave agent listener started on TCP port 46056 
The following triggers are available for your jobs 
[Trigger] - Build periodically 
[Trigger] - Build when another project is promoted 
[Trigger] - Maven Dependency Update Trigger 
[Trigger] - Poll SCM 
[Trigger] - [BuildResultTrigger] - Monitor build results of other jobs 
[Trigger] - [FSTrigger] - Monitor files 
[Trigger] - [FSTrigger] - Monitor folder 
[Trigger] - [IvyTrigger] - Poll with an Ivy script 
[Trigger] - [ScriptTrigger] - Poll with a Groovy script 
[Trigger] - [ScriptTrigger] - Poll with a shell or batch script 
[Trigger] - [URLTrigger] - Poll with a URL 
Aug 1, 2013 1:17:33 PM hudson.WebAppMain$2 run 
INFO: Jenkins is fully up and running 
Exception in thread "Jenkins cron thread" java.lang.OutOfMemoryError: PermGen space 
Exception in thread "JmDNS(sagrdev3sb12.local.).State.Timer" java.lang.OutOfMemoryError: PermGen space 
Exception in thread "ConnectorThread:[http-9040]" java.lang.OutOfMemoryError: PermGen space 
Exception in thread "JmDNS(sagrdev3sb12.local.).Timer" java.lang.OutOfMemoryError: PermGen space 
Exception in thread "WinstoneHostConfigurationMgmt:default" java.lang.OutOfMemoryError: PermGen space 

,有時我看到:

30 Aug 1, 2013 1:50:29 AM jenkins.InitReactorRunner$1 onAttained 
    31 INFO: Prepared all plugins 
    32 Exception in thread "pool-2-thread-20" java.lang.OutOfMemoryError: PermGen space 
    33 Aug 1, 2013 1:51:10 AM winstone.Logger logInternal 
    34 WARNING: Untrapped Error in Servlet 
    35 java.lang.OutOfMemoryError: PermGen space 
    36 Aug 1, 2013 1:51:12 AM winstone.Logger logInternal 
    37 SEVERE: Error in the error servlet 
    38 java.lang.OutOfMemoryError: PermGen space 
    39 Exception in thread "Jenkins cron thread" java.lang.OutOfMemoryError: PermGen space 
-bash-3.2$ 

我怎樣才能解決這個問題?當我在Windows桌面機上做同樣的練習時,出現了同樣的問題。我需要使用更少還是更少的插件?

感謝

+1

我使用了最少數量的插件,現在它的工作。但我懷疑,只要我下載更多的道路,這個permGen空間問題將再次肯定 –

+0

你有沒有想過哪些插件或PermGen錯誤開始發生多少插件後? – Illidanek

回答

9

在我的〜/ .bash_profile文件中,我已經設置了以下3個變量。注意,有在這個文件中其他變量也即JAVA_HOME,ANT_HOME,SONAR_HOME,SONAR_RUNNER_HOME等:

export JAVA_OPTS="-XX:MaxPermSize=512m -Xms512m -Xmx1024m" 
export GRADLE_OPTS="-XX:MaxPermSize=512m" 
export SONAR_RUNNER_OPTS="-Xmx512m -XX:MaxPermSize=512m" 

全部 - 現在的工作。第一行輸出:將讓Jenkins進入沒有PermGen錯誤的狀態,第二行將在Jenkins調用Gradle腳本時(通過另一個用於ex。.sh/etc的包裝腳本)使Gradle進入第三行使得「sonar- runner「命令正常工作(否則,在聲納runner命令輸出期間,」Initialize Hibernate「...行之後,我得到了PermGen的錯誤)。您在已編譯java的工作區中運行sonar-runner命令,與靜態代碼分析工具(pmd/checkstyle/findbugs)和其他代碼覆蓋率報告(jacoco/cobertura)相關的報告。工作區應該有「sonar-project.properties」文件。查找有關此文件的SonarQube幫助頁面以及它爲項目包含的所有變量。

所有這些選項都記錄在這裏: http://docs.oracle.com/javase/8/docs/technotes/tools/windows/java.html 或在這裏如果你使用的是Java 7:通過添加GRADLE_OPTS MaxPermSize參數: http://docs.oracle.com/javase/7/docs/technotes/tools/windows/java.html

0

如果您使用的搖籃,您可以設置-Xmx或-XX全局環境變量在Jenkins全局配置中。爲此,請單擊管理Jenkins,然後單擊配置系統。在全局屬性部分,單擊環境變量的複選框,然後添加一個新的環境變量稱爲GRADLE_OPTS有如下設置適當的值:

name: GRADLE_OPTS value: -Xmx1024m -XX:MaxPermSize=1024m

,其中1024是內存中指定。您可以根據您的要求更改它。

Maven需要類似的配置。請參閱下面的鏈接瞭解更多詳情: https://wiki.jenkins-ci.org/display/JENKINS/Builds+failing+with+OutOfMemoryErrors