- From: <sthomas2@ups.com>
- Date: Thu, 29 Mar 2007 08:46:21 -0400
- To: <www-ws@w3.org>
Hi Folks, For those that don't want to read a long post, my request can be summarized: Does anyone have any good pointers to material (papers, studies, guidelines, etc.) on lifecycle management of web services? I'm especially interested in how to architect and/or design web services so that it will be easy (dare I say feasible?) to upgrade and eventually retire them in the future? To elaborate, it seems to me that lifecycle management of web services presents some unique challenges, and I don't know if anyone is really addressing those challenges. Especially interesting are the relationships between consumers and producers of web services. (I realize that there are several products for managing the deployment of web services and related aspects of their lifecycle, but those appear to be focused strictly on the producers/developers of the services.) Since web services are primarily software products (in the sense that most of the effort required to create them resembles traditional software development), the first thought might be to treat web service lifecycles the same as software product lifecycles. But there are at least a couple of characteristics of web services that suggest that this approach won't work very well. First, web services are not used the same way as traditional software products. Second, the economic model for web services is likely to differ from that of traditional software. To appreciate those differences, consider the problem of retiring an obsolete web service using a "Windows 95" model. Windows 95 is a traditional software product running on a standalone computer. At some point Microsoft can declare that the product is no longer supported, and Microsoft can free up the resources required to provide that support. Windows 95 users, however, can still continue to use the product as much as they wish. Although they might not be able to receive support for the product, as long as it was working adequately for them before the end-of-life point, it will continue to work adequately after the end-of-life. Satisfied customers remain (relatively) satisfied customers. In a web service world, of course, the situation is entirely different. The consumer of a web service requires that the web service producer continue to support the service for as long as the consumer wants to use it. If a producer withdraws supports for a particular service (e.g. by dedicating the server resources to a new service), then the consumer immediately stops working. Satisfied consumers suddenly become very dissatisfied consumers. The economic models of traditional software and web services also have a major impact on lifecycle management. When a customer purchases Windows 95, Microsoft immediately receives the revenue for that transaction. Although Microsoft undoubtedly wants to keep its customers as satisfied as possible, in the narrowest sense there is no real cost to Microsoft to replace Windows 95 with a new product. (I'm ignoring second order effects like preserving brand equity, etc.) With web services, however, the economic model is likely based on transactions. If the service producer is generating revenue from web services, it is likely doing so incrementally with each individual use of the service. (Amazon, for example, gets revenue whenever someone uses a web service to purchase a book.) For web service producers, there is a real economic cost to discontinuing a web service, even if discontinuing the service allows them to introduce newer services. It seems to me, therefore, that once a web service is deployed it may be extremely difficult to ever retire that service. Indeed, the problem could be even more severe because for the same reasons it may be difficult for the producer to simply upgrade the service. (It is easy to imagine cases where poorly developed web service clients only work with, say, SOAP 1.2 and break when the producer upgrades to, say, SOAP 2.0. This might be true even if SOAP 2.0 is ostensibly backwards-compatible with SOAP 1.2, because that backwards-compatibly assumes good coding practices on the part of client developers. Unfortunately, such practices cannot be enforced.) So what do web service producers do about this problem? Are there steps, guidelines, best practices, etc. that developers can employ to at least minimize the problem, even if they can't eliminate it entirely? Have folks already solved this problem and I'm just not looking in the right place? Any pointers, comments, suggestions would be appreciated. Thanks, Stephen
Received on Friday, 30 March 2007 02:48:48 UTC