Signed-off-by: WalkerWatch <ctwalker@gmail.com>
This commit is contained in:
parent
726fcd814c
commit
1e76c99442
|
@ -27,9 +27,11 @@ Enabling these frameworks in the Jetty distribution is as easy as activating any
|
||||||
[source, screen, subs="{sub-order}"]
|
[source, screen, subs="{sub-order}"]
|
||||||
....
|
....
|
||||||
[my-base]$ java -jar ../start.jar --add-to-start=logging-jetty
|
[my-base]$ java -jar ../start.jar --add-to-start=logging-jetty
|
||||||
INFO : logging-jetty initialized in ${jetty.base}/start.d/logging-jetty.ini
|
INFO : logging-jetty initialized in ${jetty.base}/start.d/logging-jetty.ini
|
||||||
INFO : resources transitive
|
INFO : resources transitively enabled
|
||||||
INFO : Base directory was modified
|
MKDIR : ${jetty.base}/resources
|
||||||
|
COPY : ${jetty.home}/modules/logging-jetty/resources/jetty-logging.properties to ${jetty.base}/resources/jetty-logging.properties
|
||||||
|
INFO : Base directory was modified
|
||||||
....
|
....
|
||||||
|
|
||||||
As noted above, Jetty supports a wide array of logging technologies.
|
As noted above, Jetty supports a wide array of logging technologies.
|
||||||
|
@ -78,7 +80,8 @@ Most other top level logging modules work in the same way: `logging-jcl`, `loggi
|
||||||
Jetty uses the SLF4J api as a binding to provide logging information to additional frameworks such as Log4j or Logback.
|
Jetty uses the SLF4J api as a binding to provide logging information to additional frameworks such as Log4j or Logback.
|
||||||
It can also be used on it's own to provide simple server logging.
|
It can also be used on it's own to provide simple server logging.
|
||||||
To enable the SLF4J framework, you need to activate the `logging-slf4j` module.
|
To enable the SLF4J framework, you need to activate the `logging-slf4j` module.
|
||||||
By default, log files will be stored in `${jetty.base}/logs`.
|
|
||||||
|
//TODO - Update after 1019 is resolved
|
||||||
|
|
||||||
[source, screen, subs="{sub-order}"]
|
[source, screen, subs="{sub-order}"]
|
||||||
....
|
....
|
||||||
|
@ -115,9 +118,9 @@ Proceed (y/N)? y
|
||||||
INFO : slf4j-api transitively enabled
|
INFO : slf4j-api transitively enabled
|
||||||
INFO : logging-slf4j initialized in ${jetty.base}/start.d/logging-slf4j.ini
|
INFO : logging-slf4j initialized in ${jetty.base}/start.d/logging-slf4j.ini
|
||||||
MKDIR : ${jetty.base}/lib/slf4j
|
MKDIR : ${jetty.base}/lib/slf4j
|
||||||
DOWNLOAD: http://central.maven.org/maven2/org/slf4j/slf4j-api/1.7.21/slf4j-api-1.7.21.jar to ${jetty.base}/lib/slf4j/slf4j-api-1.7.21.jar
|
DOWNLD: http://central.maven.org/maven2/org/slf4j/slf4j-api/1.7.21/slf4j-api-1.7.21.jar to ${jetty.base}/lib/slf4j/slf4j-api-1.7.21.jar
|
||||||
INFO : Base directory was modified
|
INFO : Base directory was modified
|
||||||
ERROR : Module logging-slf4j requires a `slf4j-impl` module from one of [slf4j-simple-impl, slf4j-logback, slf4j-jul, slf4j-jcl, slf4j-log4j2, slf4j-log4j]
|
ERROR : Module logging-slf4j requires a module providing slf4j-impl from one of [slf4j-simple-impl, slf4j-logback, slf4j-jul, slf4j-log4j2, slf4j-log4j]
|
||||||
|
|
||||||
ERROR : Unsatisfied module dependencies: logging-slf4j
|
ERROR : Unsatisfied module dependencies: logging-slf4j
|
||||||
|
|
||||||
|
@ -154,13 +157,15 @@ INFO : Base directory was modified
|
||||||
└── slf4j-simple-impl.ini
|
└── slf4j-simple-impl.ini
|
||||||
....
|
....
|
||||||
|
|
||||||
|
Jetty is now configured to log using the SLF4J framework.
|
||||||
|
A standard SLF4J properties file is located in `${jetty.base}/resources/simplelogger.properties`.
|
||||||
|
|
||||||
[[example-logging-log4j]]
|
[[example-logging-log4j]]
|
||||||
==== Logging with Log4j and Log4j2
|
==== Logging with Log4j and Log4j2
|
||||||
|
|
||||||
It is possible to have the Jetty Server logging configured so that Log4j or Log4j2 controls the output of logging events produced by Jetty.
|
It is possible to have the Jetty Server logging configured so that Log4j or Log4j2 controls the output of logging events produced by Jetty.
|
||||||
This is accomplished by configuring Jetty for logging to http://logging.apache.org/log4j/[Apache Log4j] via http://slf4j.org/manual.html[Slf4j] and the http://slf4j.org/manual.html#swapping[Slf4j binding layer for Log4j].
|
This is accomplished by configuring Jetty for logging to http://logging.apache.org/log4j/[Apache Log4j] via http://slf4j.org/manual.html[Slf4j] and the http://slf4j.org/manual.html#swapping[Slf4j binding layer for Log4j].
|
||||||
Implementation of Log4j can be done by enabling the `logging-log4j` module.
|
Implementation of Log4j can be done by enabling the `logging-log4j` module.
|
||||||
By default, log files will be stored in `${jetty.base}/logs`.
|
|
||||||
|
|
||||||
[source, screen, subs="{sub-order}"]
|
[source, screen, subs="{sub-order}"]
|
||||||
....
|
....
|
||||||
|
@ -204,13 +209,12 @@ INFO : resources transitively enabled
|
||||||
INFO : slf4j-log4j transitively enabled
|
INFO : slf4j-log4j transitively enabled
|
||||||
INFO : logging-log4j initialized in ${jetty.base}/start.d/logging-log4j.ini
|
INFO : logging-log4j initialized in ${jetty.base}/start.d/logging-log4j.ini
|
||||||
MKDIR : ${jetty.base}/lib/slf4j
|
MKDIR : ${jetty.base}/lib/slf4j
|
||||||
DOWNLOAD: http://central.maven.org/maven2/org/slf4j/slf4j-api/1.7.21/slf4j-api-1.7.21.jar to ${jetty.base}/lib/slf4j/slf4j-api-1.7.21.jar
|
DOWNLD: http://central.maven.org/maven2/org/slf4j/slf4j-api/1.7.21/slf4j-api-1.7.21.jar to ${jetty.base}/lib/slf4j/slf4j-api-1.7.21.jar
|
||||||
MKDIR : ${jetty.base}/resources
|
|
||||||
COPY : ${jetty.home}/modules/log4j/log4j.properties to ${jetty.base}/resources/log4j.properties
|
|
||||||
MKDIR : ${jetty.base}/lib/log4j
|
MKDIR : ${jetty.base}/lib/log4j
|
||||||
DOWNLOAD: http://central.maven.org/maven2/log4j/log4j/1.2.17/log4j-1.2.17.jar to ${jetty.base}/lib/log4j/log4j-1.2.17.jar
|
COPY : /Users/chris/.m2/repository/log4j/log4j/1.2.17/log4j-1.2.17.jar to ${jetty.base}/lib/log4j/log4j-1.2.17.jar
|
||||||
MKDIR : ${jetty.base}/logs
|
MKDIR : ${jetty.base}/resources
|
||||||
DOWNLOAD: http://central.maven.org/maven2/org/slf4j/slf4j-log4j12/1.7.21/slf4j-log4j12-1.7.21.jar to ${jetty.base}/lib/slf4j/slf4j-log4j12-1.7.21.jar
|
COPY : ${jetty.home}/modules/log4j-impl/resources/log4j.xml to ${jetty.base}/resources/log4j.xml
|
||||||
|
DOWNLD: http://central.maven.org/maven2/org/slf4j/slf4j-log4j12/1.7.21/slf4j-log4j12-1.7.21.jar to ${jetty.base}/lib/slf4j/slf4j-log4j12-1.7.21.jar
|
||||||
INFO : Base directory was modified
|
INFO : Base directory was modified
|
||||||
|
|
||||||
[my-base]$ tree
|
[my-base]$ tree
|
||||||
|
@ -221,19 +225,20 @@ INFO : Base directory was modified
|
||||||
│ └── slf4j
|
│ └── slf4j
|
||||||
│ ├── slf4j-api-1.7.21.jar
|
│ ├── slf4j-api-1.7.21.jar
|
||||||
│ └── slf4j-log4j12-1.7.21.jar
|
│ └── slf4j-log4j12-1.7.21.jar
|
||||||
├── logs
|
|
||||||
├── resources
|
├── resources
|
||||||
│ └── log4j.properties
|
│ └── log4j.xml
|
||||||
└── start.d
|
└── start.d
|
||||||
└── logging-log4j.ini
|
└── logging-log4j.ini
|
||||||
....
|
....
|
||||||
|
|
||||||
Or, to enable Log4j2, simply enable the `logging-log4j2` module.
|
Jetty is now configured to log using the Log4j framework.
|
||||||
By default, log files will be stored in `${jetty.base}/logs`.
|
A standard Log4j configuration file is located in `${jetty.base}/resources/log4j.xml`.
|
||||||
|
|
||||||
|
Or, to set up Log4j2, enable the `logging-log4j2` module.
|
||||||
|
|
||||||
[source, screen, subs="{sub-order}"]
|
[source, screen, subs="{sub-order}"]
|
||||||
....
|
....
|
||||||
[my-base]$ java -jar ../start.jar --add-to-start=logging-log4j2
|
[my-base]$ java -jar ../start.jar --add-to-start=logging-log4j2
|
||||||
|
|
||||||
ALERT: There are enabled module(s) with licenses.
|
ALERT: There are enabled module(s) with licenses.
|
||||||
The following 2 module(s):
|
The following 2 module(s):
|
||||||
|
@ -274,34 +279,32 @@ INFO : resources transitively enabled
|
||||||
INFO : slf4j-log4j2 transitively enabled
|
INFO : slf4j-log4j2 transitively enabled
|
||||||
INFO : log4j2-impl transitively enabled
|
INFO : log4j2-impl transitively enabled
|
||||||
MKDIR : ${jetty.base}/lib/slf4j
|
MKDIR : ${jetty.base}/lib/slf4j
|
||||||
DOWNLOAD: http://central.maven.org/maven2/org/slf4j/slf4j-api/1.7.21/slf4j-api-1.7.21.jar to ${jetty.base}/lib/slf4j/slf4j-api-1.7.21.jar
|
DOWNLD: http://central.maven.org/maven2/org/slf4j/slf4j-api/1.7.21/slf4j-api-1.7.21.jar to ${jetty.base}/lib/slf4j/slf4j-api-1.7.21.jar
|
||||||
MKDIR : ${jetty.base}/lib/log4j
|
|
||||||
DOWNLOAD: http://central.maven.org/maven2/org/apache/logging/log4j/log4j-api/2.6.1/log4j-api-2.6.1.jar to ${jetty.base}/lib/log4j/log4j-api-2.6.1.jar
|
|
||||||
MKDIR : ${jetty.base}/resources
|
|
||||||
DOWNLOAD: http://central.maven.org/maven2/org/apache/logging/log4j/log4j-slf4j-impl/2.6.1/log4j-slf4j-impl-2.6.1.jar to ${jetty.base}/lib/log4j/log4j-slf4j-impl-2.6.1.jar
|
|
||||||
MKDIR : ${jetty.base}/lib/log4j2
|
MKDIR : ${jetty.base}/lib/log4j2
|
||||||
DOWNLOAD: http://central.maven.org/maven2/org/apache/logging/log4j/log4j-core/2.6.1/log4j-core-2.6.1.jar to ${jetty.base}/lib/log4j2/log4j-core-2.6.1.jar
|
DOWNLD: http://central.maven.org/maven2/org/apache/logging/log4j/log4j-api/2.6.1/log4j-api-2.6.1.jar to ${jetty.base}/lib/log4j2/log4j-api-2.6.1.jar
|
||||||
COPY : ${jetty.home}/modules/log4j2/log4j2.xml to ${jetty.base}/resources/log4j2.xml
|
MKDIR : ${jetty.base}/resources
|
||||||
MKDIR : ${jetty.base}/logs
|
DOWNLD: http://central.maven.org/maven2/org/apache/logging/log4j/log4j-slf4j-impl/2.6.1/log4j-slf4j-impl-2.6.1.jar to ${jetty.base}/lib/log4j2/log4j-slf4j-impl-2.6.1.jar
|
||||||
|
DOWNLD: http://central.maven.org/maven2/org/apache/logging/log4j/log4j-core/2.6.1/log4j-core-2.6.1.jar to ${jetty.base}/lib/log4j2/log4j-core-2.6.1.jar
|
||||||
|
COPY : ${jetty.home}/modules/log4j2-impl/resources/log4j2.xml to ${jetty.base}/resources/log4j2.xml
|
||||||
INFO : Base directory was modified
|
INFO : Base directory was modified
|
||||||
|
|
||||||
[my-base]$ tree
|
[my-base]$ tree
|
||||||
.
|
.
|
||||||
├── lib
|
├── lib
|
||||||
│ ├── log4j
|
|
||||||
│ │ ├── log4j-api-2.6.1.jar
|
|
||||||
│ │ └── log4j-slf4j-impl-2.6.1.jar
|
|
||||||
│ ├── log4j2
|
│ ├── log4j2
|
||||||
│ │ └── log4j-core-2.6.1.jar
|
│ │ ├── log4j-api-2.6.1.jar
|
||||||
|
│ │ ├── log4j-core-2.6.1.jar
|
||||||
|
│ │ └── log4j-slf4j-impl-2.6.1.jar
|
||||||
│ └── slf4j
|
│ └── slf4j
|
||||||
│ └── slf4j-api-1.7.21.jar
|
│ └── slf4j-api-1.7.21.jar
|
||||||
├── logs
|
|
||||||
├── resources
|
├── resources
|
||||||
│ └── log4j2.xml
|
│ └── log4j2.xml
|
||||||
└── start.d
|
└── start.d
|
||||||
└── logging-log4j2.ini
|
└── logging-log4j2.ini
|
||||||
....
|
....
|
||||||
|
|
||||||
|
At this point Jetty is configured so that the Jetty server itself will log using Log4j2, using the Log4j2 configuration found in `{$jetty.base}/resources/log4j2.xml`.
|
||||||
|
|
||||||
[[example-logging-logback]]
|
[[example-logging-logback]]
|
||||||
==== Logging with Logback
|
==== Logging with Logback
|
||||||
|
|
||||||
|
@ -309,7 +312,6 @@ It is possible to have the Jetty Server logging configured so that Logback contr
|
||||||
This is accomplished by configuring Jetty for logging to `Logback`, which uses http://slf4j.org/manual.html[Slf4j] and the http://logback.qos.ch/[Logback Implementation for Slf4j].
|
This is accomplished by configuring Jetty for logging to `Logback`, which uses http://slf4j.org/manual.html[Slf4j] and the http://logback.qos.ch/[Logback Implementation for Slf4j].
|
||||||
|
|
||||||
To set up Jetty logging via Logback, enable the `logging-logback` module.
|
To set up Jetty logging via Logback, enable the `logging-logback` module.
|
||||||
By default, log files will be stored in `${jetty.base}/logs`.
|
|
||||||
|
|
||||||
[source, screen, subs="{sub-order}"]
|
[source, screen, subs="{sub-order}"]
|
||||||
....
|
....
|
||||||
|
@ -362,13 +364,12 @@ INFO : slf4j-logback transitively enabled
|
||||||
INFO : logging-logback initialized in ${jetty.base}/start.d/logging-logback.ini
|
INFO : logging-logback initialized in ${jetty.base}/start.d/logging-logback.ini
|
||||||
INFO : resources transitively enabled
|
INFO : resources transitively enabled
|
||||||
MKDIR : ${jetty.base}/lib/slf4j
|
MKDIR : ${jetty.base}/lib/slf4j
|
||||||
DOWNLOAD: http://central.maven.org/maven2/org/slf4j/slf4j-api/1.7.21/slf4j-api-1.7.21.jar to ${jetty.base}/lib/slf4j/slf4j-api-1.7.21.jar
|
DOWNLD: http://central.maven.org/maven2/org/slf4j/slf4j-api/1.7.21/slf4j-api-1.7.21.jar to ${jetty.base}/lib/slf4j/slf4j-api-1.7.21.jar
|
||||||
MKDIR : ${jetty.base}/lib/logback
|
MKDIR : ${jetty.base}/lib/logback
|
||||||
DOWNLOAD: http://central.maven.org/maven2/ch/qos/logback/logback-core/1.1.7/logback-core-1.1.7.jar to ${jetty.base}/lib/logback/logback-core-1.1.7.jar
|
DOWNLD: http://central.maven.org/maven2/ch/qos/logback/logback-core/1.1.7/logback-core-1.1.7.jar to ${jetty.base}/lib/logback/logback-core-1.1.7.jar
|
||||||
MKDIR : ${jetty.base}/resources
|
MKDIR : ${jetty.base}/resources
|
||||||
COPY : ${jetty.home}/modules/logback/logback.xml to ${jetty.base}/resources/logback.xml
|
COPY : ${jetty.home}/modules/logback-impl/resources/logback.xml to ${jetty.base}/resources/logback.xml
|
||||||
MKDIR : ${jetty.base}/logs
|
DOWNLD: http://central.maven.org/maven2/ch/qos/logback/logback-classic/1.1.7/logback-classic-1.1.7.jar to ${jetty.base}/lib/logback/logback-classic-1.1.7.jar
|
||||||
DOWNLOAD: http://central.maven.org/maven2/ch/qos/logback/logback-classic/1.1.7/logback-classic-1.1.7.jar to ${jetty.base}/lib/logback/logback-classic-1.1.7.jar
|
|
||||||
INFO : Base directory was modified
|
INFO : Base directory was modified
|
||||||
|
|
||||||
[my-base]$ tree
|
[my-base]$ tree
|
||||||
|
@ -379,7 +380,6 @@ INFO : Base directory was modified
|
||||||
│ │ └── logback-core-1.1.7.jar
|
│ │ └── logback-core-1.1.7.jar
|
||||||
│ └── slf4j
|
│ └── slf4j
|
||||||
│ └── slf4j-api-1.7.21.jar
|
│ └── slf4j-api-1.7.21.jar
|
||||||
├── logs
|
|
||||||
├── resources
|
├── resources
|
||||||
│ └── logback.xml
|
│ └── logback.xml
|
||||||
└── start.d
|
└── start.d
|
||||||
|
@ -387,7 +387,6 @@ INFO : Base directory was modified
|
||||||
....
|
....
|
||||||
|
|
||||||
At this point Jetty is configured so that the Jetty server itself will log using Logback, using the Logback configuration found in `{$jetty.base}/resources/logback.xml`.
|
At this point Jetty is configured so that the Jetty server itself will log using Logback, using the Logback configuration found in `{$jetty.base}/resources/logback.xml`.
|
||||||
Log files will be stored in `${jetty.base}/logs`.
|
|
||||||
|
|
||||||
==== Logging with Java Util Logging
|
==== Logging with Java Util Logging
|
||||||
|
|
||||||
|
@ -396,7 +395,8 @@ Log files will be stored in `${jetty.base}/logs`.
|
||||||
It is possible to have the Jetty Server logging configured so that `java.util.logging` controls the output of logging events produced by Jetty.
|
It is possible to have the Jetty Server logging configured so that `java.util.logging` controls the output of logging events produced by Jetty.
|
||||||
|
|
||||||
This example demonstrates how to configuring Jetty for logging to `java.util.logging` via http://slf4j.org/manual.html[Slf4j] and the http://slf4j.org/manual.html#swapping[Slf4j binding layer for java.util.logging].
|
This example demonstrates how to configuring Jetty for logging to `java.util.logging` via http://slf4j.org/manual.html[Slf4j] and the http://slf4j.org/manual.html#swapping[Slf4j binding layer for java.util.logging].
|
||||||
By default, log files will be stored in `${jetty.base}/logs`.
|
|
||||||
|
//TODO - Review after 1020 is resolved
|
||||||
|
|
||||||
[source, screen, subs="{sub-order}"]
|
[source, screen, subs="{sub-order}"]
|
||||||
....
|
....
|
||||||
|
@ -436,11 +436,10 @@ INFO : slf4j-jul transitively enabled
|
||||||
INFO : logging-jul initialized in ${jetty.base}/start.d/logging-jul.ini
|
INFO : logging-jul initialized in ${jetty.base}/start.d/logging-jul.ini
|
||||||
INFO : resources transitively enabled
|
INFO : resources transitively enabled
|
||||||
MKDIR : ${jetty.base}/etc
|
MKDIR : ${jetty.base}/etc
|
||||||
COPY : ${jetty.home}/modules/jul-impl/java-util-logging.properties to ${jetty.base}/etc/java-util-logging.properties
|
COPY : ${jetty.home}/modules/jul-impl/etc/java-util-logging.properties to ${jetty.base}/etc/java-util-logging.properties
|
||||||
MKDIR : ${jetty.base}/logs
|
|
||||||
MKDIR : ${jetty.base}/lib/slf4j
|
MKDIR : ${jetty.base}/lib/slf4j
|
||||||
DOWNLOAD: http://central.maven.org/maven2/org/slf4j/slf4j-api/1.7.21/slf4j-api-1.7.21.jar to ${jetty.base}/lib/slf4j/slf4j-api-1.7.21.jar
|
DOWNLD: http://central.maven.org/maven2/org/slf4j/slf4j-api/1.7.21/slf4j-api-1.7.21.jar to ${jetty.base}/lib/slf4j/slf4j-api-1.7.21.jar
|
||||||
DOWNLOAD: http://central.maven.org/maven2/org/slf4j/slf4j-jdk14/1.7.21/slf4j-jdk14-1.7.21.jar to ${jetty.base}/lib/slf4j/slf4j-jdk14-1.7.21.jar
|
DOWNLD: http://central.maven.org/maven2/org/slf4j/slf4j-jdk14/1.7.21/slf4j-jdk14-1.7.21.jar to ${jetty.base}/lib/slf4j/slf4j-jdk14-1.7.21.jar
|
||||||
MKDIR : ${jetty.base}/resources
|
MKDIR : ${jetty.base}/resources
|
||||||
INFO : Base directory was modified
|
INFO : Base directory was modified
|
||||||
|
|
||||||
|
@ -452,76 +451,50 @@ INFO : Base directory was modified
|
||||||
│ └── slf4j
|
│ └── slf4j
|
||||||
│ ├── slf4j-api-1.7.21.jar
|
│ ├── slf4j-api-1.7.21.jar
|
||||||
│ └── slf4j-jdk14-1.7.21.jar
|
│ └── slf4j-jdk14-1.7.21.jar
|
||||||
├── logs
|
|
||||||
├── resources
|
├── resources
|
||||||
└── start.d
|
└── start.d
|
||||||
└── logging-jul.ini
|
└── logging-jul.ini
|
||||||
....
|
....
|
||||||
|
|
||||||
[[example-logging-java-commons-logging]]
|
Jetty is now configured to log using the JUL framework.
|
||||||
==== Logging with Java Commons Logging
|
A standard JUL properties file is located in `${jetty.base}/etc/java-util-logging.properties`.
|
||||||
Jetty provides support of the Java Commons Logging (jcl) through the `logging-jcl` module, using Slf4j as a binding.
|
|
||||||
This is enabled by activating the `logging-jcl` module.
|
==== Capturing Console Output
|
||||||
By default, log files will be stored in `${jetty.base}/logs`.
|
|
||||||
|
By default, enabling the above modules will output log information to the console.
|
||||||
|
Included in the distribution is the `console-capture` module, which can be used in lieu of additional configuration to the selected logging module to capture this output to a `logs` directory in your `${jetty.base}`.
|
||||||
|
To enable this functionality, activate the `console-capture` module.
|
||||||
|
|
||||||
[source, screen, subs="{sub-order}"]
|
[source, screen, subs="{sub-order}"]
|
||||||
....
|
....
|
||||||
[my-base]$ java -jar ../start.jar --add-to-start=logging-jcl
|
[my-base]$ java -jar ../start.jar --add-to-start=console-capture
|
||||||
|
INFO : console-capture initialized in ${jetty.base}/start.d/console-capture.ini
|
||||||
ALERT: There are enabled module(s) with licenses.
|
MKDIR : ${jetty.base}/logs
|
||||||
The following 2 module(s):
|
INFO : Base directory was modified
|
||||||
+ contains software not provided by the Eclipse Foundation!
|
|
||||||
+ contains software not covered by the Eclipse Public License!
|
|
||||||
+ has not been audited for compliance with its license
|
|
||||||
|
|
||||||
Module: jcl-impl
|
|
||||||
+ Log4j is released under the Apache 2.0 license.
|
|
||||||
+ http://www.apache.org/licenses/LICENSE-2.0.html
|
|
||||||
|
|
||||||
Module: slf4j-api
|
|
||||||
+ SLF4J is distributed under the MIT License.
|
|
||||||
+ Copyright (c) 2004-2013 QOS.ch
|
|
||||||
+ All rights reserved.
|
|
||||||
+ Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
+ a copy of this software and associated documentation files (the
|
|
||||||
+ "Software"), to deal in the Software without restriction, including
|
|
||||||
+ without limitation the rights to use, copy, modify, merge, publish,
|
|
||||||
+ distribute, sublicense, and/or sell copies of the Software, and to
|
|
||||||
+ permit persons to whom the Software is furnished to do so, subject to
|
|
||||||
+ the following conditions:
|
|
||||||
+ The above copyright notice and this permission notice shall be
|
|
||||||
+ included in all copies or substantial portions of the Software.
|
|
||||||
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
||||||
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
|
||||||
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
|
||||||
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
|
|
||||||
Proceed (y/N)? y
|
|
||||||
INFO : slf4j-api transitively enabled
|
|
||||||
INFO : jcl-impl transitively enabled
|
|
||||||
INFO : resources transitively enabled
|
|
||||||
INFO : slf4j-jcl transitively enabled
|
|
||||||
INFO : logging-jcl initialized in ${jetty.base}/start.d/logging-jcl.ini
|
|
||||||
DOWNLOAD: http://central.maven.org/maven2/org/slf4j/slf4j-api/1.7.21/slf4j-api-1.7.21.jar to ${jetty.base}/lib/slf4j/slf4j-api-1.7.21.jar
|
|
||||||
DOWNLOAD: http://central.maven.org/maven2/commons-logging/commons-logging/1.1.3/commons-logging-1.1.3.jar to ${jetty.base}/lib/jcl/commons-logging-1.1.3.jar
|
|
||||||
MKDIR: ${jetty.base}/logs
|
|
||||||
DOWNLOAD: http://central.maven.org/maven2/org/slf4j/slf4j-jcl/1.7.21/slf4j-jcl-1.7.21.jar to ${jetty.base}/lib/slf4j/slf4j-jcl-1.7.21.jar
|
|
||||||
INFO : Base directory was modified
|
|
||||||
|
|
||||||
[my-base]$ tree
|
[my-base]$ tree
|
||||||
.
|
.
|
||||||
├── lib
|
|
||||||
│ ├── jcl
|
|
||||||
│ │ └── commons-logging-1.1.3.jar
|
|
||||||
│ └── slf4j
|
|
||||||
│ ├── slf4j-api-1.7.21.jar
|
|
||||||
│ └── slf4j-jcl-1.7.21.jar
|
|
||||||
├── logs
|
├── logs
|
||||||
├── resources
|
|
||||||
│ └── commons-logging.properties
|
|
||||||
└── start.d
|
└── start.d
|
||||||
└── logging-jcl.ini
|
└── console-capture.ini
|
||||||
|
....
|
||||||
|
|
||||||
|
As an example, here is the output from Logback before using the `console-capture` module:
|
||||||
|
|
||||||
|
[source, screen, subs="{sub-order}"]
|
||||||
|
....
|
||||||
|
[my-base]$ java -jar ../start.jar
|
||||||
|
419 [main] INFO org.eclipse.jetty.util.log - Logging initialized @508ms to org.eclipse.jetty.util.log.Slf4jLog
|
||||||
|
540 [main] INFO org.eclipse.jetty.server.Server - jetty-9.4.0-SNAPSHOT
|
||||||
|
575 [main] INFO o.e.jetty.server.AbstractConnector - Started ServerConnector@3c0ecd4b{HTTP/1.1,[http/1.1]}{0.0.0.0:8080}
|
||||||
|
575 [main] INFO org.eclipse.jetty.server.Server - Started @668ms
|
||||||
|
....
|
||||||
|
|
||||||
|
After enabling `console-capture`, the output is as follows:
|
||||||
|
|
||||||
|
[source, screen, subs="{sub-order}"]
|
||||||
|
....
|
||||||
|
[my-base]$ java -jar ../start.jar
|
||||||
|
151 [main] INFO org.eclipse.jetty.util.log - Logging initialized @238ms to org.eclipse.jetty.util.log.Slf4jLog
|
||||||
|
196 [main] INFO org.eclipse.jetty.util.log - Console stderr/stdout captured to /installs/jetty-distribution/mybase/logs/2016_10_21.jetty.log
|
||||||
....
|
....
|
||||||
|
|
|
@ -23,21 +23,39 @@
|
||||||
If you do nothing to configure a separate logging framework, Jetty will default to using an internal `org.eclipse.jetty.util.log.StdErrLog` implementation.
|
If you do nothing to configure a separate logging framework, Jetty will default to using an internal `org.eclipse.jetty.util.log.StdErrLog` implementation.
|
||||||
This will output all logging events to STDERR (aka `System.err`).
|
This will output all logging events to STDERR (aka `System.err`).
|
||||||
|
|
||||||
Simply use Jetty and `StdErrLog` based logging is output to the console.
|
Simply use Jetty and `StdErrLog`-based logging is output to the console.
|
||||||
|
|
||||||
Included in the Jetty distribution is a logging module that is capable of performing simple capturing of all STDOUT (`System.out`) and STDERR (`System.err`) output to a file that is rotated daily.
|
Included in the Jetty distribution is a logging module named `console-capture` that is capable of performing simple capturing of all STDOUT (`System.out`) and STDERR (`System.err`) output to a file that is rotated daily.
|
||||||
|
|
||||||
To enable on this feature via the command line:
|
To enable this feature, simply activate the `console-capture` module on the command line:
|
||||||
|
|
||||||
|
[source, screen, subs="{sub-order}"]
|
||||||
|
....
|
||||||
|
[my-base]$ java -jar ../start.jar --add-to-start=console-capture
|
||||||
|
INFO : console-capture initialized in ${jetty.base}/start.d/console-capture.ini
|
||||||
|
MKDIR : ${jetty.base}/logs
|
||||||
|
INFO : Base directory was modified
|
||||||
|
|
||||||
|
[my-base]$ tree
|
||||||
|
.
|
||||||
|
├── logs
|
||||||
|
└── start.d
|
||||||
|
└── console-capture.ini
|
||||||
|
....
|
||||||
|
|
||||||
|
The default configuration for logging output will create a file `${jetty.base}/logs/yyyy_mm_dd.stderrout.log` which allows configuration of the output directory by setting the `jetty.logs` property.
|
||||||
|
|
||||||
|
Just enabling the `console-capture` will simply output the values of STDERR and STDOUT to a log file.
|
||||||
|
To customize the log further, a module named `logging-jetty` is available to provides a default properties file to configure.
|
||||||
|
As with `console-capture`, you activate the `logging-jetty` on the command line.
|
||||||
|
|
||||||
[source, screen, subs="{sub-order}"]
|
[source, screen, subs="{sub-order}"]
|
||||||
....
|
....
|
||||||
[my-base]$ java -jar ../start.jar --add-to-start=logging-jetty
|
[my-base]$ java -jar ../start.jar --add-to-start=logging-jetty
|
||||||
INFO : logging-jetty initialized in ${jetty.base}/start.d/logging-jetty.ini
|
INFO : logging-jetty initialized in ${jetty.base}/start.d/logging-jetty.ini
|
||||||
INFO : console-capture transitively enabled, ini template available with --add-to-start=console-capture
|
|
||||||
INFO : resources transitively enabled
|
INFO : resources transitively enabled
|
||||||
MKDIR : ${jetty.base}/resources
|
MKDIR : ${jetty.base}/resources
|
||||||
COPY : ${jetty.home}/modules/logging-jetty/jetty-logging.properties to ${jetty.base}/resources/jetty-logging.properties
|
COPY : ${jetty.home}/modules/logging-jetty/resources/jetty-logging.properties to ${jetty.base}/resources/jetty-logging.properties
|
||||||
MKDIR : ${jetty.base}/logs
|
|
||||||
INFO : Base directory was modified
|
INFO : Base directory was modified
|
||||||
|
|
||||||
[my-base]$ tree
|
[my-base]$ tree
|
||||||
|
@ -46,26 +64,31 @@ INFO : Base directory was modified
|
||||||
├── resources
|
├── resources
|
||||||
│ └── jetty-logging.properties
|
│ └── jetty-logging.properties
|
||||||
└── start.d
|
└── start.d
|
||||||
|
├── console-capture.ini
|
||||||
└── logging-jetty.ini
|
└── logging-jetty.ini
|
||||||
....
|
....
|
||||||
|
|
||||||
The default configuration for logging output will create a file `${jetty.base}/logs/yyyy_mm_dd.stderrout.log` which allows configuration of the output directory by setting the `jetty.logs` property.
|
Once activated, you can find the properties file at `${jetty.base}/resources/jetty-logging.properties`.
|
||||||
|
By default, the following parameters are defined.
|
||||||
For more advanced logging configurations, please consider use of a separate logging library.
|
To change them, un-comment the line and substitute your naming scheme and configuration choices.
|
||||||
|
|
||||||
The recommended way to configure `StdErrLog` is to create a `${jetty.base}/resources/jetty-logging.properties` file, specify the log implementation to `StdErrLog` and then setup logging levels.
|
|
||||||
|
|
||||||
[source, properties, subs="{sub-order}"]
|
[source, properties, subs="{sub-order}"]
|
||||||
....
|
....
|
||||||
# Configure Jetty for StdErrLog Logging
|
## Force jetty logging implementation
|
||||||
org.eclipse.jetty.util.log.class=org.eclipse.jetty.util.log.StrErrLog
|
#org.eclipse.jetty.util.log.class=org.eclipse.jetty.util.log.StdErrLog
|
||||||
# Overall Logging Level is INFO
|
|
||||||
org.eclipse.jetty.LEVEL=INFO
|
## Set logging levels from: ALL, DEBUG, INFO, WARN, OFF
|
||||||
# Detail Logging for WebSocket
|
#org.eclipse.jetty.LEVEL=INFO
|
||||||
org.eclipse.jetty.websocket.LEVEL=DEBUG
|
#com.example.LEVEL=INFO
|
||||||
|
|
||||||
|
## Hide stacks traces in logs?
|
||||||
|
#com.example.STACKS=false
|
||||||
|
|
||||||
|
## Show the source file of a log location?
|
||||||
|
#com.example.SOURCE=false
|
||||||
....
|
....
|
||||||
|
|
||||||
There are a number of properties that can be defined in the configuration that will affect the behavior of `StdErrLog`.
|
There are a number of properties that can be defined in the configuration that will affect the behavior of StdErr logging with `console-capture`.
|
||||||
|
|
||||||
`<name>.LEVEL=<level>`::
|
`<name>.LEVEL=<level>`::
|
||||||
Sets the logging level for all loggers within the `name` specified to the level, which can be (in increasing order of restriction) `ALL`, `DEBUG`, `INFO`, `WARN`, `OFF`.
|
Sets the logging level for all loggers within the `name` specified to the level, which can be (in increasing order of restriction) `ALL`, `DEBUG`, `INFO`, `WARN`, `OFF`.
|
||||||
|
@ -95,22 +118,20 @@ There are a number of properties that can be defined in the configuration that w
|
||||||
+
|
+
|
||||||
[source, screen, subs="{sub-order}"]
|
[source, screen, subs="{sub-order}"]
|
||||||
....
|
....
|
||||||
2014-06-03 14:36:16.013:INFO:oejs.Server:main: jetty-9.2.0.v20140526
|
2016-10-21 15:31:01.248:INFO::main: Logging initialized @332ms to org.eclipse.jetty.util.log.StdErrLog
|
||||||
2014-06-03 14:36:16.028:INFO:oejdp.ScanningAppProvider:main: Deployment monitor [file:/opt/jetty/demo-base/webapps/] at interval 1
|
2016-10-21 15:31:01.370:INFO:oejs.Server:main: jetty-9.4.0-SNAPSHOT
|
||||||
2014-06-03 14:36:16.051:INFO:oejsh.ContextHandler:main: Started o.e.j.s.h.MovedContextHandler@7d256e50{/oldContextPath,null,AVAILABLE}
|
2016-10-21 15:31:01.400:INFO:oejs.AbstractConnector:main: Started ServerConnector@2c330fbc{HTTP/1.1,[http/1.1]}{0.0.0.0:8080}
|
||||||
2014-06-03 14:36:17.880:INFO:oejs.ServerConnector:main: Started ServerConnector@34f2d11a{HTTP/1.1}{0.0.0.0:8080}
|
2016-10-21 15:31:01.400:INFO:oejs.Server:main: Started @485ms
|
||||||
2014-06-03 14:36:17.888:INFO:oejs.Server:main: Started @257ms
|
|
||||||
....
|
....
|
||||||
+
|
+
|
||||||
* Example when set to true:
|
* Example when set to true:
|
||||||
+
|
+
|
||||||
[source, screen, subs="{sub-order}"]
|
[source, screen, subs="{sub-order}"]
|
||||||
....
|
....
|
||||||
2014-06-03 14:38:19.019:INFO:org.eclipse.jetty.server.Server:main: jetty-9.2.0.v20140526
|
2016-10-21 15:31:35.020:INFO::main: Logging initialized @340ms to org.eclipse.jetty.util.log.StdErrLog
|
||||||
2014-06-03 14:38:19.032:INFO:org.eclipse.jetty.deploy.providers.ScanningAppProvider:main: Deployment monitor [file:/opt/jetty/demo-base/webapps/] at interval 1
|
2016-10-21 15:31:35.144:INFO:org.eclipse.jetty.server.Server:main: jetty-9.4.0-SNAPSHOT
|
||||||
2014-06-03 14:38:19.054:INFO:org.eclipse.jetty.server.handler.ContextHandler:main: Started o.e.j.s.h.MovedContextHandler@246d8660{/oldContextPath,null,AVAILABLE}
|
2016-10-21 15:31:35.174:INFO:org.eclipse.jetty.server.AbstractConnector:main: Started ServerConnector@edf4efb{HTTP/1.1,[http/1.1]}{0.0.0.0:8080}
|
||||||
2014-06-03 14:38:20.715:INFO:org.eclipse.jetty.server.ServerConnector:main: Started ServerConnector@59f625be{HTTP/1.1}{0.0.0.0:8080}
|
2016-10-21 15:31:35.175:INFO:org.eclipse.jetty.server.Server:main: Started @495ms
|
||||||
2014-06-03 14:38:20.723:INFO:org.eclipse.jetty.server.Server:main: Started @243ms
|
|
||||||
....
|
....
|
||||||
|
|
||||||
[[deprecated-parameters]]
|
[[deprecated-parameters]]
|
||||||
|
|
|
@ -15,9 +15,9 @@
|
||||||
// ========================================================================
|
// ========================================================================
|
||||||
|
|
||||||
[[example-logging-logback-centralized]]
|
[[example-logging-logback-centralized]]
|
||||||
=== Example: Centralized Logging with Logback
|
=== Centralized Logging using Logback
|
||||||
|
|
||||||
The term _Centralized Logging_ refers to a forced logging configuration for the Jetty Server and all web applications that are deployed on the server.
|
The term _Centralized Logging_ refers to a forced logging configuration for the Jetty Server and all web applications that are deployed on the server.
|
||||||
It routes all logging events from the web applications to a single configuration on the Server side.
|
It routes all logging events from the web applications to a single configuration on the Server side.
|
||||||
|
|
||||||
The example below shows how to accomplish this with Jetty and Slf4j, using `Logback` to manage the final writing of logs to disk.
|
The example below shows how to accomplish this with Jetty and Slf4j, using `Logback` to manage the final writing of logs to disk.
|
||||||
|
@ -30,7 +30,7 @@ ____
|
||||||
|
|
||||||
This configuration is essentially the multiple logger configuration with added configuration to the deployers to force a `WebAppClassLoader` change to use the server classpath over the webapps classpath for the logger specific classes.
|
This configuration is essentially the multiple logger configuration with added configuration to the deployers to force a `WebAppClassLoader` change to use the server classpath over the webapps classpath for the logger specific classes.
|
||||||
|
|
||||||
The technique used by this configuration is to provide an link:{JDURL}org/eclipse/jetty/deploy/AppLifeCycle.Binding.html[AppLifeCycle.Binding] against the link:{JDURL}/org/eclipse/jetty/deploy/AppLifeCycle.html[`"deploying"`node] that modifies the link:{JDURL}/org/eclipse/jetty/webapp/WebAppContext.html#addSystemClass(java.lang.String)[WebAppContext.addSystemClass(String)] for the common logging classes.
|
The technique used by this configuration is to provide an link:{JDURL}org/eclipse/jetty/deploy/AppLifeCycle.Binding.html[AppLifeCycle.Binding] against the link:{JDURL}/org/eclipse/jetty/deploy/AppLifeCycle.html[`"deploying"`node] that modifies the link:{JDURL}/org/eclipse/jetty/webapp/WebAppContext.html#addSystemClass(java.lang.String)[WebAppContext.addSystemClass(String)] for the common logging classes.
|
||||||
See https://github.com/jetty-project/jetty-webapp-logging/blob/master/src/main/java/org/eclipse/jetty/webapp/logging/CentralizedWebAppLoggingBinding.java[org.eclipse.jetty.logging.CentralizedWebAppLoggingBinding] for actual implementation.
|
See https://github.com/jetty-project/jetty-webapp-logging/blob/master/src/main/java/org/eclipse/jetty/webapp/logging/CentralizedWebAppLoggingBinding.java[org.eclipse.jetty.logging.CentralizedWebAppLoggingBinding] for actual implementation.
|
||||||
|
|
||||||
A convenient replacement `logging` module has been created to bootstrap your `${jetty.base}` directory for capturing all Jetty server logging from multiple logging frameworks into a single logging output file managed by Logback.
|
A convenient replacement `logging` module has been created to bootstrap your `${jetty.base}` directory for capturing all Jetty server logging from multiple logging frameworks into a single logging output file managed by Logback.
|
||||||
|
|
Loading…
Reference in New Issue