I have a dependency injection container setup in my application and I’m thinking that composing the container every time a WCF service request comes in is going to be inefficient.
Can somebody explain to me, for an http/IIS hosted WCF service, what the lifecycle of the service is? If I can figure this out, I can make an educated decision on where the container is to be stored, instantiated, destroyed, etc.
If your
InstanceContextModeis PerCall, the service class will be created from scratch for every incoming request, and then disposed of when it’s done.If your
InstanceContextModeis PerSession, the service class will be created and used to service one given client for the duration of the session (or until an “InactivityTimeout” is encountered, or an error occurs).If your
InstanceContextModeis Single (singleton), the service class will be created when the first request comes in and will stay in memory as long as requests keep coming in, as long as no error occurs and no inactivityTimeout is reached.So, there you have it! Of course, the concurrency mode (for
PerSessionandSingleservices) will also come into play to make things just a tad more “interesting”