在做web service 服务的时候,有多台电脑访问这个服务,每个客户端访问都会写一个记录在访问日志里,这样有可能会出现争夺共享资源的问题。
为了解决此类问题,.net 有一个Mutex 类。
功能描述:
当两个或更多线程需要同时访问一个共享资源时,系统需要使用同步机制来确保一次只有一个线程使用该资源。 Mutex 是同步基元,它只向一个线程授予对共享资源的独占访问权。 如果一个线程获取了互斥体,则要获取该互斥体的第二个线程将被挂起,直到第一个线程释放该互斥体。
代码实例:
private static Mutex muxFileWrite = new Mutex();
public void WriteRequestDataLog(string msg, string webserviceName, string functonName)
{
muxFileWrite.WaitOne();
var tempDirPath = AppDomain.CurrentDomain.BaseDirectory + "log\\" + webserviceName;
Directory.CreateDirectory(tempDirPath);
string logPath = HttpContext.Current.Server.MapPath("log\\" + webserviceName + "\\"+ functonName + DateTime.Now.ToString("yyyy-MM-dd") + ".log");
StreamWriter sw;
if (!File.Exists(logPath))
{
sw = File.CreateText(logPath);
}
else
{
sw = File.AppendText(logPath);
}
try
{
sw.WriteLine(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss: ") + "\r\n" + msg);
}
finally
{
sw.Dispose();
}
muxFileWrite.ReleaseMutex();
}