Wiki source code of Logging
Version 4.3 by Vincent Massol on 2010/06/02
Show last authors
author | version | line-number | content |
---|---|---|---|
1 | {{box cssClass="floatinginfobox" title="**Contents**"}}{{toc/}}{{/box}} | ||
2 | |||
3 | XWiki uses Commons Logging for logging. By default XWiki is configured so that Commons Logging uses log4J. XWiki's Log4J configuration is located inside XWiki's JAR (xwiki.jar), in a ##[[log4j.properties>>http://fisheye2.cenqua.com/browse/raw,r=trunk/xwiki/xwiki-platform/core/trunk/src/main/resources/log4j.properties]]## file. XWiki' JAR is itself located in your ##WEB-INF/lib/## directory. | ||
4 | |||
5 | {{info}} | ||
6 | By default XWiki is configured to log everything both on the console and in a xwiki.log file located in the directory from where you have started the JVM. This is usually the directory from where you have started your application server/Servlet container. It's recommended to either start the JVM from a location where it's ok to output the xwiki.log file or to create a custom Log4J configuration as explained below. | ||
7 | {{/info}} | ||
8 | |||
9 | = Using a custom Log4J configuration = | ||
10 | |||
11 | The best solution is to create a new ##log4j.properties## file in your ##WEB-INF/classes## directory. It'll thus override the one from the XWiki JAR. As an example, here's a sample configuration: | ||
12 | |||
13 | {{code language="none"}} | ||
14 | ### Direct log messages to stdout | ||
15 | log4j.appender.stdout=org.apache.log4j.ConsoleAppender | ||
16 | log4j.appender.stdout.Target=System.out | ||
17 | log4j.appender.stdout.layout=org.apache.log4j.PatternLayout | ||
18 | log4j.appender.stdout.layout.ConversionPattern=%d [%X{url}] [%t] %-5p %-30.30c{2} %x - %m %n | ||
19 | |||
20 | log4j.appender.file=org.apache.log4j.RollingFileAppender | ||
21 | log4j.appender.file.File=xwiki.log | ||
22 | log4j.appender.file.MaxFileSize=10MB | ||
23 | log4j.appender.file.MaxBackupIndex=50 | ||
24 | log4j.appender.file.layout=org.apache.log4j.PatternLayout | ||
25 | log4j.appender.file.layout.ConversionPattern=%d [%X{url}] [%t] %-5p %-30.30c{2} %x - %m %n | ||
26 | |||
27 | ### By default everything that is of warning or severity WARN, ERROR or FATAL is logged both to | ||
28 | ### the console and to the xwiki.log file. | ||
29 | log4j.rootLogger=warn, stdout, file | ||
30 | |||
31 | ### Hibernate logging options | ||
32 | log4j.logger.org.hibernate=warn | ||
33 | log4j.logger.org.hibernate.SQL=warn | ||
34 | log4j.logger.org.hibernate.type=warn | ||
35 | log4j.logger.org.hibernate.ps.PreparedStatementCache=warn | ||
36 | |||
37 | ### XWiki logging configuration | ||
38 | log4j.logger.org.xwiki=info | ||
39 | log4j.logger.com.xpn.xwiki=warn | ||
40 | log4j.logger.com.xpn.xwiki.render.XWikiRadeoxRenderEngine=warn | ||
41 | log4j.logger.com.xpn.xwiki.store.migration=info | ||
42 | |||
43 | ### Deactive Struts warnings | ||
44 | log4j.logger.org.apache.struts.util.RequestUtils=error | ||
45 | |||
46 | ### Deactivate JGroups warnings | ||
47 | log4j.logger.org.jgroups=error | ||
48 | |||
49 | ## Deactive PDF Export CSS Applier warnings | ||
50 | log4j.logger.info.informatica.doc.style.css.dom=error | ||
51 | log4j.logger.org.apache.fop.layoutmgr.inline.ContentLayoutManager=error | ||
52 | {{/code}} | ||
53 | |||
54 | Refer to Log4J's documentation to understand the settings. As an example, to turn on Hibernate's calls, just set the following: | ||
55 | |||
56 | {{code}} | ||
57 | log4j.logger.org.hibernate.SQL=debug | ||
58 | {{/code}} | ||
59 | |||
60 | = Activating the XWiki monitoring feature = | ||
61 | |||
62 | {{info}} | ||
63 | The monitoring feature is already active in the default configuration. | ||
64 | {{/info}} | ||
65 | |||
66 | XWiki has a feature to monitor times spent in its major components. To activate it, you need to: | ||
67 | |||
68 | * Enable the Monitor plugin by adding/modifying the following plugin definition in the ##xwiki.cfg## configuration file: | ||
69 | |||
70 | {{code language="none"}} | ||
71 | xwiki.plugins=\ | ||
72 | [...] | ||
73 | com.xpn.xwiki.monitor.api.MonitorPlugin | ||
74 | {{/code}} | ||
75 | |||
76 | * Enable it by adding/modifying the following in the ##xwiki.cfg## configuration file: | ||
77 | |||
78 | {{code language="none"}} | ||
79 | xwiki.monitor=1 | ||
80 | {{/code}} | ||
81 | |||
82 | * Since the plugin logs everything under the ##DEBUG## severity you also need to configure Log4J (as described above) by adding the following in ##log4j.properties##: | ||
83 | |||
84 | {{code language="none"}} | ||
85 | log4j.logger.com.xpn.xwiki.monitor=debug | ||
86 | {{/code}} |