JGroupsCustomLoggerFactory:
import org.jgroups.logging.CustomLogFactory;
import org.jgroups.logging.Log;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class JGroupsCustomLoggerFactory implements CustomLogFactory {
@Override
@SuppressWarnings("rawtypes")
public Log getLog(Class clazz) {
Logger logger = LoggerFactory.getLogger(LogUtils.formatClassName(clazz));
return new JGroupsCustomLog(logger);
}
@Override
public Log getLog(String category) {
Logger logger = LoggerFactory.getLogger(category);
return new JGroupsCustomLog(logger);
}
}
JGroupsCustomLog.java:
import org.jgroups.logging.Log;
import org.slf4j.Logger;
import org.slf4j.Marker;
public class JGroupsCustomLog implements Log {
private Logger logger;
public JGroupsCustomLog(Logger logger) {
this.logger = logger;
}
@Override
public boolean isFatalEnabled() {
return false;
}
@Override
public boolean isErrorEnabled() {
return logger.isErrorEnabled();
}
@Override
public boolean isWarnEnabled() {
return logger.isErrorEnabled();
}
@Override
public boolean isInfoEnabled() {
return logger.isInfoEnabled();
}
@Override
public boolean isDebugEnabled() {
return logger.isDebugEnabled();
}
@Override
public boolean isTraceEnabled() {
return logger.isTraceEnabled();
}
public String getName() {
return logger.getName();
}
public void trace(String msg) {
logger.trace(msg);
}
public void trace(String format, Object arg) {
logger.trace(format, arg);
}
public void trace(String format, Object arg1, Object arg2) {
logger.trace(format, arg1, arg2);
}
public void trace(String format, Object[] argArray) {
logger.trace(format, argArray);
}
public void trace(String msg, Throwable t) {
logger.trace(msg, t);
}
public boolean isTraceEnabled(Marker marker) {
return logger.isTraceEnabled(marker);
}
public void trace(Marker marker, String msg) {
logger.trace(marker, msg);
}
public void trace(Marker marker, String format, Object arg) {
logger.trace(marker, format, arg);
}
public void trace(Marker marker, String format, Object arg1, Object arg2) {
logger.trace(marker, format, arg1, arg2);
}
public void trace(Marker marker, String format, Object[] argArray) {
logger.trace(marker, format, argArray);
}
public void trace(Marker marker, String msg, Throwable t) {
logger.trace(marker, msg, t);
}
public void debug(String msg) {
logger.debug(msg);
}
public void debug(String format, Object arg) {
logger.debug(format, arg);
}
public void debug(String format, Object arg1, Object arg2) {
logger.debug(format, arg1, arg2);
}
public void debug(String format, Object[] argArray) {
logger.debug(format, argArray);
}
public void debug(String msg, Throwable t) {
logger.debug(msg, t);
}
public boolean isDebugEnabled(Marker marker) {
return logger.isDebugEnabled(marker);
}
public void debug(Marker marker, String msg) {
logger.debug(marker, msg);
}
public void debug(Marker marker, String format, Object arg) {
logger.debug(marker, format, arg);
}
public void debug(Marker marker, String format, Object arg1, Object arg2) {
logger.debug(marker, format, arg1, arg2);
}
public void debug(Marker marker, String format, Object[] argArray) {
logger.debug(marker, format, argArray);
}
public void debug(Marker marker, String msg, Throwable t) {
logger.debug(marker, msg, t);
}
public void info(String msg) {
logger.info(msg);
}
public void info(String format, Object arg) {
logger.info(format, arg);
}
public void info(String format, Object arg1, Object arg2) {
logger.info(format, arg1, arg2);
}
public void info(String format, Object[] argArray) {
logger.info(format, argArray);
}
public void info(String msg, Throwable t) {
logger.info(msg, t);
}
public boolean isInfoEnabled(Marker marker) {
return logger.isInfoEnabled(marker);
}
public void info(Marker marker, String msg) {
logger.info(marker, msg);
}
public void info(Marker marker, String format, Object arg) {
logger.info(marker, format, arg);
}
public void info(Marker marker, String format, Object arg1, Object arg2) {
logger.info(marker, format, arg1, arg2);
}
public void info(Marker marker, String format, Object[] argArray) {
logger.info(marker, format, argArray);
}
public void info(Marker marker, String msg, Throwable t) {
logger.info(marker, msg, t);
}
public void warn(String msg) {
logger.warn(msg);
}
public void warn(String format, Object arg) {
logger.warn(format, arg);
}
public void warn(String format, Object[] argArray) {
logger.warn(format, argArray);
}
public void warn(String format, Object arg1, Object arg2) {
logger.warn(format, arg1, arg2);
}
public void warn(String msg, Throwable t) {
logger.warn(msg, t);
}
public boolean isWarnEnabled(Marker marker) {
return logger.isWarnEnabled(marker);
}
public void warn(Marker marker, String msg) {
logger.warn(marker, msg);
}
public void warn(Marker marker, String format, Object arg) {
logger.warn(marker, format, arg);
}
public void warn(Marker marker, String format, Object arg1, Object arg2) {
logger.warn(marker, format, arg1, arg2);
}
public void warn(Marker marker, String format, Object[] argArray) {
logger.warn(marker, format, argArray);
}
public void warn(Marker marker, String msg, Throwable t) {
logger.warn(marker, msg, t);
}
public void error(String msg) {
logger.error(msg);
}
public void error(String format, Object arg) {
logger.error(format, arg);
}
public void error(String format, Object arg1, Object arg2) {
logger.error(format, arg1, arg2);
}
public void error(String format, Object[] argArray) {
logger.error(format, argArray);
}
public void error(String msg, Throwable t) {
logger.error(msg, t);
}
public boolean isErrorEnabled(Marker marker) {
return logger.isErrorEnabled(marker);
}
public void error(Marker marker, String msg) {
logger.error(marker, msg);
}
public void error(Marker marker, String format, Object arg) {
logger.error(marker, format, arg);
}
public void error(Marker marker, String format, Object arg1, Object arg2) {
logger.error(marker, format, arg1, arg2);
}
public void error(Marker marker, String format, Object[] argArray) {
logger.error(marker, format, argArray);
}
public void error(Marker marker, String msg, Throwable t) {
logger.error(marker, msg, t);
}
@Override
public void fatal(String msg) {
logger.error(msg);
}
@Override
public void fatal(String msg, Throwable throwable) {
logger.error(msg, throwable);
}
@Override
public void trace(Object msg) {
logger.trace(msg.toString());
}
@Override
public void trace(Object msg, Throwable throwable) {
logger.trace(msg.toString(), throwable);
}
@Override
public void setLevel(String level) {
}
@Override
public String getLevel() {
return "INFO";
}
}
Just befor initialize JGroups, call:
try {
System.setProperty(Global.CUSTOM_LOG_FACTORY, "package.JGroupsCustomLoggerFactory");
jChannel = new JChannel();
jChannel.connect("channel-ver-3.0");