I have a service application that on startup reads an XML file and starts a thread for each entry in the XML file. Each thread creates an instance of a worker class which requires a logger to log any output to a thread specific log file.
In the services app.config I have the log4net configuration settings set to use an XML appender and the file is specified as a PatternString as shown below:
<appender name="XmlAppender" type="log4net.Appender.FileAppender">
<file type="log4net.Util.PatternString" value="D:TempLogs\%property{LogName}.log" />
<immediateFlush value="true"/>
<appendToFile value="true" />
<layout type="log4net.Layout.SimpleLayout" />
</appender>
In a thread locked method for each instance of the worker class created I get the logger using the log4net.LogManager.GetLogger("MyLogger")
method and then I set the current threads PatternStrings LogName property using ThreadContext.Properties["LogName"] = "Log name prefix"
.
All of the files are created but when the logger is called it just logs all message to one seemingly random file.
I have searched about for quite a while trying to find a solution or some answers to what I am doing wrong but I have had no luck.
Does anyone have any idea why this is happening?
See Question&Answers more detail:
os 与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…