The course is intended for individuals looking to understand the basics of software engineering as they relate to building large software systems that leverage big data. You will be introduced to software engineering concepts necessary to build and scale large, data intensive, distributed systems. Starting with software engineering best practices and loosely coupled, highly cohesive data microservices, the course takes you through the evolution of a distributed system over time.



Fundamentals of Software Architecture for Big Data
This course is part of Software Architecture for Big Data Specialization


Instructors: Tyson Gern
Access provided by KAUST Academy learning programs
10,205 already enrolled
(87 reviews)
Recommended experience
What you'll learn
- Practice software engineering fundamentals; test first development, refactoring, continuous integration, and continuous delivery. 
- Architect and create a big data or distributed system using rest collaboration, event collaboration, and batch processing. 
- Create a performant, scalable distributed system that handles big data. 
Skills you'll gain
Details to know

Add to your LinkedIn profile
6 quizzes, 4 assignments
See how employees at top companies are mastering in-demand skills

Build your subject-matter expertise
- Learn new concepts from industry experts
- Gain a foundational understanding of a subject or tool
- Develop job-relevant skills with hands-on projects
- Earn a shareable career certificate

There are 4 modules in this course
Welcome to Fundamentals of Software Architecture for Big Data. In the first week of this course, you will learn the basics of modern software engineering. You will learn how our industry progresses over time, practice test driven development, and implement widely used data structures.
What's included
7 videos8 readings1 assignment1 peer review1 discussion prompt
In this week you will learn the fundamentals of software architecture. You will learn how to evolve an architecture over time, how to work within a large codebase, and a bit about blockchain.
What's included
5 videos4 readings1 quiz1 assignment1 peer review1 discussion prompt
This week you will learn the fundamentals of monitoring software in production. You will learn how to create reliable background jobs, how to calculate and communicate service availability, and how to implement production metrics and monitoring.
What's included
1 video2 readings2 quizzes1 assignment
In this last week of the course, you will learn the fundamentals of production quality databases and messaging systems. You will understand the tradeoffs between consistency and availability, how to implement database transactions to improve consistency, and how to implement messaging systems to improve availability.
What's included
3 videos4 readings3 quizzes1 assignment
Earn a career certificate
Add this credential to your LinkedIn profile, resume, or CV. Share it on social media and in your performance review.
Build toward a degree
This course is part of the following degree program(s) offered by University of Colorado Boulder. If you are admitted and enroll, your completed coursework may count toward your degree learning and your progress can transfer with you.¹
Instructors

Offered by
Why people choose Coursera for their career




Learner reviews
87 reviews
- 5 stars37.93% 
- 4 stars20.68% 
- 3 stars16.09% 
- 2 stars8.04% 
- 1 star17.24% 
Showing 3 of 87
Reviewed on Oct 19, 2023
Good lectures and code assignments to solidify concepts.
Reviewed on Jul 5, 2024
Solid advanced-level course for software architects looking to broaden horizons. The course is challange-based and requires experience with Object Oriented Programming, plus basic experience in Java.
Reviewed on Dec 14, 2023
The course is knowledgeable and enriching. The is scope for more peer interaction and virtual discussions/meetings once in a while.
Explore more from Computer Science
 - University of Colorado Boulder 
 - University of Colorado Boulder 
 - University of Colorado Boulder 
 - University of Colorado Boulder 

