Overview
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
Pre-requisites or Co-requisites
Prerequisite unit: COIT20256 Data structures and AlgorithmsAnti-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).
Offerings For Term 2 - 2024
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.
Class Timetable
Assessment Overview
Assessment Grading
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.
All University policies are available on the CQUniversity Policy site.
You may wish to view these policies:
- Grades and Results Policy
- Assessment Policy and Procedure (Higher Education Coursework)
- Review of Grade Procedure
- Student Academic Integrity Policy and Procedure
- Monitoring Academic Progress (MAP) Policy and Procedure - Domestic Students
- Monitoring Academic Progress (MAP) Policy and Procedure - International Students
- Student Refund and Credit Balance Policy and Procedure
- Student Feedback - Compliments and Complaints Policy and Procedure
- Information and Communications Technology Acceptable Use Policy and Procedure
This list is not an exhaustive list of all University policies. The full list of University policies are available on the CQUniversity Policy site.
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.
Feedback from 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.
Feedback from 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.
- 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).
Alignment of Assessment Tasks to Learning Outcomes
Assessment Tasks | Learning Outcomes | |||||
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | |
1 - Practical Assessment - 30% | ||||||
2 - Practical Assessment - 35% | ||||||
3 - Written Assessment - 35% |
Alignment of Graduate Attributes to Learning Outcomes
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 | ||||||
8 - Aboriginal and Torres Strait Islander Cultures |
Alignment of Assessment Tasks to Graduate Attributes
Assessment Tasks | Graduate Attributes | |||||||
---|---|---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | |
1 - Practical Assessment - 30% | ||||||||
2 - Practical Assessment - 35% | ||||||||
3 - Written Assessment - 35% |
Textbooks
Distributed Systems Concepts and Design
Edition: 5 (2012) (2012)
Authors: George Coulouris,Jean Dollimore, Tim Kindberg and Gordon Blair
Pearson Education
Gordon Blair Gordon Blair , UK
ISBN: 13: 9780137521081
Binding: Paperback
IT Resources
- CQUniversity Student Email
- Internet
- Unit Website (Moodle)
- JDK 21
- NetBeans IDE 20
All submissions for this unit must use the referencing style: Harvard (author-date)
For further information, see the Assessment Tasks.
w.li@cqu.edu.au
Module/Topic
An Introduction to Distributed Systems
Chapter
Chapter 1 and Chapter 2
Events and Submissions/Topic
Module/Topic
Inter-process Communication
Chapter
Chapter 4
Events and Submissions/Topic
Module/Topic
Distributed Objects and Remote Invocation
Chapter
Chapter 5
Events and Submissions/Topic
Module/Topic
Process and Thread Management - Operating System Support
Chapter
Chapter 7
Events and Submissions/Topic
Module/Topic
Security in Distributed Systems
Chapter
Chapter 11
Events and Submissions/Topic
Module/Topic
Chapter
Events and Submissions/Topic
Module/Topic
Replication and Fault Tolerance
Chapter
Chapter 18
Events and Submissions/Topic
Module/Topic
Name Services
Chapter
Chapter 13
Events and Submissions/Topic
Module/Topic
Coordination and Agreement
Chapter
Chapter 15
Events and Submissions/Topic
Module/Topic
Transactions, Distributed Transactions, and Concurrent Control
Chapter
Chapter 16 and 17
Events and Submissions/Topic
Module/Topic
Distributed File Systems
Chapter
Chapter 12
Events and Submissions/Topic
Module/Topic
Web Services and Mobile/Ubiquitous Computing
Chapter
Chapter 9 and Chapter 19
Events and Submissions/Topic
Module/Topic
A Complex Distributed System Case Study
Chapter
Unit Moodle online materials
Events and Submissions/Topic
Module/Topic
Chapter
Events and Submissions/Topic
Module/Topic
Assignment 3 Submission
Chapter
Events and Submissions/Topic
This is an advanced unit in MIT Course, covering theory and practice of distributed computing. Students’ commitment is very important for your success of this unit. Please attend each lecture and tutorial to build your knowledge and skills for development of distributed systems.
The unit coordinator contact information for this term:
DR Wei Li
School of Engineering & Technology
Central Queensland University
Rockhampton QLD 4702, Australia
Phone: + 61 7 4930 9686
Email: w.li@cqu.edu.au
1 Practical Assessment
Your task for this assignment is to develop a simplified Master/Worker Framework. The framework is a typical client/server system that utilises distributed computing power. The purpose of this assignment is to assess your competence on Java multi-threading, TCP streaming, object serialization and client/server model.
The assignment specification and marking criteria can be accessed from the unit Moodle site.
Please note: re-attempts of this assignment are not allowed.
Week 5 Friday (9 Aug 2024) 11:59 pm AEST
Assignment 1 Due
Week 6 Friday (23 Aug 2024)
Assignment 1 results release two weeks after submission
The assignment will be assessed by the software implementation and user instruction document.
- Analysis and design of a software application using TCP networking and client-server model for the given problem
- Implementation of the application using TCP streaming, multi-threading, and object serialization
- Incorporation of concurrent multi-user access to the software application
- Use of good programming techniques/practices
- Rigorous testing of software application.
The detailed assessment description and marking criteria can be found under the Assessment block of the unit website.
- Develop distributed applications using networking, inter-process communication, and remote invocation
- Solve problems in the distributed systems domain by applying the principles of distributed systems to authentic problems
- Knowledge
- Communication
- Cognitive, technical and creative skills
- Self-management
2 Practical Assessment
You will be tasked with a team-based software development project. You will be part of a small team to design, implement, test and document a Secured Master/Worker Framework. The purpose of this assignment is to assess your competence in symmetrical and asymmetrical cryptography and the applications in mutual authentication and secured communication of distributed systems. Your ability to work collaboratively in a small team will also be assessed by this assignment.
The assignment specification and marking criteria can be accessed from the unit Moodle site.
Please note: re-attempts of this assignment are not allowed.
Week 10 Friday (20 Sept 2024) 11:59 pm AEST
Assignment 2 Due
Week 12 Friday (4 Oct 2024)
Assignment 2 results release two weeks after submission
The assignment will be assessed by the software implementation and user instruction document.
- Analysis and design of a secured software application using symmetrical and asymmetrical cryptography for the given problem
- Implementation of the secured application using mutual authentication
- Critique the issues involved in developing secured, reliable, and scalable distributed systems
- Work independently and collaboratively in small teams
The detailed assessment description and marking criteria can be found under the Assessment block of the unit website.
- 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
- Work independently and collaboratively in small teams.
- Knowledge
- Communication
- Cognitive, technical and creative skills
- Research
- Self-management
- Ethical and Professional Responsibility
- Leadership
3 Written Assessment
Your task for this assignment is to research and address some key issues in the area of distributed systems or distributed computing. The purpose of this assignment is to assess your understanding of the key issues or competence to apply the key principles to distributed computing. Writing of a formal academic report is also assessed.
The assignment specification and marking criteria can be accessed from the unit Moodle site.
Please note: re-attempts of this assignment are not allowed.
Review/Exam Week Friday (11 Oct 2024) 11:59 pm AEST
Assignment 3 Due
The marked assignment will be returned on the day of Certification of Grades
The assignment will be assessed by understanding of the given key issues and application of the key principles.
- Clear demonstration of your understanding of the topics given in the specification
- Critical review of relevant information and logical construction of arguments
- Relevant discussion of the impact of specific aspects of distributed systems
- Appropriate formatting, clarity of expressions, and relevant and correct use of references.
The detailed assessment description and marking criteria can be found under the Assessment block of the unit website.
- 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.
- Knowledge
- Communication
- Cognitive, technical and creative skills
- Research
- Self-management
- Ethical and Professional Responsibility
As a CQUniversity student you are expected to act honestly in all aspects of your academic work.
Any assessable work undertaken or submitted for review or assessment must be your own work. Assessable work is any type of work you do to meet the assessment requirements in the unit, including draft work submitted for review and feedback and final work to be assessed.
When you use the ideas, words or data of others in your assessment, you must thoroughly and clearly acknowledge the source of this information by using the correct referencing style for your unit. Using others’ work without proper acknowledgement may be considered a form of intellectual dishonesty.
Participating honestly, respectfully, responsibly, and fairly in your university study ensures the CQUniversity qualification you earn will be valued as a true indication of your individual academic achievement and will continue to receive the respect and recognition it deserves.
As a student, you are responsible for reading and following CQUniversity’s policies, including the Student Academic Integrity Policy and Procedure. This policy sets out CQUniversity’s expectations of you to act with integrity, examples of academic integrity breaches to avoid, the processes used to address alleged breaches of academic integrity, and potential penalties.
What is a breach of academic integrity?
A breach of academic integrity includes but is not limited to plagiarism, self-plagiarism, collusion, cheating, contract cheating, and academic misconduct. The Student Academic Integrity Policy and Procedure defines what these terms mean and gives examples.
Why is academic integrity important?
A breach of academic integrity may result in one or more penalties, including suspension or even expulsion from the University. It can also have negative implications for student visas and future enrolment at CQUniversity or elsewhere. Students who engage in contract cheating also risk being blackmailed by contract cheating services.
Where can I get assistance?
For academic advice and guidance, the Academic Learning Centre (ALC) can support you in becoming confident in completing assessments with integrity and of high standard.