All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.slf4j.impl.LogbackMDCAdapter Maven / Gradle / Ivy

/**
 * Logback: the reliable, generic, fast and flexible logging framework.
 * Copyright (C) 1999-2009, QOS.ch. All rights reserved.
 *
 * This program and the accompanying materials are dual-licensed under
 * either the terms of the Eclipse Public License v1.0 as published by
 * the Eclipse Foundation
 *
 *   or (per the licensee's choosing)
 *
 * under the terms of the GNU Lesser General Public License version 2.1
 * as published by the Free Software Foundation.
 */
package org.slf4j.impl;

import java.util.HashMap;
import java.util.Map;
import java.util.Set;

import org.slf4j.spi.MDCAdapter;

/**
 * A Mapped Diagnostic Context, or MDC in short, is an instrument
 * for distinguishing interleaved log output from different sources. Log output
 * is typically interleaved when a server handles multiple clients
 * near-simultaneously. 

The MDC is managed on a per thread basis. * A child thread automatically inherits a copy of the mapped * diagnostic context of its parent.

* * For more information about MDC, please refer to the online manual at * http://logback.qos.ch/manual/mdc.html * * @author Ceki Gülcü */ public class LogbackMDCAdapter implements MDCAdapter { // final CopyOnInheritThreadLocal copyOnInheritThreadLocal = new // CopyOnInheritThreadLocal(); final CopyOnInheritThreadLocal copyOnInheritThreadLocal = new CopyOnInheritThreadLocal(); LogbackMDCAdapter() { } /** * Put a context value (the val parameter) as identified with * the key parameter into the current thread's context map. * Note that contrary to log4j, the val parameter can be null. * *

If the current thread does not have a context map it is created as a * side effect of this call. * *

Each time a value is added, a new instance of the map is created. This * is to be certain that the serialization process will operate on the updated * map and not send a reference to the old map, thus not allowing the remote * logback component to see the latest changes. * * @throws IllegalArgumentException * in case the "key" parameter is null */ public void put(String key, String val) throws IllegalArgumentException { if (key == null) { throw new IllegalArgumentException("key cannot be null"); } HashMap oldMap = copyOnInheritThreadLocal.get(); HashMap newMap = new HashMap(); if (oldMap != null) { newMap.putAll(oldMap); } // the newMap replaces the old one for serialisation's sake copyOnInheritThreadLocal.set(newMap); newMap.put(key, val); } /** * Get the context identified by the key parameter. * *

This method has no side effects. */ public String get(String key) { HashMap hashMap = copyOnInheritThreadLocal.get(); if ((hashMap != null) && (key != null)) { return hashMap.get(key); } else { return null; } } /** * Remove the the context identified by the key parameter. * *

Each time a value is removed, a new instance of the map is created. * This is to be certain that the serialization process will operate on the * updated map and not send a reference to the old map, thus not allowing the * remote logback component to see the latest changes. */ public void remove(String key) { HashMap oldMap = copyOnInheritThreadLocal.get(); HashMap newMap = new HashMap(); if (oldMap != null) { newMap.putAll(oldMap); } // the newMap replaces the old one for serialisation's sake copyOnInheritThreadLocal.set(newMap); newMap.remove(key); } /** * Clear all entries in the MDC. */ public void clear() { HashMap hashMap = copyOnInheritThreadLocal.get(); if (hashMap != null) { hashMap.clear(); copyOnInheritThreadLocal.remove(); } } /** * Get the current thread's MDC as a map. This method is intended to be used * internally. */ public Map getPropertyMap() { return copyOnInheritThreadLocal.get(); } /** * Return a copy of the current thread's context map. Returned value may be * null. */ public Map getCopyOfContextMap() { HashMap hashMap = copyOnInheritThreadLocal.get(); if (hashMap == null) { return null; } else { return new HashMap(hashMap); } } /** * Returns the keys in the MDC as a {@link Set}. The returned value can be * null. */ public Set getKeys() { HashMap hashMap = copyOnInheritThreadLocal.get(); if (hashMap != null) { return hashMap.keySet(); } else { return null; } } @SuppressWarnings("unchecked") public void setContextMap(Map contextMap) { HashMap oldMap = copyOnInheritThreadLocal.get(); HashMap newMap = new HashMap(); newMap.putAll(contextMap); // the newMap replaces the old one for serialisation's sake copyOnInheritThreadLocal.set(newMap); // hints for the garbage collector if (oldMap != null) { oldMap.clear(); oldMap = null; } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy