Service Oriented Architecture
      There has been much recent interest in service-based architectures as a very promising means to structure software development. This represents a convergence of simple ideas from the world of objects with other concepts in distributed systems and component-based development, underpinned by cross-platform protocols based largely on XML.
Frequency
This subject has been discontinued; no further courses are planned.
Objectives
The course aims to give the student an understanding of the strengths and weaknesses of a service-based architecture, informed by an ability to implement and deploy simple web services using a suitable development platform. They will also learn to define and design applications as combinations of services, and be able to discuss the emergent properties of those compositions; and to understand the research context and potential future directions for these technologies.
Contents
- Software components
 - Modularity; reuse; contracts; component-oriented programming; services.
 - Web-services
 - XML; HTTP; SOAP; WSDL; UDDI.
 - Representational state transfer
 - Architectural styles of the web; REST; resource-oriented architecture.
 - Composition
 - Workflow; activity diagrams; BPMN; BPEL.
 - Objects
 - OO middleware; CORBA; objects versus services.
 - Software architecture
 - Client-server; layers; pipes and filters; EDA; repositories; peer-to-peer; Grid Computing.
 - Semantic web
 - Knowledge representation; Resource Description Framework; Web Ontology Language; Semantic Frameworks.
 - Service qualities
 - Transactions; performance; security.
 - Engineering SOA
 - Organization; lifecycle; versioning; governance.
 
Requirements
The course presupposes a basic understanding of XML schema and XML namespaces. Practical exercises entail a considerable amount of Java programming; fluency with some OO programming language will be helpful, and participants may want to read up on Java beforehand if not familiar with it. The design discussion assumes a basic knowledge of UML.