RESTful Service Composition
dc.contributor.advisor | Deters, Ralph | en_US |
dc.contributor.committeeMember | Zhang, Chris | en_US |
dc.contributor.committeeMember | Neufeld, Eric | en_US |
dc.contributor.committeeMember | Osgood, Nathaniel | en_US |
dc.contributor.committeeMember | Bunt, Rick | en_US |
dc.creator | Liu, Dong | en_US |
dc.date.accessioned | 2013-07-05T12:00:17Z | |
dc.date.available | 2013-07-05T12:00:17Z | |
dc.date.created | 2013-05 | en_US |
dc.date.issued | 2013-07-04 | en_US |
dc.date.submitted | May 2013 | en_US |
dc.description.abstract | The Service-Oriented Architecture (SOA) has become one of the most popular approaches to building large-scale network applications. The web service technologies are de facto the default implementation for SOA. Simple Object Access Protocol (SOAP) is the key and fundamental technology of web services. Service composition is a way to deliver complex services based on existing partner services. Service orchestration with the support of Web Services Business Process Execution Language (WSBPEL) is the dominant approach of web service composition. WSBPEL-based service orchestration inherited the issue of interoperability from SOAP, and it was furthermore challenged for performance, scalability, reliability and modifiability. I present an architectural approach for service composition in this thesis to address these challenges. An architectural solution is so generic that it can be applied to a large spectrum of problems. I name the architectural style RESTful Service Composition (RSC), because many of its elements and constraints are derived from Representational State Transfer (REST). REST is an architectural style developed to describe the architectural style of the Web. The Web has demonstrated outstanding interoperability, performance, scalability, reliability and modifiability. RSC is designed for service composition on the Internet. The RSC style is composed on specific element types, including RESTful service composition client, RESTful partner proxy, composite resource, resource client, functional computation and relaying service. A service composition is partitioned into stages; each stage is represented as a computation that has a uniform identifier and a set of uniform access methods; and the transitions between stages are driven by computational batons. RSC is supplemented by a programming model that emphasizes on-demand function, map-reduce and continuation passing. An RSC-style composition does not depend on either a central conductor service or a common choreography specification, which makes it different from service orchestration or service choreography. Four scenarios are used to evaluate the performance, scalability, reliability and modifiability improvement of the RSC approach compared to orchestration. An RSC-style solution and an orchestration solution are compared side by side in every scenario. The first scenario evaluates the performance improvement of the X-Ray Diffraction (XRD) application in ScienceStudio; the second scenario evaluates the scalability improvement of the Process Variable (PV) snapshot application; the third scenario evaluates the reliability improvement of a notification application by simulation; and the fourth scenario evaluates the modifiability improvement of the XRD application in order to fulfil emerging requirements. The results show that the RSC approach outperforms the orchestration approach in every aspect. | en_US |
dc.identifier.uri | http://hdl.handle.net/10388/ETD-2013-05-1077 | en_US |
dc.language.iso | eng | en_US |
dc.subject | Web Services | en_US |
dc.subject | Service Composition | en_US |
dc.subject | Service Orchestration | en_US |
dc.subject | REST | en_US |
dc.subject | Software Architecture | en_US |
dc.subject | Performance | en_US |
dc.subject | Scalability | en_US |
dc.subject | Reliability | en_US |
dc.subject | Modifiability | en_US |
dc.title | RESTful Service Composition | en_US |
dc.type.genre | Thesis | en_US |
dc.type.material | text | en_US |
thesis.degree.department | Computer Science | en_US |
thesis.degree.discipline | Computer Science | en_US |
thesis.degree.grantor | University of Saskatchewan | en_US |
thesis.degree.level | Doctoral | en_US |
thesis.degree.name | Doctor of Philosophy (Ph.D.) | en_US |