だから私はLogbackに本当に慣れていないので、何かを実装する方法について質問があります。
2 つのアペンダーがあるとします。アペンダー "a" には 1 または 2 のみのマーカーを受け入れさせたいのですが、アペンダー "b" には 1 または 3 のみのマーカーを受け入れさせたいとします。どのタイプのフィルターを使用すればよいでしょうか? これには何かありますか?
1 つのオプションは、Event Evaluatorを使用することです。独自のフィルターを作成することもできます。実際、組み込みの例は、(ほとんど)あなたが望むことを行います。
以下のフィルターは、探しているものに近いはずです。
import ch.qos.logback.classic.spi.LoggingEvent;
import ch.qos.logback.core.filter.Filter;
import ch.qos.logback.core.spi.FilterReply;
import org.slf4j.Marker;
import org.slf4j.MarkerFactory;
import java.util.ArrayList;
import java.util.List;
public class OneTwoMarkerFilter extends Filter
{
private final List<Marker> markers = new ArrayList<Marker>();
public MarkerFilter()
{
markers.add(MarkerFactory.getMarker("1"));
markers.add(MarkerFactory.getMarker("2"));
}
@Override
public FilterReply decide(Object event)
{
if (!isStarted())
{
return FilterReply.NEUTRAL;
}
LoggingEvent logEvent = (LoggingEvent) event;
Marker eventMarker = logEvent.getMarker();
if (eventMarker != null && markers.contains(eventMarker))
{
return FilterReply.NEUTRAL;
}
else
{
return FilterReply.DENY;
}
}
}
私はこれをテストしていないことに注意してください。
ユリアの答えは素晴らしいです!
そして、 AbstractMatcherFilter を拡張することは、より良い始まりかもしれないと思います。
public class MarkerFilter extends AbstractMatcherFilter<ILoggingEvent> {
private Marker markerToMatch = null;
@Override
public void start() {
if (null != this.markerToMatch)
super.start();
else
addError("!!! no marker yet !!!");
}
@Override
public FilterReply decide(ILoggingEvent event) {
Marker marker = event.getMarker();
if (!isStarted())
return FilterReply.NEUTRAL;
if (null == marker)
return onMismatch;
if (markerToMatch.contains(marker))
return onMatch;
return onMismatch;
}
public void setMarker(String markerStr) {
if(null != markerStr)
markerToMatch = MarkerFactory.getMarker(markerStr);
}
}
<filter class="your.pkg.MarkerFilter">
<marker>YOUR_MARKER</marker>
<onMatch>ACCEPT</onMatch>
<onMismatch>DENY</onMismatch>
</filter>
AbstractMatcherFilter で決定をオーバーライドし、markerToMatch.contains(marker) をロジックに置き換えて、一致する (つまり、受け入れられる) マーカーを決定する必要があります。
利用方法:
log.info(MarkerFacotry.getMarker("YOUR_MARKER"), "---msg---");