Douglas Anderson
Douglas Anderson

Reputation: 4690

What's the maximum number of threads in Windows Server 2003?

Does anyone know? And a bigger question is what happens when you encounter this maximum? Is this the same number with other Windows OSs such as Vista, XP etc.?

Upvotes: 32

Views: 75224

Answers (8)

Teoman shipahi
Teoman shipahi

Reputation: 23052

Default stack size is 1MB and the user-mode address space assigned to the windows process under 32 bit Windows OS is about 2 GB. that allow around 2000 thread per process (2000 * 1MB = 2GB). for 64 bit, practically, there is no such a problem .

Upvotes: 3

Saurabh D
Saurabh D

Reputation: 275

Question seems very old but like to add as can be helpfull to others as well :

This article regarding : Pushing the Limits of Windows: Processes and Threads

http://blogs.technet.com/b/markrussinovich/archive/2009/07/08/3261309.aspx

Upvotes: 1

Marco van de Voort
Marco van de Voort

Reputation: 26356

If you are stuck with an existing design that utilizes a high number of threads and needs to scale, you might also consider fibers:

http://msdn.microsoft.com/en-us/library/ms682661%28v=vs.85%29.aspx

It can save you a total redesign.

Indy considered it for Indy 10, but it never happened because the .NET adventures consumed most of the time it seems.

Upvotes: 1

ShuggyCoUk
ShuggyCoUk

Reputation: 36438

First I would advise reading this: http://blogs.msdn.com/oldnewthing/archive/2007/03/01/1775759.aspx

then http://blogs.msdn.com/oldnewthing/archive/2005/07/29/444912.aspx

To summarise, the limitation is normally stack space (which must be in contiguous blocks) and since every thread consumes this scattered about you rapidly run out of contiguous blocks. On 64 bit machines and operating systems this is much less of a problem.

Mitigation strategies exist but will only go so far (and rely on you not using much stack per thread)

As a rough guide:

  • creating tens is almost certain to work
  • hundreds is probable on current server and desktop hardware but risky
  • thousands will almost certainly fail.

You likely shouldn't need to create more than ten anyway (and if you really do need to you should know this information already)

Upvotes: 37

Michael Burr
Michael Burr

Reputation: 340208

Do read the Raymond Chen blog postings that ShuggyCoUk's answer pointed to.

But pay special attention to this bit:

But the real question that is raised whenever somebody asks, "What's the maximum number of threads that a process can create?" is "Why are you creating so many threads that this even becomes an issue?"

The "one thread per client" model is well-known not to scale beyond a dozen clients or so. If you're going to be handling more than that many clients simultaneously, you should move to a model where instead of dedicating a thread to a client, you instead allocate an object. (Someday I'll muse on the duality between threads and objects.) Windows provides I/O completion ports and a thread pool to help you convert from a thread-based model to a work-item-based model.

Upvotes: 2

TheSoftwareJedi
TheSoftwareJedi

Reputation: 35196

Note that you should examine your design closely if you are concerned about hitting this limit!!!!!!!!

The answer to your "More Important Question" of what happens is OutOfMemoryException.

Not exactly a direct answer, but here's some code to find out the limit. It could be available memory dependent though. Would be interested in seeing other OS/cpu/mem results.

Feel free to edit and add your machine in:

  • Windows 7, VS2008, dual core, 2gb mem: 1,465 then crash with OutOfMemoryException

        int i = 0;
        try
        {
            while (true)
            {
                new Thread(new ThreadStart(() => Thread.Sleep(int.MaxValue))).Start();
                i++;
            }
        }
        catch (Exception ex)
        {
            Console.WriteLine(i);
            Console.WriteLine(ex.ToString());
        }
    

Upvotes: 16

Rex M
Rex M

Reputation: 144112

The best answer I've heard when asking such questions is:

It doesn't matter, and if you find that it does matter, you need to rethink what you're doing so that it doesn't matter.

Upvotes: 26

Kosi2801
Kosi2801

Reputation: 23095

As far as I understand the whole threading model it should not have changed much since Win2K.

There is no real limit of threads per se, but more a limit of the processes stack-space. See an in-depth explanation of threading limits from Raymond Chen for more details on this.

Upvotes: 1

Related Questions