WCF: What is a ServiceHost?
Asked Answered
M

2

39

As I'm currently learning to use WCF Services, I am constantly encountering tutorials on the internet which mention using a ServiceHost when using a WCF Service.

What exactly is this ServiceHost ?


In my current project I am using a WCF Service and having a reference to it from my app and whenever I want to consume it from my app I just instantiate its ServiceClient like such:

new MusicRepo_DBAccess_ServiceClient(new InstanceContext(instanceContext), customBinding, endpointAddress);

And then access my web methods (OperationContracts) from that instance (obviously opening it before consuming the method and closing it afterwards with Open and Close)

My WCF service is host in my IIS and I just access the .svc from my app to instantiate the ServiceClient.

So why and where is ServiceHost used?

Macedonian answered 3/5, 2009 at 3:9 Comment(0)
D
33

A ServiceHost basically provides you everything you need to host a WCF service in a non-IIS or WAS setting. A common place for a ServiceHost would be in a console app or Windows service. See the example code from MSDN for how to setup a ServiceHost in a console app.

Didymium answered 3/5, 2009 at 3:27 Comment(5)
Almost correct - even IIS and WAS will use a ServiceHost to host your WCF Service - they just create it and tear it down automagically behind your back.Urdar
Yeah, I was just trying to describe when you'd see a ServiceHost in your own code. The IIS/WAS ServiceHost is not usually accessed directly by the developer.Didymium
Yeah, that's right - the ServiceHost is almost invisible in the IIS/WAS scenario :)Urdar
I love that shitty page by MS "provides a host for services" wtf. Thanks for nothing Microsoft. I learned nothing on that page.Lundell
You have to look toward the bottom of the MS page for the Remarks and Examples sections, which provide a better explanation than just "Provides a host for services."Aundrea
U
29

Your service implementation is just a .NET class - you need to have a runtime environment for it, so it can be executed somehow. That's what the ServiceHost is for - it will load your service class, set up the endpoints and channel listeners and all that stuff, and thus give your service class an "ecosystem" to live and operate in.

You can either instantiate a ServiceHost class yourself in a console app, a Windows service, or even a Winforms app, and thus make your WCF service class available to the outside world - or you can delegate that work to IIS or WAS. Even IIS or WAS will use a ServiceHost to host your WCF service - they just do it automagically behind the scenes, and "on demand" - whenever a request for your WCF service comes in.

Marc

Urdar answered 3/5, 2009 at 8:15 Comment(1)
would you use that in TDD tests where you want to test calls such as sending in specific headers or data to the http request (WebOperationContext) to wcf service methods?Lundell

© 2022 - 2024 — McMap. All rights reserved.