views:

211

answers:

3

I'm trying out web services for an idea I've had. Running in debug it looks like the web service class instantiates each time a client calls a method in the web service. I can see this by seeing that the constructor gets called each time I call a method. I only instantiate the proxy web service once in the client.

This would mean I would have to store all data between calls and means that if I use a databse I'll have to re-connect with for every call to a method.

That can't be correct?

+4  A: 

That is indeed correct.

Web Services (in a Service Oriented Architecture) are meant to be stateless (they don't remember anything between calls...all data persistance is up to you).

If you search long enough on the web, you'll find attempts to create stateful web services (which do have their place, but go against the core principals of SOA). You'll find, though, that they don't alleviate your concerns. You'll get a new class instantianciation with every call and any connections to the DB will have to be re-created.

Justin Niessner
+1  A: 

Yes, that's 100% correct. Every time a request is received by the server, a new object is instantiated to handle the request on a separate thread.

This is the same thing that happens with a basic ASP.NET Web Form.

Randolpho
+2  A: 

For ASMX, it's correct and largely a good thing. Services should be as stateless as possible, and if you really need to store something between calls then you can use a singleton. I don't think holding onto a database connection would qualify, though, because they're cached and you want to scope your use, anyhow.

If you want a single object to stay alive between calls, WCF does offer this option. Given that ASMX is obsolete, you might want to move to WCF.

Steven Sudit
Maybe not quite obsolete. "Legacy" is the word MS uses.
John Saunders
That's very tactful of them.
Steven Sudit