Web Services and Middleware
Code | Completion | Credits | Range | Language |
---|---|---|---|---|
MI-MDW.16 | Z,ZK | 5 | 2P+1C | Czech |
- Garant předmětu:
- Lecturer:
- Tutor:
- Supervisor:
- Department of Software Engineering
- Synopsis:
-
Students learn new trends and technologies in the area of service-oriented architectures, web services, middleware, and cloud computing, including their theoretical background.
- Requirements:
-
Software architectures and Web technologies (HTTP, HTML, URI, XML), programming skills (Java, JavaScript), computer networks, basic algorithms.
- Syllabus of lectures:
-
1. Current and future roles of web services in ICT industry.
2. Objects, components, services. SOA.
3. Web Service Description Language (WSDL) and selected WS-* specifications.
4. Representational State Transfer (REST) and its RESTful realization, comparison with WSDL.
5. Process modelling workflow patterns, Business Process Execution Language (BPEL).
6. Middleware architectures: ESB, P/S, MQ.
7. Reliability and scalability of applications.
8. P2P systems, Skype case study.
9. Commercial software model vs. SaaS model.
10. Cloud computing, architectures of modern applications.
11. Infrastructure as a Service (IaaS), distributed processing and distributed file systems.
12. Platform as a Service (PaaS), Google case study.
13. Software as a Service (SaaS), SalesForce and GoodData case study.
- Syllabus of tutorials:
-
1. Application requirements analysis.
2. Object oriented application design, components and objects integration.
3. Web API application design (WSDL and RESTful).
4. Application implementation in the Web server environment.
5. Application implementation in the cloud computing environment (e.g. Google, Amazon).
6. Benchmarking, results comparison.
- Study Objective:
-
Modern applications require a certain level of flexibility with respect to changes that may occur in requirements on applications. From this reason, there are new types of application architectures with services exposing application functionality that allow to configure application processes. Another important requirement is to provide scalable, secure, and reliable infrastructures for applications. This module provides information about concepts, architectures, and technologies for the development of such applications.
- Study materials:
-
1. Erl, T. ''Service-Oriented Architecture: Concepts, Technology, and Design''. Prentice Hall, 2005. ISBN 0131858580.
2. Steinmetz, R., Wehrle, K. ''Peer-to-Peer Systems and Applications''. Springer, 2005. ISBN 354029192X.
3. Foster, I., Kesselman, C. ''The Grid 2: Blueprint for a New Computing Infrastructure (2nd Edition)''. Morgan Kaufmann, 2003. ISBN 1558609334.
4. Reese, G. ''Cloud Application Architectures: Building Applications and Infrastructure in the Cloud''. O'Reilly Media, 2009. ISBN 0596156367.
- Note:
- Further information:
- https://courses.fit.cvut.cz/MI-MDW/
- No time-table has been prepared for this course
- The course is a part of the following study plans:
-
- Master branch Knowledge Engineering, in Czech, 2016-2017 (elective course)
- Master branch Computer Security, in Czech, 2016-2019 (elective course)
- Master branch Computer Systems and Networks, in Czech, 2016-2019 (compulsory course of the specialization)
- Master branch Design and Programming of Embedded Systems, in Czech, 2016-2019 (elective course)
- Master branch Web and Software Engineering, spec. Info. Systems and Management, in Czech, 2016-2019 (compulsory course of the specialization)
- Master branch Web and Software Engineering, spec. Software Engineering, in Czech, 2016-2019 (compulsory course of the specialization)
- Master branch Web and Software Engineering, spec. Web Engineering, in Czech, 2016-2019 (compulsory course of the specialization)
- Master program Informatics, unspecified branch, in Czech, version 2016-2019 (VO)
- Master branch System Programming, spec. System Programming, in Czech, 2016-2019 (elective course)
- Master branch System Programming, spec. Computer Science, in Czech, 2016-2017 (elective course)
- Master specialization Computer Science, in Czech, 2018-2019 (elective course)
- Master branch Knowledge Engineering, in Czech, 2018-2019 (elective course)