COIT20257 - Distributed Systems: Principles and Development

General Information

Unit Synopsis

Distributed Systems: Principles and Development you will learn basic principles of distributed systems including architecture, design, and algorithms and how to use these principles in the development of distributed applications. You will explore the significant distributed system characteristics of scalability, heterogeneity, security, and failure handling in addition to the fundamentals of networking, inter-process communication, remote invocation, and operating system support. You will examine different approaches to supporting distributed applications including distributed objects, web services, and peer-to-peer solutions. You will learn about distributed file systems, naming, and data-related aspects of distributed transactions, and data replication. Algorithms associated to timing, and coordination and agreement will also be studied. You will also analyse the areas of mobile and ubiquitous computing and the social impact arising from the ubiquity of distributed systems. You will consolidate the key theoretical material through the computer lab tutorial sessions and development of software applications.

Details

Level Postgraduate
Unit Level 9
Credit Points 6
Student Contribution Band SCA Band 2
Fraction of Full-Time Student Load 0.125
Pre-requisites or Co-requisites

Prerequisite unit: COIT20256 Data structures and Algorithms

Anti-Requisite unit: COIT23005 Distributed Systems

Important note: Students enrolled in a subsequent unit who failed their pre-requisite unit, should drop the subsequent unit before the census date or within 10 working days of Fail grade notification. Students who do not drop the unit in this timeframe cannot later drop the unit without academic and financial liability. See details in the Assessment Policy and Procedure (Higher Education Coursework).

Class Timetable View Unit Timetable
Residential School No Residential School

Unit Availabilities from Term 3 - 2024

Term 3 - 2024 Profile
Online
Term 1 - 2025 Profile
Brisbane
Melbourne
Online
Rockhampton
Sydney
Term 2 - 2025 Profile
Brisbane
Melbourne
Online
Rockhampton
Sydney
Term 3 - 2025 Profile
Brisbane
Melbourne
Online
Sydney
Term 1 - 2026 Profile
Brisbane
Melbourne
Online
Rockhampton
Sydney
Term 2 - 2026 Profile
Brisbane
Melbourne
Online
Rockhampton
Sydney
Term 3 - 2026 Profile
Brisbane
Melbourne
Online
Sydney

Attendance Requirements

All on-campus students are expected to attend scheduled classes - in some units, these classes are identified as a mandatory (pass/fail) component and attendance is compulsory. International students, on a student visa, must maintain a full time study load and meet both attendance and academic progress requirements in each study period (satisfactory attendance for International students is defined as maintaining at least an 80% attendance record).

Assessment Overview

Recommended Student Time Commitment

Each 6-credit Postgraduate unit at CQUniversity requires an overall time commitment of an average of 12.5 hours of study per week, making a total of 150 hours for the unit.

Assessment Tasks

Assessment Task Weighting
1. Practical Assessment 30%
2. Practical Assessment 35%
3. Written Assessment 35%

This is a graded unit: your overall grade will be calculated from the marks or grades for each assessment task, based on the relative weightings shown in the table above. You must obtain an overall mark for the unit of at least 50%, or an overall grade of ‘pass’ in order to pass the unit. If any ‘pass/fail’ tasks are shown in the table above they must also be completed successfully (‘pass’ grade). You must also meet any minimum mark requirements specified for a particular assessment task, as detailed in the ‘assessment task’ section (note that in some instances, the minimum mark for a task may be greater than 50%).

Consult the University's Grades and Results Policy for more details of interim results and final grades

Past Exams

To view Past Exams,
please login
Previous Feedback

Term 1 - 2024 : The overall satisfaction for students in the last offering of this course was 83.33% (`Agree` and `Strongly Agree` responses), based on a 24% response rate.

Feedback, Recommendations and Responses

Every unit is reviewed for enhancement each year. At the most recent review, the following staff and student feedback items were identified and recommendations were made.

Source: UC self reflection and teaching team feedback
Feedback
Students need a comprehensive and complex case study to synthesise the concepts, models and architecture that are covered by the unit.
Recommendation
Combine Transactions and Distributed Transactions to a single week. Then a week space can leave to introduce social computing networks by a comprehensive and complex distributed case study (e.g. secured chat systems).
Action Taken
The Week 9 and Week 10 contents have been combined/updated into Week 9. The original Week 11 and Week 12 have been moved to Week 10 and Week 11. A complex distributed system case study on Secured Online Chat has been implemented for Week 12 lecture, lab and tutorial.
Source: UC self reflection and teaching team feedback
Feedback
Lack or not enough depth in advanced Java programming.
Recommendation
Introduce or strengthen Java interfaces, object serialization and streaming, Java generics and multithreading to handle distributed interaction and modelling.
Action Taken
All of the technical issues have been implemented and distributed in relevant weeks' contents and assessed by assignments.
Source: UC self reflection and teaching team feedback
Feedback
Involving more students for unit evaluation.
Recommendation
1. In Week 1 and 6 Lectures: clearly explain to students why teaching evaluations are important to the improvement of the unit and helps instructors enhance their teaching methods. 2. In Week 10 Lecture and Tutorial: encourage class discussions about the importance of feedback and improvements. Lead discussions on the topic and involve students in brainstorming ways to enhance the unit.
Action Taken
The promotion for teaching evaluation has been done in Week 1, Week 6 and Week 10.
Source: Unit Coordinator self reflection
Feedback
There is a need to gather feedback from students and the teaching team on the newly added content regarding 1) security topics (mutual authentication and symmetrical/asymmetrical cryptography) and 2) the complex distributed system case study, to assess their reception and integration into the course and inform necessary refinements for improved learning outcomes.
Recommendation
Collect feedback from the teaching team and check students' performance on the newly added content on the two topics. If necessary, make proper adjustments/updates to the content.
Action Taken
In Progress
Source: Unit Coordinator self reflection
Feedback
The rise of IoT, demand for low-latency applications, and growth of 5G underscore the importance of incorporating edge computing into the curriculum to equip students with knowledge of efficient and scalable computing solutions.
Recommendation
Introduce the modern distributed computing model of Edge Computing, along with key industry standards. Assess Edge Computing through a simplified case study, such as Smart Farming.
Action Taken
In Progress
Unit learning Outcomes

On successful completion of this unit, you will be able to:

  1. Develop distributed applications using networking, inter-process communication, and remote invocation
  2. Design and develop distributed applications using one of the approaches of distributed objects, web services, and peer-to-peer solutions
  3. Solve problems in the distributed systems domain by applying the principles of distributed systems to authentic problems
  4. Critique the issues involved in developing reliable, secure, and scalable distributed systems
  5. Discuss the technology needs and social impact arising from ubiquitous distributed systems
  6. Work independently and collaboratively in small teams.

Australian Computer Society (ACS) recognises the Skills Framework for the Information Age (SFIA). SFIA is in use in over 100 countries and provides a widely used and consistent definition of ICT skills. SFIA is increasingly being used when developing job descriptions and role profiles.

ACS members can use the tool MySFIA to build a skills profile at https://www.acs.org.au/professionalrecognition/mysfia-b2c.html

This unit contributes to the following workplace skills as defined by SFIA. The SFIA code is included:

  • Systems Design (DESN)
  • Systems Integration (SINT)
  • Program ming/Software Development ( PROG),
  • Database/Repository Design (DBDS)
  • Testing (TEST)
  • Network Support (NTAS)
  • Release and Deployment (RELM),
  • Application Support (ASUP).

Alignment of Assessment Tasks to Learning Outcomes
Assessment Tasks Learning Outcomes
1 2 3 4 5 6
1 - Practical Assessment
2 - Practical Assessment
3 - Written Assessment
Alignment of Graduate Attributes to Learning Outcomes
Professional Level
Advanced Level
Graduate Attributes Learning Outcomes
1 2 3 4 5 6
1 - Knowledge
2 - Communication
3 - Cognitive, technical and creative skills
4 - Research
5 - Self-management
6 - Ethical and Professional Responsibility
7 - Leadership
Alignment of Assessment Tasks to Graduate Attributes
Professional Level
Advanced Level
Assessment Tasks Graduate Attributes
1 2 3 4 5 6 7 8
1 - Practical Assessment
2 - Practical Assessment
3 - Written Assessment