Установка "java.util.logging.manager" во время запуска weblogic дает ClassNotFoundException - PullRequest
0 голосов
/ 28 апреля 2011

Для того, чтобы добиться пользовательского логина, я переопределяю java.util.logging.LogManager. Теперь мне нужно указать системное свойство «java.util.logging.manager» на мой класс CustomLogManager.

В jdev его можно установить параметрами java в свойствах проекта. "-Djava.util.logging.manager = project8.CustomLogManager".

Я отредактировал startWebLogic.sh и добавил то же самое.

# START WEBLOGIC

echo "starting weblogic with Java version:"

${JAVA_HOME}/bin/java ${JAVA_VM} -version

if [ "${WLS_REDIRECT_LOG}" = "" ] ; then
    echo "Starting WLS with line:"
    echo "${JAVA_HOME}/bin/java ${JAVA_VM} ${MEM_ARGS} -Djava.util.logging.manager=project8.CustomLogManager -Dweblogic.Name=${SERVER_NAME} -Djava.security.policy=${WL_HOME}/server/lib/weblogic.policy ${JAVA_OPTIONS} ${PROXY_SETTINGS} ${SERVER_CLASS}"

Но при запуске сервера администратора я получаю эту ошибку ..

 weblogic.Server
Could not load Logmanager "project8.CustomLogManager "
java.lang.ClassNotFoundException: project8.CustomLogManager 
        at java.net.URLClassLoader$1.run(URLClassLoader.java:200)
        at java.net.URLClassLoader.findClass(URLClassLoader.java:188)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:303)
        at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:248)
        at java.util.logging.LogManager$1.run(LogManager.java:167)
        at java.util.logging.LogManager.<clinit>(LogManager.java:156)
        at java.util.logging.Logger.getAnonymousLogger(Logger.java:342)
        at weblogic.kernel.KernelLogManager.createClientLogger(KernelLogManager.java:44)
        at weblogic.kernel.KernelLogManager.access$000(KernelLogManager.java:17)
        at weblogic.kernel.KernelLogManager$LoggerMaker.<clinit>(KernelLogManager.java:20)
        at weblogic.kernel.KernelLogManager.getLogger(KernelLogManager.java:26)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
        at java.lang.reflect.Method.invoke(Method.java:597)
        at weblogic.logging.MessageLogger.log(MessageLogger.java:96)
        at weblogic.logging.MessageLogger.log(MessageLogger.java:112)
        at weblogic.logging.WLMessageLogger.log(WLMessageLogger.java:53)
        at weblogic.kernel.T3SrvrLogger.logDomainLibPath(T3SrvrLogger.java:2440)
        at weblogic.Server.appendToClassPath(Server.java:129)
        at weblogic.Server.intializeClassloader(Server.java:140)
        at weblogic.Server.main(Server.java:67)

Но в то же время, сразу после этого я вижу, как мой CustomLogManager.jar импортируется. У меня есть файл CustomLogManager.jar в каталоге / domain-folder / bin /.

<Notice> <WebLogicServer> <BEA-000395> <Following extensions directory contents added to the end of the classpath:
/export/......../CustomLogManager.jar

Так что любая идея, как мне избежать ошибки ClassNotFound .?

Заранее спасибо

1 Ответ

1 голос
/ 05 мая 2011

Включите ваш файл CustomLogManager.jar в свой WEBLOGIC_CLASSPATH

...