Назад | Перейти на главную страницу

Как установить «MaxPermSize» для Atlassian Fisheye / Crucible, работающего в качестве службы в Win2k3?

Я пытался настроить 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

Выделение памяти в куче увеличилось по сравнению со значениями по умолчанию - я проиндексировал несколько довольно объемных репозиториев, и я мог позволить себе дополнительные ресурсы - вы можете обойтись меньшими выделениями по умолчанию.