Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Ported Access Log documentation to 4.x #5054

Merged
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
92 changes: 92 additions & 0 deletions docs/includes/server/access-log-config-common.adoc
Original file line number Diff line number Diff line change
@@ -0,0 +1,92 @@
///////////////////////////////////////////////////////////////////////////////

Copyright (c) 2022 Oracle and/or its affiliates.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

///////////////////////////////////////////////////////////////////////////////

ifndef::rootdir[:rootdir: {docdir}/../..]
:description: Access Log Config
:keywords: helidon, webserver, access, log


== Configuration Options

The following configuration options can be defined:

[cols="2,2,2,5", role="flex, sm10"]
|===
|Config key |Default value |Builder method |Description

|`enabled` |`true` |`enabled(boolean)` |When this option is set to `false`, access logging will be disabled
|`logger-name` |`io.helidon.webserver.AccessLog` |`loggerName(String)` |Name of the logger to use when writing log entries
|`format` |`helidon` |`helidonLogFormat()`, `commonLogFormat()`, `add(AccessLogEntry entry)` |Configuration of access log output,
when `helidon` is defined, the Helidon log format (see below) is used.
Can be configured to explicitly define log entries (see below as well)
|`exclude-paths`|N/A|`excludePaths(List<String>)` | List of path patterns to exclude from access log. Path pattern syntax is as
defined in `io.helidon.webserver.PathMatcher`. Can be used to exclude
paths such as `/health` or `/metrics` to avoid cluttering log.

|===

== Supported Log Formats

=== Supported Log Entries

The following log entries are supported in Helidon:

[cols="2,2,5",role="flex, sm7"]
|===
|Config format |Class (to use with builder) |Description

|%h |`HostLogEntry` |IP address of the remote host
|%l |`UserIdLogEntry` |Client identity, always undefined in Helidon
|%u |`UserLogEntry` |The username of logged-in user (when Security is used)
|%t |`TimestampLogEntry` |The current timestamp
|%r |`RequestLineLogEntry` |The request line (method, path and HTTP version)
|%s |`StatusLogEntry` |The HTTP status returned to the client
|%b |`SizeLogEntry` |The response entity size (if available)
|%D |`TimeTakenLogEntry` |The time taken in microseconds
|%T |`TimeTakenLogEntry` |The time taken in seconds
|%{`header-name`}i |`HeaderLogEntry` |Value of a header (can have multiple such specification to write
multiple headers)
|===

Currently we only support the entries defined above, with NO support for free text.

=== Helidon Log Format
When format is set to `helidon`, the format used is:

`"%h %u %t %r %s %b %D"`

The entries logged:

1. IP Address
2. Username of a logged-in user
3. Timestamp
4. Request Line
5. HTTP Status code
6. Entity size
7. Time taken (microseconds)

Access log example:

[source, listing]
----
192.168.0.104 - [18/Jun/2019:22:28:55 +0200] "GET /greet/test HTTP/1.1" 200 53
0:0:0:0:0:0:0:1 - [18/Jun/2019:22:29:00 +0200] "GET /metrics/vendor HTTP/1.1" 200 1658
0:0:0:0:0:0:0:1 jack [18/Jun/2019:22:29:07 +0200] "PUT /greet/greeting HTTP/1.1" 200 21
0:0:0:0:0:0:0:1 jill [18/Jun/2019:22:29:12 +0200] "PUT /greet/greeting HTTP/1.1" 403 0
0:0:0:0:0:0:0:1 - [18/Jun/2019:22:29:17 +0200] "PUT /greet/greeting HTTP/1.1" 401 0
----
31 changes: 31 additions & 0 deletions docs/mp/server.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -111,6 +111,37 @@ include::{rootdir}/config/io_helidon_reactive_webserver_WebServer.adoc[leveloffs

== Examples

=== Access Log

Access logging in Helidon is done by a dedicated module that can be
added to Maven and configured.

To enable Access logging add the following dependency to project's `pom.xml`:

[source,xml]
----
<dependency>
<groupId>io.helidon.microprofile</groupId>
<artifactId>helidon-microprofile-access-log</artifactId>
</dependency>
----

=== Configuring Access Log in a configuration file

Access log can be configured as follows:

[source, properties]
.Access Log configuration file
----
server.port=8080
server.host=0.0.0.0
server.access-log.format=helidon
----

All options shown above are also available programmatically when using builder.

include::{rootdir}/includes/server/access-log-config-common.adoc[leveloffset=+1]

=== Configuring TLS

Helidon MP also supports custom TLS configuration.
Expand Down
136 changes: 30 additions & 106 deletions docs/se/webserver.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -822,6 +822,16 @@ in the order it is registered with WebServer routing.
This implies that if you register it last and another `Service` or
`Handler` finishes the request, the service will not be invoked.

To enable Access logging add the following dependency to project's `pom.xml`:

[source,xml]
----
<dependency>
<groupId>io.helidon.webserver</groupId>
<artifactId>helidon-webserver-access-log</artifactId>
</dependency>
----


=== Configuring Access Log in your code

Expand Down Expand Up @@ -851,120 +861,34 @@ server:

All options shown above are also available programmatically when using builder.

=== Configuration options

The following configuration options can be defined:

[cols="2,2,2,5", role="flex, sm10"]
|===
|Config key |Default value |Builder method |Description

|`enabled` |`true` |`enabled(boolean)` |When this option is set to `false`, access logging will be disabled
|`logger-name` |`io.helidon.reactive.webserver.AccessLog` |`loggerName(String)` |Name of the logger to use when writing log entries
|`format` |`helidon` |`helidonLogFormat()`, `commonLogFormat()`, `add(AccessLogEntry entry)` |Configuration of access log output,
when `helidon` is defined, the Helidon log format (see below) is used.
Can be configured to explicitly define log entries (see below as well)
|`exclude-paths`|N/A|`excludePaths(List<String>)` | List of path patterns to exclude from access log. Path pattern syntax is as
defined in `io.helidon.reactive.webserver.PathMatcher`. Can be used to exclude
paths such as `/health` or `/metrics` to avoid cluttering log.

|===

=== Supported Log Formats
include::{rootdir}/includes/server/access-log-config-common.adoc[leveloffset=+1]

==== Supported Log Entries

The following log entries are supported in Helidon:

[cols="2,2,5",role="flex, sm7"]
|===
|Config format |Class (to use with builder) |Description

|%h |`HostLogEntry` |IP address of the remote host
|%l |`UserIdLogEntry` |Client identity, always undefined in Helidon
|%u |`UserLogEntry` |The username of logged-in user (when Security is used)
|%t |`TimestampLogEntry` |The current timestamp
|%r |`RequestLineLogEntry` |The request line (method, path and HTTP version)
|%s |`StatusLogEntry` |The HTTP status returned to the client
|%b |`SizeLogEntry` |The response entity size (if available)
|%D |`TimeTakenLogEntry` |The time taken in microseconds
|%T |`TimeTakenLogEntry` |The time taken in seconds
|%{`header-name`}i |`HeaderLogEntry` |Value of a header (can have multiple such specification to write
multiple headers)
|===

Currently we only support the entries defined above, with NO support for free text.

==== Helidon Log Format
When format is set to `helidon`, the format used is:

`"%h %u %t %r %s %b %D"`

The entries logged:

1. IP Address
2. Username of a logged-in user
3. Timestamp
4. Request Line
5. HTTP Status code
6. Entity size
7. Time taken (microseconds)

Access log example:

[source, listing]
----
192.168.0.104 - [18/Jun/2019:22:28:55 +0200] "GET /greet/test HTTP/1.1" 200 53
0:0:0:0:0:0:0:1 - [18/Jun/2019:22:29:00 +0200] "GET /metrics/vendor HTTP/1.1" 200 1658
0:0:0:0:0:0:0:1 jack [18/Jun/2019:22:29:07 +0200] "PUT /greet/greeting HTTP/1.1" 200 21
0:0:0:0:0:0:0:1 jill [18/Jun/2019:22:29:12 +0200] "PUT /greet/greeting HTTP/1.1" 403 0
0:0:0:0:0:0:0:1 - [18/Jun/2019:22:29:17 +0200] "PUT /greet/greeting HTTP/1.1" 401 0
----
== TLS Configuration

==== Common Log Format
When format is set to `common`, the format used is:

`"%h %l %u %t %r %s %b"`

The entries logged:

1. IP Address
2. Client identity
3. Username of a logged-in user
4. Timestamp
5. Request Line
6. HTTP Status code
7. Entity size

Access log example:

[source, listing]
----
192.168.0.104 - - [18/Jun/2019:22:28:55 +0200] "GET /greet/test HTTP/1.1" 200 53
0:0:0:0:0:0:0:1 - - [18/Jun/2019:22:29:00 +0200] "GET /metrics/vendor HTTP/1.1" 200 1658
0:0:0:0:0:0:0:1 - jack [18/Jun/2019:22:29:07 +0200] "PUT /greet/greeting HTTP/1.1" 200 21
0:0:0:0:0:0:0:1 - jill [18/Jun/2019:22:29:12 +0200] "PUT /greet/greeting HTTP/1.1" 403 0
0:0:0:0:0:0:0:1 - - [18/Jun/2019:22:29:17 +0200] "PUT /greet/greeting HTTP/1.1" 401 0
----

=== Configuring Access Log with Java util logging
Configure TLS either programmatically, or by the Helidon configuration framework.

To support a separate file for Access log entries, Helidon provides a custom
log handler, that extends the `FileHandler`.
=== Configuring TLS in your code

To log to a file `access.log` with appending records after restart, you can use the
following configuration in `logging.properties`:
To configure TLS in WebServer programmatically create your keystore configuration and pass it to the WebServer builder.

[source, properties]
.Logging configuration file
[source,java]
----
io.helidon.reactive.webserver.accesslog.AccessLogHandler.level=INFO
io.helidon.reactive.webserver.accesslog.AccessLogHandler.pattern=access.log
io.helidon.reactive.webserver.accesslog.AccessLogHandler.append=true
KeyConfig keyConfig = KeyConfig.keystoreBuilder()
//Whether this keystore is also trust store
.trustStore()
//Keystore location/name
.keystore(Resource.create("keystore.p12"))
//Password to the keystore
.keystorePassphrase("password")
.build();

io.helidon.reactive.webserver.AccessLog.level=INFO
io.helidon.reactive.webserver.AccessLog.useParentHandlers=false
io.helidon.reactive.webserver.AccessLog.handlers=io.helidon.reactive.webserver.accesslog.AccessLogHandler
WebServer.builder()
.tls(WebServerTls.builder()
.trust(keyConfig)
.privateKey(keyConfig)
.build())
.build();
----

== TLS configuration
Expand Down