2014-01-23 3 views
2

О, можно ли создать среду JBoss7.1.1 AS с standalone.sh? Обычно мы запускаем его с помощью сценария инициализации, а затем развертываем WAR с помощью jboss-cli.sh. Но этот метод не позволяет создавать файлы ведения журнала.JBoss 7 multiple log4j Конфигурация с использованием профиля пружины

log4j.appender.A1.File=../server/default/log/Mylog.log 

Когда я запускаю сервер с standalone.sh, файлы журнала создаются успешно.

Но когда я запускаю его с помощью сервиса jboss start &, тогда разворачиваем его с помощью jboss-cli.sh Я получаю эту ошибку.

12:00:38,996 ERROR [stderr] (MSC service thread 1-3) log4j:ERROR setFile(null,true) call failed. 
    12:00:38,997 ERROR [stderr] (MSC service thread 1-3) java.io.FileNotFoundException: ../server/default/log/Mylog.log (No such file or directory) 
    12:00:38,998 ERROR [stderr] (MSC service thread 1-3) at java.io.FileOutputStream.open(Native Method) 
    12:00:38,998 ERROR [stderr] (MSC service thread 1-3) at java.io.FileOutputStream.<init>(FileOutputStream.java:212) 
    12:00:38,999 ERROR [stderr] (MSC service thread 1-3) at java.io.FileOutputStream.<init>(FileOutputStream.java:136) 
    12:00:38,999 ERROR [stderr] (MSC service thread 1-3) at org.apache.log4j.FileAppender.setFile(FileAppender.java:294) 
    12:00:39,000 ERROR [stderr] (MSC service thread 1-3) at org.apache.log4j.RollingFileAppender.setFile(RollingFileAppender.java:207) 
    12:00:39,000 ERROR [stderr] (MSC service thread 1-3) at org.apache.log4j.FileAppender.activateOptions(FileAppender.java:165) 
    12:00:39,000 ERROR [stderr] (MSC service thread 1-3) at org.apache.log4j.config.PropertySetter.activate(PropertySetter.java:307) 
    12:00:39,000 ERROR [stderr] (MSC service thread 1-3) at org.apache.log4j.config.PropertySetter.setProperties(PropertySetter.java:172) 
    12:00:39,001 ERROR [stderr] (MSC service thread 1-3) at org.apache.log4j.config.PropertySetter.setProperties(PropertySetter.java:104) 
    12:00:39,001 ERROR [stderr] (MSC service thread 1-3) at org.apache.log4j.PropertyConfigurator.parseAppender(PropertyConfigurator.java:842) 
    12:00:39,001 ERROR [stderr] (MSC service thread 1-3) at org.apache.log4j.PropertyConfigurator.parseCategory(PropertyConfigurator.java:768) 
    12:00:39,002 ERROR [stderr] (MSC service thread 1-3) at org.apache.log4j.PropertyConfigurator.configureRootCategory(PropertyConfigurator.java:648) 
    12:00:39,002 ERROR [stderr] (MSC service thread 1-3) at org.apache.log4j.PropertyConfigurator.doConfigure(PropertyConfigurator.java:514) 
    12:00:39,002 ERROR [stderr] (MSC service thread 1-3) at org.apache.log4j.PropertyConfigurator.doConfigure(PropertyConfigurator.java:580) 
    12:00:39,003 ERROR [stderr] (MSC service thread 1-3) at org.apache.log4j.PropertyConfigurator.configure(PropertyConfigurator.java:415) 
    12:00:39,003 ERROR [stderr] (MSC service thread 1-3) at org.springframework.util.Log4jConfigurer.initLogging(Log4jConfigurer.java:72) 
    12:00:39,003 ERROR [stderr] (MSC service thread 1-3) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    12:00:39,004 ERROR [stderr] (MSC service thread 1-3) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
    12:00:39,004 ERROR [stderr] (MSC service thread 1-3) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    12:00:39,004 ERROR [stderr] (MSC service thread 1-3) at java.lang.reflect.Method.invoke(Method.java:606) 
    12:00:39,005 ERROR [stderr] (MSC service thread 1-3) at org.springframework.util.MethodInvoker.invoke(MethodInvoker.java:273) 
    12:00:39,005 ERROR [stderr] (MSC service thread 1-3) at org.springframework.beans.factory.config.MethodInvokingFactoryBean.doInvok 

Я добавил JBoss структуру также

<?xml version="1.0" encoding="UTF-8"?> 
    <jboss-deployment-structure> 
     <deployment> 
      <exclusions> 
       <module name="org.apache.log4j" /> 
      </exclusions> 
     </deployment> 
    </jboss-deployment-structure> 
    <!-- <jboss-deployment-structure> <deployment> <exclusions> <module name="org.apache.log4j" 
     /> </exclusions> </deployment> <sub-deployment name="takaful.war"> <exclusions> 
     <module name="org.apache.log4j" /> </exclusions> </sub-deployment> <sub-deployment 
     name="takaful-0.0.1-SNAPSHOT.jar"> <exclusions> <module name="org.apache.log4j" 
     /> </exclusions> </sub-deployment> </jboss-deployment-structure> --> 

развертывания И последний мой пружинный боб инициализировать log4j.

<beans profile="a"> 
    <bean id="logb" 
     class="org.springframework.beans.factory.config.MethodInvokingFactoryBean"> 
     <property name="targetClass" value="org.springframework.util.Log4jConfigurer" /> 
     <property name="targetMethod" value="initLogging" /> 
     <property name="arguments"> 
     <list> 
     <value>${loc}/${log4j.properties.location}</value> 
     </list> 
     </property> 
     </bean> 
     </beans> 

     <beans profile="b"> 
     <bean id="logb" 
         class="org.springframework.beans.factory.config.MethodInvokingFactoryBean"> 
     <property name="targetClass" value="org.springframework.util.Log4jConfigurer" /> 
     <property name="targetMethod" value="initLogging" /> 
     <property name="arguments"> 
     <list> 
     <value>${loc}/${log4j.properties.location2}</value> 
     </list> 
     </property> 
     </bean> 
     </beans> 

     <beans profile="c"> 
     <bean id="logb" 
         class="org.springframework.beans.factory.config.MethodInvokingFactoryBean"> 
     <property name="targetClass" value="org.springframework.util.Log4jConfigurer" /> 
     <property name="targetMethod" value="initLogging" /> 
     <property name="arguments"> 
     <list> 
     <value>${loc}/${log4j.properties.location3}</value> 
     </list> 
     </property> 
     </bean> 
     </beans> 

Этот код работает отлично, если я начать JBoss7.1.1.FINAL с standalone.sh но дает эту ошибку, если я использую старт JBoss службы и развернуть войну с jboss-cli.sh по развертывания warname.war

Пожалуйста, помогите.

ответ

0

Это говорит

java.io.FileNotFoundException: ../server/default/log/Mylog.log 

Так текущий каталог отличается, когда вы начинаете с «началом службы JBoss». Попробуйте добавить JBOSS_HOME в jboss-as.conf или установить JBoss в JBOSS_HOME =/usr/share/jboss-as

Смежные вопросы