Я пытался настроить Atlassian Fisheye / Crucible как службу на Win 2K3 R2 в течение двух недель. Я продолжаю получать различные ошибки «java.lang.OutOfMemoryError: PermGen space», которые вызывают сбой Fisheye и вынуждают меня перезапускать службу.
Я следил за пример на сайте поддержки Atlassian, чтобы настроить MaxPermSize внутри служебной оболочки. Однако, когда я проверяю SysInfo на страницах администратора Fisheye и в журнале отладки, я не вижу никакого подтверждения. Информация о Java Heap находится в обоих местах, поэтому я ожидаю, что параметр MaxPermSize будет отображаться в обоих местах.
Ошибка повторяется, и поддержка Atlassian почти не помогла.
Я ценю любую помощь.
Вы можете установить это в вашем файле Wrapper.conf. Вот мой файл конфигурации, и у меня он отлично работает. Я использую его с Fisheye 2.6.3, работающим на Windows Server 2008 R2. Этот файл в основном идентичен образцу / конфигурации по умолчанию, с несколькими важными дополнениями, которые я прокомментирую в конце.
#******************************************************************** # Wrapper Properties #******************************************************************** # Working Directory wrapper.working.dir=../../ # Java Application wrapper.java.command=C:\Program Files\Java\jdk1.6.0_25\bin\java.exe # Java Main class. This class must implement the WrapperListener interface # or guarantee that the WrapperManager class is initialized. Helper # classes are provided to do this for you. See the Integration section # of the documentation for details. wrapper.java.mainclass=com.cenqua.fisheye.FisheyeServiceWrapper # Java Classpath (include wrapper.jar) Add class path elements as # needed starting from 1 (add lib FIRST so that log4j config gets loaded first) wrapper.java.classpath.1=./fisheyeboot.jar wrapper.java.classpath.2=wrapper/lib/*.jar # Java Library Path (location of Wrapper.DLL or libwrapper.so) wrapper.java.library.path.1=wrapper/lib wrapper.java.library.path.2=lib/native/linux-i386 wrapper.java.library.path.3=lib/native/osx-ppc wrapper.java.library.path.4=lib/native/solaris-sparc wrapper.java.library.path.5=lib/native/win32-x86 # Java Additional Parameters wrapper.java.additional.1=-server wrapper.java.additional.2=-showversion wrapper.java.additional.3=-Djava.awt.headless=true # JDK 1.5 Additional Parameters for jmx wrapper.java.additional.4=-Dcom.sun.management.jmxremote wrapper.java.additional.5=-Dcom.sun.management.jmxremote.port=4242 wrapper.java.additional.6=-Dcom.sun.management.jmxremote.authenticate=false wrapper.java.additional.7=-Dcom.sun.management.jmxremote.ssl=false wrapper.java.additional.8=-Dcom.sun.management.jmxremote.authenticate=false wrapper.java.additional.9=-Dcom.sun.management.jmxremote.password.file=./wrapper/jmxremote.password wrapper.java.additional.10=-Dwrapper.mbean.name="wrapper:type=Java Service Wrapper Control" wrapper.java.additional.11=-Dfisheye.inst="C:\Atlassian\fecru-2.6.3\bin\.." wrapper.java.additional.12=-XX:MaxPermSize=256m wrapper.java.additional.13=-Xrs wrapper.java.additional.14=-Dfile.encoding=UTF-8 # Initial Java Heap Size (in MB) wrapper.java.initmemory=64 # Maximum Java Heap Size (in MB) wrapper.java.maxmemory=1024 # Application parameters. Add parameters as needed starting from 1 # The first application parameter is the name of the class whose main # method is to be called when the application is launched. The class # name is followed by the number of parameters to be passed to its main # method. Then comes the actual parameters. wrapper.app.parameter.1=com.cenqua.fisheye.FishEyeCtl wrapper.app.parameter.2=1 wrapper.app.parameter.3=start # The start parameters are followed by the name of the class whose main # method is to be called to stop the application. The stop class name # is followed by a flag which controls whether or not the Wrapper should # wait for all non daemon threads to complete before exiting the JVM. # The flag is followed by the number of parameters to be passed to the # stop class's main method. Finally comes the actual parameters. wrapper.app.parameter.4=com.cenqua.fisheye.FishEyeCtl wrapper.app.parameter.5=true wrapper.app.parameter.6=1 wrapper.app.parameter.7=stop #******************************************************************** # Wrapper Logging Properties #******************************************************************** # Format of output for the console. (See docs for formats) wrapper.console.format=M # Log Level for console output. (See docs for log levels) wrapper.console.loglevel=INFO # Log file to use for wrapper output logging. wrapper.logfile=var/log/wrapper.log # Format of output for the log file. (See docs for formats) wrapper.logfile.format=LPTM # Log Level for log file output. (See docs for log levels) wrapper.logfile.loglevel=INFO # Maximum size that the log file will be allowed to grow to before # the log is rolled. Size is specified in bytes. The default value # of 0, disables log rolling. May abbreviate with the 'k' (kb) or # 'm' (mb) suffix. For example: 10m = 10 megabytes. wrapper.logfile.maxsize=50m # Maximum number of rolled log files which will be allowed before old # files are deleted. The default value of 0 implies no limit. wrapper.logfile.maxfiles=10 # Log Level for sys/event log output. (See docs for log levels) wrapper.syslog.loglevel=NONE #******************************************************************** # Wrapper Windows Properties #******************************************************************** # Title to use when running as a console wrapper.console.title=Fisheye #******************************************************************** # Wrapper Windows NT/2000/XP Service Properties #******************************************************************** # WARNING - Do not modify any of these properties when an application # using this configuration file has been installed as a service. # Please uninstall the service before modifying this section. The # service can then be reinstalled. # Name of the service wrapper.ntservice.name=Fisheye # Display name of the service wrapper.ntservice.displayname=Fisheye # Description of the service wrapper.ntservice.description=Fisheye # Service dependencies. Add dependencies as needed starting from 1 wrapper.ntservice.dependency.1= # Mode in which the service is installed. AUTO_START or DEMAND_START wrapper.ntservice.starttype=AUTO_START # Allow the service to interact with the desktop. wrapper.ntservice.interactive=false
wrapper.java.command = C: \ Program Files \ Java \ jdk1.6.0_25 \ bin \ java.exe
Полный путь к исполняемому файлу сервера JDK 'hotspot'. Обратите внимание, загрузите полный JDK, а не только JRE.
wrapper.java.additional.11 = -Dfisheye.inst = "C: \ Atlassian \ fecru-2.6.3 \ bin .."
wrapper.java.additional.12 = -XX: MaxPermSize = 256 м
wrapper.java.additional.13 = -Xrs
wrapper.java.additional.14 = -Dfile.encoding = UTF-8
Ничего из вышеперечисленного не показано в документации Atlassian, я добавил их с течением времени методом проб и ошибок. Когда FeCru впервые запускается под оболочкой службы, он может остановиться из-за ошибки нехватки памяти, это исправляет строка MaxPermSize.
Я также обнаружил, что необходимо указать FISHEYE_INST, как показано выше. Понятия не имею, почему путь указан с помощью /..
в конце концов, это было так в примере, который я нашел. Без сомнения, какой-то кулинарный ритуал Linux. Остальные строки, я не могу вспомнить, для чего они были, но я добавил их по той или иной причине и не документировал почему. Никто не идеален ;-)
wrapper.java.initmemory = 64 wrapper.java.maxmemory = 1024
Выделение памяти в куче увеличилось по сравнению со значениями по умолчанию - я проиндексировал несколько довольно объемных репозиториев, и я мог позволить себе дополнительные ресурсы - вы можете обойтись меньшими выделениями по умолчанию.