aboutsummaryrefslogtreecommitdiffstats
path: root/container-core/src/main/java/com/yahoo/container/logging/JSONAccessLog.java
diff options
context:
space:
mode:
Diffstat (limited to 'container-core/src/main/java/com/yahoo/container/logging/JSONAccessLog.java')
-rw-r--r--container-core/src/main/java/com/yahoo/container/logging/JSONAccessLog.java27
1 files changed, 27 insertions, 0 deletions
diff --git a/container-core/src/main/java/com/yahoo/container/logging/JSONAccessLog.java b/container-core/src/main/java/com/yahoo/container/logging/JSONAccessLog.java
new file mode 100644
index 00000000000..ece9d0d2c4a
--- /dev/null
+++ b/container-core/src/main/java/com/yahoo/container/logging/JSONAccessLog.java
@@ -0,0 +1,27 @@
+// Copyright 2017 Yahoo Holdings. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
+package com.yahoo.container.logging;
+
+import com.yahoo.component.AbstractComponent;
+import com.yahoo.container.core.AccessLogConfig;
+
+/**
+ * Log a message in Vespa JSON access log format.
+ *
+ * @author frodelu
+ * @author Tony Vaagenes
+ */
+public final class JSONAccessLog extends AbstractComponent implements RequestLogHandler {
+
+ private final AccessLogHandler logHandler;
+
+ public JSONAccessLog(AccessLogConfig config) {
+ logHandler = new AccessLogHandler(config.fileHandler(), new JSONFormatter());
+ }
+
+ @Override
+ public void log(RequestLogEntry entry) {
+ logHandler.log(entry);
+ }
+
+ @Override public void deconstruct() { logHandler.shutdown(); }
+}