Click Here to view current 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
Term 1 - 2025 Profile
Term 2 - 2025 Profile
Term 3 - 2025 Profile
Term 1 - 2026 Profile
Term 2 - 2026 Profile
Term 3 - 2026 Profile
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).
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%).
Past Exams
All University policies are available on the Policy web site, however you may wish to directly view the following policies below.
This list is not an exhaustive list of all University policies. The full list of policies are available on the Policy web site .
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
Students need a comprehensive and complex case study to synthesise the concepts, models and architecture that are covered by the unit.
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).
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
Lack or not enough depth in advanced Java programming.
Introduce or strengthen Java interfaces, object serialization and streaming, Java generics and multithreading to handle distributed interaction and modelling.
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
Involving more students for unit evaluation.
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.
The promotion for teaching evaluation has been done in Week 1, Week 6 and Week 10.
Source: Unit Coordinator self reflection
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.
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.
In Progress
Source: Unit Coordinator self reflection
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.
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.
In Progress
On successful completion of this unit, you will be able to:
- Develop distributed applications using networking, inter-process communication, and remote invocation
- Design and develop distributed applications using one of the approaches of distributed objects, web services, and peer-to-peer solutions
- Solve problems in the distributed systems domain by applying the principles of distributed systems to authentic problems
- Critique the issues involved in developing reliable, secure, and scalable distributed systems
- Discuss the technology needs and social impact arising from ubiquitous distributed systems
- 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).
| Assessment Tasks | Learning Outcomes | |||||
|---|---|---|---|---|---|---|
| 1 | 2 | 3 | 4 | 5 | 6 | |
| 1 - Practical Assessment | • | • | ||||
| 2 - Practical Assessment | • | • | • | • | ||
| 3 - Written Assessment | • | • | • | |||
| 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 | • | • | ||||
| Assessment Tasks | Graduate Attributes | ||||||||
|---|---|---|---|---|---|---|---|---|---|
| 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 8 | |
| 1 - Practical Assessment | • | • | • | • | |||||
| 2 - Practical Assessment | • | • | • | • | • | • | • | ||
| 3 - Written Assessment | • | • | • | • | • | • | |||