com.plumelog.log4j2.appender.KafkaAppender Maven / Gradle / Ivy
package com.plumelog.log4j2.appender;
import com.plumelog.core.MessageAppenderFactory;
import com.plumelog.core.dto.BaseLogMessage;
import com.plumelog.core.kafka.KafkaProducerClient;
import com.plumelog.log4j2.util.LogMessageUtil;
import org.apache.logging.log4j.core.Filter;
import org.apache.logging.log4j.core.Layout;
import org.apache.logging.log4j.core.LogEvent;
import org.apache.logging.log4j.core.appender.AbstractAppender;
import org.apache.logging.log4j.core.config.plugins.Plugin;
import org.apache.logging.log4j.core.config.plugins.PluginAttribute;
import org.apache.logging.log4j.core.config.plugins.PluginElement;
import org.apache.logging.log4j.core.config.plugins.PluginFactory;
import java.io.Serializable;
@Plugin(name = "KafkaAppender", category = "Core", elementType = "appender", printObject = true)
public class KafkaAppender extends AbstractAppender {
private KafkaProducerClient kafkaClient;
private String appName;
private String kafkaHosts;
protected KafkaAppender(String name, String appName, String kafkaHosts, Filter filter, Layout extends Serializable> layout,
final boolean ignoreExceptions) {
super(name, filter, layout, ignoreExceptions);
this.appName = appName;
this.kafkaHosts = kafkaHosts;
}
@Override
public void append(LogEvent logEvent) {
if (kafkaClient == null) {
kafkaClient = KafkaProducerClient.getInstance(kafkaHosts);
}
final BaseLogMessage logMessage = LogMessageUtil.getLogMessage(this.appName, logEvent);
MessageAppenderFactory.push(logMessage, kafkaClient);
}
@PluginFactory
public static KafkaAppender createAppender(
@PluginAttribute("name") String name,
@PluginAttribute("appName") String appName,
@PluginAttribute("kafkaHosts") String kafkaHosts,
@PluginAttribute("topic") String topic,
@PluginElement("Layout") Layout extends Serializable> layout,
@PluginElement("Filter") final Filter filter) {
return new KafkaAppender(name, appName, kafkaHosts, filter, layout, true);
}
}