Course detail

Distributed Application Environment

FIT-PDIAcad. year: 2021/2022

Common characteristics of distributed environments. Principles, algorithms and systems of distributed computing. Types of distributed environments. Design and model of distributed applications. Distributed operating and file systems. Cloud Computing. Technology JSP, J2EE, JavaBeans, EJB, RPC, XML-RPC, SOAP, IIOP. Web services.  Security in distributed applications.

Language of instruction

Czech

Number of ECTS credits

Mode of study

Not applicable.

Learning outcomes of the course unit

The student will become familiar with concepts and principles of distributed environments, with design and implementation of applications for distributed environments and security aspects in distributed environments.
  • Student learns terminology in the domain of DS
  • Student learns to create small projects
  • Student learns to present and defend the results of the small project

Prerequisites

  • knowledge of programming
  • knowledge discrete mathematics
  • basic knowledge of computer networks

Co-requisites

Not applicable.

Planned learning activities and teaching methods

Not applicable.

Assesment methods and criteria linked to learning outcomes

  • Mid-term written examination - 15 points
  • Laboratory exercises - 10 points
  • Evaluated project with the defense - 20 points
  • Final written examination - 55 points

Course curriculum

Not applicable.

Work placements

Not applicable.

Aims

The aim is to understand principles and design of applications for distributed environment, obtain overview of modern distributed environments and ability of usage application interface for various programming environments.

Specification of controlled education, way of implementation and compensation for absences

  • Scored laboratory exercises for which at least two terms are listed. The possibility of replacement only in case of objective and proven obstacles in the study.
  • Mid-term exam in the lecture.
  • Evaluated projects with defence in the form of presentation of results.

Recommended optional programme components

Not applicable.

Prerequisites and corequisites

Not applicable.

Basic literature

Kshemkalyani, Singhal: Distributed Computing, Cambridge Press, 2008.

Recommended reading

B. Burns: Designing Distributed Systems: Patterns and Paradigms for Scalable, Reliable Services,  O'Reilly Media, 1st edition, 2018.

Classification of course in study plans

  • Programme IT-MSC-2 Master's

    branch MBI , 0 year of study, winter semester, elective
    branch MBS , 0 year of study, winter semester, elective
    branch MGM , 0 year of study, winter semester, compulsory-optional
    branch MIN , 0 year of study, winter semester, elective
    branch MIS , 2 year of study, winter semester, compulsory-optional
    branch MMM , 0 year of study, winter semester, elective
    branch MPV , 0 year of study, winter semester, compulsory-optional
    branch MSK , 2 year of study, winter semester, compulsory

  • Programme MITAI Master's

    specialization NADE , 0 year of study, winter semester, compulsory
    specialization NBIO , 0 year of study, winter semester, elective
    specialization NCPS , 0 year of study, winter semester, elective
    specialization NEMB , 0 year of study, winter semester, elective
    specialization NGRI , 0 year of study, winter semester, elective
    specialization NHPC , 0 year of study, winter semester, elective
    specialization NIDE , 0 year of study, winter semester, elective
    specialization NISD , 0 year of study, winter semester, elective
    specialization NMAL , 0 year of study, winter semester, elective
    specialization NMAT , 0 year of study, winter semester, elective
    specialization NNET , 0 year of study, winter semester, compulsory
    specialization NSEC , 0 year of study, winter semester, elective
    specialization NSEN , 0 year of study, winter semester, elective
    specialization NSPE , 0 year of study, winter semester, elective
    specialization NVER , 0 year of study, winter semester, elective
    specialization NVIZ , 0 year of study, winter semester, elective
    specialization NISY up to 2020/21 , 0 year of study, winter semester, elective
    specialization NISY , 0 year of study, winter semester, elective

Type of course unit

 

Lecture

26 hod., optionally

Teacher / Lecturer

Syllabus

  1. Principles and models of distributed computation
  2. Physical and Logical Time 
  3. Global State and Snapshot Algorithms 
  4. Group communication
  5. Authentication in Distributed Systems 
  6. Algorithms of Leader Election and Mutual Exclusion
  7. Consensus and Agreement 
  8. Virtualization and Cloud Computing
  9. MapReduce Programming Model and Apache Hadoop 
  10. Distributed File Systems
  11. Apache Spark 
  12. Enterprise Service Bus 
  13. Distributed computing with BOINC

Exercise in computer lab

6 hod., compulsory

Teacher / Lecturer

Project

20 hod., compulsory

Teacher / Lecturer

Syllabus

  • Implementation of distributed application in the given target environment (CORBA, Azure, Hadoop,...).