Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

WCF Service and Threading

I have created a simple WCF (.NET 3.5) service which defines 10 contracts which are basically calculations on the supplied data. At the moment I expect quite few clients to make a call to some of these contracts. How do I make the service more responsive ? I have a feeling that the service will wait until it process one request to go to the next one. How can I use multithreading in WCF to speed things up ?

like image 410
koumides Avatar asked Oct 19 '10 14:10

koumides


People also ask

Is WCF multithreaded?

WCF does not create any queue for client messages and replays them as soon as they arrive. Each service has multiple threads processing messages concurrently.

What is the WCF service?

Windows Communication Foundation (WCF) is a framework for building service-oriented applications. Using WCF, you can send data as asynchronous messages from one service endpoint to another. A service endpoint can be part of a continuously available service hosted by IIS, or it can be a service hosted in an application.

What is concurrency mode in WCF?

There are three concurrency modes available: Single : Each service instance processes one message at a time. This is the default concurrency mode. Multiple : Each service instance processes multiple messages concurrently. The service implementation must be thread-safe to use this concurrency mode.


3 Answers

While I agree with Justin's answer, I believe some more light can be shed here on how WCF works.

You make the specific statement:

I have a feeling that the service will wait until it process one request to go to the next one. How can I use multithreading in WCF to speed things up ?

The concurrency of a service (how many calls it can take simultaneously) depends on the ConcurrencyMode value for the ServiceBehavior attached to the service. By default, this value is ConcurrencyMode.Single, meaning, it will serialize calls one after another.

However, this might not be as much of an issue as you think. If your service's InstanceContextMode is equal to InstanceContextMode.PerCall then this is a non-issue; a new instance of your service will be created per call and not used for any other calls.

If you have a singleton or a session-based service object, however, then the calls to that instance of the service implementation will be serialized.

You can always change the ConcurrencyMode, but be aware that if you do, you will have to handle concurrency issues and access to your resources manually, as you have explicitly told WCF that you will do so.

It's important not to change these just because you think that it will lead to increased performance. While not so much for concurrency, the instancing aspect of your service is very much a part of the identity of the service (if it is session or not session-based) and changing them impacts the clients consuming the service, so don't do it lightly.

Of course, this speaks nothing to whether or not the code that is actually implementing the service is efficient. That is definitely something that needs looking into, when you indicate that is the case.

like image 148
casperOne Avatar answered Nov 03 '22 00:11

casperOne


This is definitely pre-mature optimization. Implement your services first and see if there's an issue or not.

I think you'll find that you are worrying about nothing. The server won't block on a single request as that request processes. IIS/WCF should handle things for you nicely as-is.

like image 34
Justin Niessner Avatar answered Nov 03 '22 01:11

Justin Niessner


I'm not familiar with WCF, but can the process be async? If you are expecting a huge amount of data and intensive calculations, one option could be to send an id, calculate the values in a separate thread and then provide a method to return the result using the initial id.

Something like:

 int id = Service.CalculateX(...);
 ...
 var y = Service.GetResultX(id);
like image 33
Pedro Avatar answered Nov 03 '22 02:11

Pedro