WCF tutorial | WCF Instance Deactivation
In Instance Management System tutorial, you learn how to create sessionful service instance. Basically service instance is hosted in a context. Session actually correlated the client message not to the instance, but to the context that host it. When session starts, context is created and when it closes, context is terminated. WCF provides the option of separating the two lifetimes and deactivating the instance separately from its context.
ReleaseInstanceMode property of the OberationalBehavior attribute used to control the instance in relation to the method call.
Followings are the list Release mode available in the ReleaseInstanceMode
Below code show, how to add the 'ReleaseInstanceMode' property to the operational behavior.
public interface ISimpleCalculator
int Add(int num1, int num2);
public int Add(int num1, int num2)
return num1 + num2;
This property means that it will not affect the instance lifetime. By default ReleaseInstanceMode property is set to 'None'.
This property means that it will create new instance before a call is made to the operation.
If the instance is already exist,WCF deactivates the instance and calls Dispose() before the call is done. This is designed to optimize a method such as Create()
This property means that it will deactivate the instance after call is made to the method.
This is designed to optimize a method such a Cleanup()
This is means that it will create new instance of object before a call and deactivates the instance after call. This has combined effect of using ReleaseInstanceMode.BeforeCall and ReleaseInstanceMode.AfterCall
You can also explicitly deactivate instance using InstanceContext object as shown below.
public interface IMyService
public class MyService:IMyService
public void MyMethod()
- Always create the service with Interface->Implementation format, mention the contract in Interface.
- Define the service in Class library and refer the class library in Host project. Don’t use service class in host project.
- Change the instance mode to per call as default.
- Always catch exception using try/catch block and throw exception using FaultException < T >.
- Logging and Include exception should be enable while compiling the project in debug mode. While in production deployment disable the logging and Include exception details.