当前位置: 首页 > 知识库问答 >
问题:

无法在WebSphere Liberty配置文件中为多个应用程序配置log4j

田慈
2023-03-14

我在liberty中部署了多个WebApp,它们都有自己的log4j配置文件,每个WAR中的log4j配置文件位于WAR的WEB-INF/classes文件夹中。添加log4j配置的web.xml代码片段如下:

<context-param>
                <param-name>log4jConfiguration</param-name>
                <param-value>classpath:portal-log4j2.xml</param-value>
        </context-param>

这似乎适用于所有其他Tomcat和Jboss应用服务器,但不适用于WebSphere Liberty Profile。即使在WebSphere Basic profile中,似乎也是如此。在JVM.options中指定-dlog4j.configurationFile对我来说不起作用,因为我有多个应用程序

我查看了Websphere Liberty:如何指定log4j2配置位置?

也试过同样的。对我来说,这导致了以下错误

Exception = javax.xml.stream.XMLStreamException
Source = com.ibm.ws.artifact.loose.internal.LooseContainerFactoryHelper
probeid = 126
Stack Dump = javax.xml.stream.XMLStreamException: ParseError at [row,col]:[8,46]
Message: found: CHARACTERS, expected START_ELEMENT or END_ELEMENT
        at java.xml/com.sun.org.apache.xerces.internal.impl.XMLStreamReaderImpl.nextTag(XMLStreamReaderImpl.java:1361)
        at com.ibm.ws.artifact.loose.internal.LooseContainerFactoryHelper.createContainer(LooseContainerFactoryHelper.java:80)
<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="error" name="mbaasportal" packages="com.kony.mobilefabric.logger">
    <!-- Filter to control log level dynamically. The name of the key should match with key in TenantContextFilter.java -->
	<DynamicLogFilter key="KONY_PORTAL_DYNAMIC_LOG_LEVEL" />
	<Appenders>
        <CustomRollingFile name="logfileappender" fileName="${sys:LOG_LOCATION}/mbaasportal.log" append="true" filePattern="${sys:LOG_LOCATION}/mbaasportal.log.%i">
            <MobileFabricPatternLayout>
                <ProductName>console.portal</ProductName>
            </MobileFabricPatternLayout>
            <Policies>
                <SizeBasedTriggeringPolicy size="10 MB"/>
            </Policies>
            <DefaultRolloverStrategy max="10"/>
        </CustomRollingFile>

        <Console name="dockerappender" target="SYSTEM_OUT">            
            <JsonLayout compact="true" eventEol="true" properties="true" locationInfo="true">
                <KeyValuePair key="fabricService" value="console.portal"/>
            </JsonLayout>
        </Console>

        <Console name="consoleappender" target="SYSTEM_OUT"> 
            <MobileFabricPatternLayout> 
                <ProductName>console.portal</ProductName>
            </MobileFabricPatternLayout> 
        </Console>

        <Socket name="SYSLOGappender" host="localhost" port="514" protocol="UDP">
            <Rfc3164SyslogLayout charset="ISO-8859-1" ProductName="console.portal"/>
        </Socket>
    </Appenders>

    <Loggers>
    
    	<Logger name="org.hibernate" level="ERROR" additivity="false">
            <AppenderRef ref="${sys:LOG_OPTION}appender"/>
        </Logger>

        <Logger name="org.springframework" level="ERROR" additivity="false">
            <AppenderRef ref="${sys:LOG_OPTION}appender"/>
        </Logger>

        <Logger name="httpclient" level="ERROR" additivity="false">
            <AppenderRef ref="${sys:LOG_OPTION}appender"/>
        </Logger>
        
        <Logger name="com.kony.mbaas.portal.wsclient.RestTemplateWrapper" level="ERROR" additivity="false">
            <AppenderRef ref="${sys:LOG_OPTION}appender"/>
        </Logger>

        <Root level="${sys:LOG_LEVEL}">
            <AppenderRef ref="${sys:LOG_OPTION}appender"/>
        </Root>
    </Loggers>
</Configuration>

非常感谢对此的任何指导

共有1个答案

盖成弘
2023-03-14

我与IBM support的Brian一起解决了这个问题。似乎这个问题是Liberty上的Log4J22.8特有的,升级到V2.13解决了这个问题。有关详情,请参阅以下内容:

https://developer.ibm.com/answers/questions/526956/log4j-config-file-present-in-webapp-not-loaded-in.html

 类似资料:
  • 问题内容: 好的,所以我不想在这里展开一场圣战,但是我们正在努力巩固处理应用程序配置文件的方式,我们正在努力决定采用哪种最佳方法。目前,我们分发的每个应用程序都在使用其自己的临时配置文件,无论是属性文件(ini样式),XML还是JSON(目前仅在内部使用!)。 目前,我们的大多数代码是Java,因此我们一直在研究Apache Commons Config ,但是我们发现它非常冗长。我们还研究了XM

  • 我尝试了一个显示其他响应的测试用例,我将一步一步地解释它: > 我在我的设备上安装了MDM配置文件,这提示我安装了一个应用程序,并且我成功地安装了它。应用程序已进入“应用程序中的配置文件”部分。 然后我手动删除了应用程序。

  • 奇怪的事情发生在我身上。我不知道如何解决它,Spring云配置不能加载本机或云配置文件,除非它的文件名是application.yml/application.properties。 以下代码是我的配置: 波姆。xml: 配置服务器: 应用yml: 共享文件夹结构器: 资源 --shared --application-dev.yml --sms-dev.yml 它看起来不错,运行良好,没有错误,

  • 1-我有一个带有Spring Boot的API,我需要配置两个DBMS(MySQL和Postgres)。 2-对于每个DBMS,我需要配置不同的配置文件。(Dev,Prod) 遵循我的MySQL配置类: 我以为我的出口是: 重要: 当我将配置文件配置为连接到我的MySQL Dev数据库时,我只想连接到它。我想要同样的结果,当它是MySQL的Prod的基础时。 当我将配置文件配置为连接到我的Post

  • 我在Spring Boot中的资源类路径位置中有多个yml文件,就像下面的Spring Boot结构一样。起初,我只为abc的申请而写。当时,这个文件的所有值都加载到了相应的类中,但是当我添加到另一个文件应用程序xyz时。然后,yml也会加载到相应的配置类中,但此时只加载应用程序xyz的值。两个配置类中的yml。因此,需要帮助在单个构建中配置相应配置文件中两个文件的值: 申请内容abc。yml a

  • 我正在使用log4j2库来管理日志记录过程。我创建了一个名为log4j2的配置文件。包含appender和logger配置的xml。然后,我在每个类中定义了一个记录器 我没有在任何地方指定conf文件的名称,所以我认为库隐式地获取并读取它。 现在,我需要以jar文件的形式提供我的应用程序,所以我需要使配置文件可用,以便用户可以修改和配置它。 在我的例子中,我建议在jar文件级别创建一个XXX文件夹