1. Copy wllog4j.jar from your WebLogic server/lib directory and place it in your domain_root/lib folder.
2. Copy your version of log4j.jar to your domain_root/lib folder.
3. Copy your log4j.xml to your domain_root folder.
4. Log in to the your WebLogic admin server console. Click on Servers -> Admin Server -> Logging. Click on advanced mode, and change the logging implementation from JDK to Log4J. Save your changes.
Most of the blogs had these items, but the one critical piece that was missing:
5. (Linux)Edit the setDomainEnv.sh file in the domain_root/bin directory. and find the following code:
if [ "${LOG4J_CONFIG_FILE}" != "" ] ; then
JAVA_PROPERTIES="${JAVA_PROPERTIES} -Dlog4j.configuration=file:${LOG4J_CONFIG_FILE}"
export JAVA_PROPERTIES
fi
Insert the following above those lines of code(replacing the path with the one for your system's domain_root directory:
LOG4J_CONFIG_FILE=”/u01/app/oracle/middleware/user_projects/domains/base_domain/log4j.xml”
Export LOG4J_CONFIG_FILE
5. (Windows)
Edit the setDomainEnv.cmd file in the domain_root/bin directory. and find the following code:
if NOT "%LOG4J_CONFIG_FILE%"=="" (
set JAVA_PROPERTIES=%JAVA_PROPERTIES% -Dlog4j.configuration=file:%LOG4J_CONFIG_FILE%
)
Insert the following above those lines of code(replacing the path with the one for your system's domain_root directory:
set LOG4J_CONFIG_FILE=”C:\Oracle\Middleware\user_projects\domains\base_domain\log4j.xml”
6. Activate the changes and restart the admin server.
Here is a sample log4j.xml file. Obviously, you will need to update it for a valid location for your file appender, and replace yourcompany and yourproject with valid values.
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" debug="false">
<!--====================================================================-->
<!-- Appenders -->
<!-- %d{dd-MMM-yy HH:mm:ss} %-5p [%c{1}] %m%n -->
<appender name="CONSOLE" class="org.apache.log4j.ConsoleAppender">
<param name="Target" value="System.out"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="[%p] - %m (%F:%M:%L)%n"/>
<!--param name="ConversionPattern" value="%d{ISO8601} %p [%c{1}] - %m (%F:%M:%L)%n"/-->
</layout>
</appender>
<appender name="FILE" class="org.apache.log4j.RollingFileAppender">
<param name="File" value="/temp/logs/yourproject.log"/>
<param name="Append" value="true"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d{ISO8601} %t %-5p %c{2} - %m%n"/>
</layout>
</appender>
<!--====================================================================-->
<!-- Logging Levels -->
<category name="com.yourcompany.yourproject">
<priority value="DEBUG"/>
</category>
<category name="org.apache">
<priority value="WARN"/>
</category>
<category name="org.springframework">
<priority value="WARN"/>
</category>
<!--===================================================================-->
<!-- Appender Assignments -->
<root>
<priority value="ERROR"/>
<appender-ref ref="FILE"/>
</root>
</log4j:configuration>
Again, I hope that this will save someone the pain I went through to track this down.
5 comments:
Thank you for this post. This configuration worked.
Thanks really working for me .
Hello
That's very good tutorial. But i have a quesion- in my organization we have 3 separate applications deployed to weblogic 10.3.5.0
and we need 3 different log files, one for each application. How can i make it, if in log4j.xml i have only one parameter with path?
Thanks
Mat
Thank you very much for the post. I have been looking for this everywhere.. Good karma for you my man.
Program level comment is missing in this please find correct one
Configuring log4j for your Java Application for Web Logic 10.3.6.0
Server side Configurations
1. Copy wllog4j.jar from your WebLogic server/lib directory and place it in your domain_root/lib folder. –
example : /u01/oracle/Oracle/Middleware/user_projects/domains/gl_domain/lib
2. Copy your version of log4j.jar to your domain_root/lib folder.
example : /u01/oracle/Oracle/Middleware/user_projects/domains/gl_domain/lib
We used log4j-1.2.17.jar in the project
3. Copy your log4j.xml to your domain_root folder.
4.
5. (Linux)Edit the setDomainEnv.sh file in the domain_root/bin directory. and find the following code:
if [ "${LOG4J_CONFIG_FILE}" != "" ] ; then
JAVA_PROPERTIES="${JAVA_PROPERTIES} -Dlog4j.configuration=file:${LOG4J_CONFIG_FILE}"
export JAVA_PROPERTIES
fi
Insert the following above those lines of code(replacing the path with the one for your system's domain_root directory:
LOG4J_CONFIG_FILE=”/u01/app/oracle/middleware/user_projects/domains/base_domain/log4j.xml”
Export LOG4J_CONFIG_FILE
example : /u01/oracle/Oracle/Middleware/user_projects/domains/gl_domain/log4j.xml
6. Login to weblogic server console. Go to Servers -> Admin Server-> Logging. Click on advanced mode. Change the logging implementation from JDK to Log4J. Click save. (As shown in screenshots below)
7. Activate changes. Re-start the admin server.
Program level Addon
1. Place the log4j configuration file in server and provide that info in below mentioned way in Java program.
PropertyConfigurator.configure("/home/SOA_LOG_CONFIG_DIR/test_log4j.properties");
Post a Comment