LogicalThreadContext ClassApache log4net™ SDK Documentation
The log4net Logical Thread Context.
Inheritance Hierarchy

OnlineSystem Object
  log4net LogicalThreadContext

Namespace: log4net
Assembly: log4net (in log4net.dll) Version: 1.2.15.0 (1.2.15.0)
Syntax

public sealed class LogicalThreadContext
Remarks

The LogicalThreadContext provides a location for OnlineCallContext specific debugging information to be stored. The LogicalThreadContext properties override any ThreadContext or GlobalContext properties with the same name.

The Logical Thread Context has a properties map and a stack. The properties and stack can be included in the output of log messages. The PatternLayout supports selecting and outputting these properties.

The Logical Thread Context provides a diagnostic context for the current call context. This 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 Logical Thread Context is managed on a per OnlineCallContext basis.

The OnlineCallContext requires a link time OnlineSecurityPermission for the OnlineInfrastructure. If the calling code does not have this permission then this context will be disabled. It will not store any property values set on it.

Examples

Example of using the thread context properties to store a username.
LogicalThreadContext.Properties["user"] = userName;
log.Info("This log message has a LogicalThreadContext Property called 'user'");
Examples

Example of how to push a message into the context stack
using(LogicalThreadContext.Stacks["LDC"].Push("my context message"))
{
    log.Info("This log message has a LogicalThreadContext Stack message that includes 'my context message'");

} // at the end of the using block the message is automatically popped
Thread Safety

Static members of this type are safe for multi-threaded operations. Instance members of this type are safe for multi-threaded operations.
See Also