http://www.albahari.com/threading/part2.aspx#_Mutex
A Mutex is like a C# lock, but it can work across multiple processes.
In other words, Mutex can be computer-wideas well as application-wide.
Note:
Acquiring and releasing an uncontended Mutex takes a few microseconds — about 50 times slower than a lock.
With a Mutex class, you call the WaitOne method to lock and ReleaseMutex to unlock.
Closing or disposing a Mutex automatically releases it.
Just as with the lock statement, a Mutex can be released only from the same thread that obtained it.
A common use for a cross-process Mutex is to ensure that only one instance of a program can run at a time.
Here’s how it’s done:
class OneAtATimePlease { static void Method() { //Naming a Mutex makes it available computer-wide. //Use a name that's unique to your company and application (e.g., include your URL). using (var mutex = new Mutex(false, "oreilly.com OneAtATimeDemo")) { //Wait a few seconds if contended, in case another instance of the program is still in the process of shutting down. if (mutex.WaitOne(TimeSpan.FromSeconds(3), false) == false) { Console.WriteLine("Another app instance is running. Bye!"); return; } RunProgram(); } } static void RunProgram() { Console.WriteLine("Running. Press Enter to exit"); Console.ReadLine(); } }
Note:
If running under Terminal Services, a computer-wide Mutex is ordinarily visible only to applications in the same terminal server session.
To make it visible to all terminal server sessions, prefix its name with Global.
Mutex Class
A synchronization primitive that can also be used for interprocess synchronization.
Mutex(Boolean, String, Boolean)
Initializes a new instance of the Mutex class with a Boolean value that indicates whether the calling thread should have initial ownership of the mutex, a string that is the name of the mutex, and a Boolean value that, when the method returns, indicates whether the calling thread was granted initial ownership of the mutex.
[System.Security.SecurityCritical] public Mutex (bool initiallyOwned, string name, out bool createdNew);