kubectl -n rtf patch secret custom-properties -p '{"data":{"CUSTOM_LOG4J_ENABLED":"dHJ1ZQ=="}}'
Exporting Telemetry Externally
You can export telemetry externally by using a Log4j appender to integrate your logging system with applications deployed to Runtime Fabric.
You can use any Log4j appender. For information about configuring log4j2.xml
, see the
Log4j Configuration Syntax.
Requirements and Restrictions
-
MuleSoft Support doesn’t assist in implementing custom logging configurations or resolving issues caused by custom logging configurations.
-
MuleSoft is not responsible for issues arising from misconfiguration of your Log4j appender, including these or other issues:
-
Lost logging data
-
Performance degradation
-
Running out of disk space
-
-
Do not use synchronous log appenders.
-
Do not change anything in the console appender or Anypoint Monitoring appender.
You can use only asynchronous log appenders.
-
File appenders, such as FileAppender, RollingFileAppender, AnypointMonitoringFileAppender, and RandomAccessFileAppender, are removed automatically.
-
When using custom Log4j configurations, both Mule runtime engine and application logs remain available in Anypoint Monitoring.
Enable Log4j
Custom Log4j configurations are disabled by default. When you install Runtime Fabric, the parameter is disabled (false
) in Values.yaml
. You must set the value to true
.
You can also enable custom Log4j configurations by running the following steps:
-
From inside your cluster, run:
-
Restart the Runtime Fabric agent pod.
-
Restart the application associated with the custom Log4j configuration.
Custom Log4j is only supported by Mule applications running on Mule runtime engine instances greater than or equal to Mule version 4.3.0. The Mule image must be built after Nov 17, 2022. For details, refer to the Runtime Fabric Release Notes. |
Example: Create a Log4j Configuration Using Splunk
For logs to be viewable in Runtime Fabric and flow to Splunk, configure the SplunkHttp
Log4j appender.
To enable the Log4j appender:
-
Update the
log4j2.xml
configuration file with your logger settings and include theSplunkHttp
Log4j appender.In Anypoint Studio, the
log4j2.xml
file is located in thesrc/main/resources
directory.
<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="INFO" name="cloudhub" packages="com.mulesoft.ch.logging.appender, com.splunk.logging">
<Appenders>
<Console name="CONSOLE" target="SYSTEM_OUT">
<PatternLayout pattern="[%d{MM-dd HH:mm:ss}] %-5p %c{1} [%t]: %m%n"/>
</Console>
<SplunkHttp name="SPLUNK"
source="${env:APP_NAME}"
host="${env:POD_NAME}"
sourceType="mule-app"
url="${sys:splunk.host}"
token="${sys:splunk.token}"
index="main">
<PatternLayout pattern="[%d{MM-dd HH:mm:ss}] %-5p %c{1} [%t]: %m%n" />
</SplunkHttp>
</Appenders>
<Loggers>
<AsyncRoot level="INFO">
<AppenderRef ref="CONSOLE"/>
<AppenderRef ref="SPLUNK"/>
</AsyncRoot>
</Loggers>
</Configuration>
-
Ensure that the configuration includes the Splunk dependency:
<dependency> <groupId>com.splunk.logging</groupId> <artifactId>splunk-library-javalogging</artifactId> <version>x.x.x</version> </dependency> ********* ****************** <repository> <id>splunk-artifactory</id> <name>Splunk Releases</name> <url>https://splunk.jfrog.io/splunk/ext-releases-local</url>; </repository>
For the latest version of Splunk, see GitHub.
After your application starts, logs start flowing to your custom Log4j appender, and you can view them on your target logging system.
Disable Custom Log4j
If you enabled Custom Log4j in the values.yaml
during the installation of Runtime Fabric and you want to disable it at the Runtime Fabric cluster level, follow these steps:
-
In your cluster, run:
# kubectl -nrtf patch secret custom-properties -p '{"data":{"CUSTOM_LOG4J_ENABLED":""}}
-
Restart the Runtime Fabric agent pod:
# kubectl delete pod -n rtf -l app=agent
-
Restart the Mule app associated with the custom Log4j configuration.