blob: 0b9e2e4a7782aaefc2f5b0d7ee8cb0b284336103 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
// Copyright Verizon Media. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
package com.yahoo.container.logging;
import com.google.inject.Inject;
import com.yahoo.component.AbstractComponent;
import java.util.logging.Level;
import java.util.logging.Logger;
/**
* @author mortent
*/
public class FileConnectionLog extends AbstractComponent implements ConnectionLog {
private static final Logger logger = Logger.getLogger(FileConnectionLog.class.getName());
private final ConnectionLogHandler logHandler;
@Inject
public FileConnectionLog(ConnectionLogConfig config) {
logHandler = new ConnectionLogHandler(config.cluster());
}
@Override
public void log(ConnectionLogEntry connectionLogEntry) {
try {
logHandler.log(connectionLogEntry.toJson()+ '\n');
} catch (Exception e) {
logger.log(Level.WARNING, "Unable to write connection log entry for connection id " + connectionLogEntry.id(), e);
}
}
@Override
public void deconstruct() {
logHandler.shutdown();
}
}
|