Software Architecture Schedule
Week One
Quality Attributes
Simplicity
Modularity
Maintainability
Topics
Course Overview
Slides
Software Architecture
Handout
Slides
What is Software Architecture?
High Quality Software
Quality Attributes
Architectural Views
Handout
Slides
C4 Model
C4 Model
Software Architecture in Practice
Views
4+1 Views
Layered Architecture
Handout
Slides
Monolith Architecture
Layered Architecture
Layered Design Principles
AWS Course Material:
Cloud Foundations
Introduction
Introduction
Module 1
Module 2 (skim)
Modules 3 - 5
Readings from
Software Architecture in Practice
4
th
edition
Chapter 1 (skim section 1.2)
Chapter 2
Chapter 3
Case Study Session
No Case Study Session this week.
Practical
Worksheet
Worksheet (HTML)
HTTP APIs
REST
Flask
Week Two
Quality Attributes
Security
Topics
Security Principles
Handout
Slides
Guiding Security Principles
Security Practices
Architecture Decision Records
Handout
Slides
Pipeline Architecture
Handout
Slides
AWS Course Material:
Cloud Foundations
Modules 6 - 10
Readings from
Software Architecture in Practice
4
th
edition
Chapter 1 (section 1.2)
Chapter 11
Chapter 19
Case Study Session
Write Up
Brief
Codegram
Practical
Worksheet
Worksheet (HTML)
Object Relational Mapping
SQLAlchemy
Migrations
Testing HTTP APIs
Assessment
Project proposal assignment released this week.
Specification
Video Intro
Week Three
Quality Attributes
Extensibility
Interoperability
Modifiability
Topics
Containers
Handout
Slides
Video
Microkernel Architecture
Handout
Slides
Video
Media Server Example
C4 Model
Technical vs Domain Partitioning
AWS Course Material:
Cloud Architecting
Modules 1 & 2
AWS Course Material:
Cloud Developing
Module 1, 2 & 8 (just introduction to Docker containers)
Readings from
Software Architecture in Practice
4
th
edition
Chapter 7
Chapter 8
Chapter 16
Case Study Session
Brief
MicroForecast
Practical
Worksheet
Worksheet (HTML)
Object Relational Mapping
SQLAlchemy
Migrations
Testing HTTP APIs
Assessment
Project Proposal is due March 25.
Week Four
Quality Attributes
Deployability
Topics
Service-Based Architecture
Handout
Slides
Infrastructure as Code
Handout
Slides
AWS Course Material:
Cloud Architecting
Modules 3 & 4
Readings from
Software Architecture in Practice
4
th
edition
Chapter 5
Chapter 17
Case Study Session
Brief
C4 Model
yLearn
Practical
Worksheet
Worksheet (HTML)
Docker
Docker Compose
Assessment
Project Proposal is due next Tuesday (March 25).
Cloud Infrastructure assignment released this week.
Specification
Week Five
Quality Attributes
Reliability
Topics
Distributed Systems I
Handout
Slides
Fallacies of Distributed Computing
Reliability and Fault Tolerance
Simple Scaling
Event-driven Architecture (intro)
Handout
Slides
AWS Course Material:
Cloud Architecting
Module 5
Modules 6 - 8 (skim)
Readings from
Software Architecture in Practice
4
th
edition
Chapter 4
Chapter 21
Case Study Session
Brief
DevOps
Practical
Worksheet
Worksheet (HTML)
AWS
Terraform
Assessment
Project Proposal voting is due next week.
API Functionality is due next week.
Week Six
Quality Attributes
Scalability
Topics
Distributed Systems II
Handout
Slides
Replications
Partitioning
Transactions
AWS Course Material:
Cloud Architecting
Modules 9 & 10
Module 11 (skim)
Readings from
Software Architecture in Practice
4
th
edition
Chapter 9
Chapter 22
Case Study Session
Cloud Infrastructure Assignment Help Session
Practical
Worksheet
Worksheet (HTML)
Deploying RDS on AWS using Terraform
Deploying HTTP API on AWS using Terraform
Using a container repository
Assessment
Project Proposal voting is due this Sunday.
API Functionality is due this Friday.
Start working on Deploy to Cloud.
Week Seven
Quality Attributes
Scalability (continued)
Topics
Event-driven Architecture (cont.)
Handout
Slides
Microservices Architecture
Slides
AWS Course Material:
Cloud Architecting
Module 12
Readings from
Software Architecture in Practice
4
th
edition
Chapter 6
Chapter 20
Case Study Session
Brief
Eventual Broker
Practical
Worksheet
Worksheet (HTML)
Load Balancers
Auto Scaling
Assessment
Deploy to Cloud is due next week.
Architecture Presentation assignment released this week.
Capstone Project assignment released this week.
Week Eight
Quality Attributes
Scalability (continued)
Maintainability
Topics
Microservices Architecture (cont.)
Slides
Serverless Architecture
Slides
Distributed Systems II (continued)
Handout
Slides
Replications
Partitioning
Transactions
AWS Course Material:
Cloud Architecting
Module 13 (skim Lambdas)
Readings from
Software Architecture in Practice
4
th
edition
Chapter 10
Case Study Session
Brief
Scalable Text-to-Speech
Practical
Worksheet — Queues
Worksheet (HTML) — Queues
Queues
Worker Queues
Cloud Deployment Assignment Help
Meet Your Project Team
Assessment
Deploy to Cloud is due this
Thursday
.
Start working on Scalable Application.
Start working on the Capstone Project.
Mid-Semester Break
Week Nine
Quality Attributes
Scalability (continued)
Topics
Monitoring & Logging (Guest Lecture by
Larene Le Gassick
)
Slides
Distributed Systems II (continued)
Handout
Slides
Replications
Partitioning
Transactions
AWS Course Material:
Cloud Architecting
Module 14 (skim)
Readings from
Software Architecture in Practice
4
th
edition
Chapter 12
Case Study Session
Monitoring & Logging
Practical
Worksheet — Load Testing
Worksheet (HTML) — Load Testing
Logging
Load Testing
Bottlenecks
Assessment
Scalable Application is due next week.
Continue working on the Capstone Project.
Week Ten
Quality Attributes
Scalability (continued)
Topics
Labour Day Public Holiday
No lecture this week
Case Study Session
Ticket Sales to the World — Scaling Transactions
Practical
Scalable Application Assignment Help
Project Team Meetings
Assessment
Scalable Application is due this Friday.
Continue working on the Capstone Project.
Week Eleven
Quality Attributes
Scalability
Extensibility
Deployability
Topics
Distributed Systems III
Handout
Slides
Consensus
Consistency
Fault Tolerance
Distributed Transactions
Technical Documentation (Guest Lecture by
Anna Truffet
from Google)
Slides
Case Study Session
Spam Handling
Practical
Project Team Meetings
Assessment
Continue working on the Capstone Project.
Start working on the Architecture Presentation.
Week Twelve
Quality Attributes
Scalability
Evolvability
Interoperability
Security
Topics
Deployment Strategies
Slides
Release Branching
Recreate Deployment
Rolling Deployment
Blue/green Deployment
Canary Deployment
A/B Deployment
Shadow Deployment
Data Unleashed
(Guest Lecture by
Bronwen Zande
)
Case Study Session
Scalability Assignment Solution
Course Feedback
Practical
Project Team Meetings
Assessment
Continue working on the Capstone Project.
Architecture Presentation is due next week.
Week Thirteen
Quality Attributes
Maintainability
Topics
Decomposing Monoliths
Slides
Soft Skills for Architects
Slides
Leveraging Conway's Law
Breadth over Depth
Software Engineering Research
Case Study Session
Presentations
Practical
Presentations
Project Team Meetings
Assessment
Architecture Presentation slides are due this Monday.
Architecture Presentations are conducted this week.
Continue working on the Capston Project — due June 9.
This work is licensed under a
Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License
.