4.4
Beginner
12h
Distributed Systems: Building Software for the Real World
Explore architecting, designing, and building resilient distributed systems for real-world challenges. Gain insights into creating stability, designing for production, delivering systems, and solving systemic issues.
In this course, you will examine ways to architect, design, and build software —particularly distributed systems—for the muck and mire of the real world. You will prepare for the armies of illogical users who do crazy, unpredictable things. Your software will be under attack from the moment you release it. It needs to stand up to the typhoon winds of flash mobs or the crushing pressure of a DDoS attack by poorly secured IoT toaster ovens. You’ll take a hard look at software that failed the test and find ways to make sure your software survives contact with the real world. The course is divided into four parts, each introduced by a case study.
In Part I: Create Stability you’ll see how to keep your systems alive, maintaining system uptime.
In Part II: Design for Production, you’ll see what it means to live in production.
In Part III: Deliver Your System, you’ll look at deployments.
In Part IV: Solve Systemic Problems, you’ll examine the system’s ongoing life as part of the overall information ecosystem.
In this course, you will examine ways to architect, design, and build software —particularly distributed systems—for the muck an...Show More
WHAT YOU'LL LEARN
Understand system architecture and information architecture
Learn about development lifecycle and different architectures to build a software
Learn about stability anti-patterns, problems in network connection and their vulnerabilities
Learn service discovery systems, control plane, bounded/unbounded result sets and their effects
Understand system architecture and information architecture
Show more
TAKEAWAY SKILLS
Content
1.
Living in Production
4 Lessons
Step through readiness for production, holistic design, and pragmatic architecture in software.
2.
The Exception That Grounded an Airline
9 Lessons
Solve challenges with a case study on resolving airline system outages and preventing failures.
3.
Stabilize Your System
7 Lessons
Break apart strategies to maintain stability, prevent failures, and ensure system longevity.
4.
Stability Antipatterns
13 Lessons
Break down complex ideas on stability antipatterns in distributed systems and mitigation strategies.
5.
Failures And Blockages
19 Lessons
Take a closer look at handling failures and blockages in distributed systems to ensure resilience.
6.
Force Multiplier
6 Lessons
Investigate safeguards and strategies to prevent failures in automated distributed systems.
7.
Stability Patterns
17 Lessons
Master the steps to ensuring system stability through timeouts, circuit breakers, bulkheads, and effective resource management.
8.
Launching An Online Store
8 Lessons
Address challenges of online store launch, load testing, traffic management, and server diagnostics during peak retail events.
9.
Foundations
9 Lessons
Walk through the fundamentals of distributed systems, including virtualization, containers, and cloud environments.
10.
Processes on Machines
9 Lessons
Examine the essentials of deploying, managing, and monitoring distributed system processes on machines.
11.
Interconnect
12 Lessons
Grasp the fundamentals of interconnect layers, DNS, load balancing, demand control, and service discovery.
12.
Control Plane
14 Lessons
Take a closer look at the control plane's role in managing and automating distributed systems.
13.
Security
11 Lessons
Implement measures to enhance security in distributed systems, mitigating breaches and vulnerabilities effectively.
14.
Design for Deployment
10 Lessons
Master deployment strategies, minimize downtime, ensure system stability, and enhance user experience.
15.
Handling Versions
5 Lessons
Try out strategies for handling versions and maintaining API compatibility in distributed systems.
16.
Case Study: Trampled by Your Own Customers
6 Lessons
Walk through the challenges and resolutions in launching and stabilizing a new online system.
17.
Adaptation
8 Lessons
Work your way through adapting software for changes, efficient processes, effective teams, and service autonomy.
18.
System Architecture
7 Lessons
Grasp the fundamentals of resilient, adaptable system architecture principles and modularity.
19.
Information Architecture
6 Lessons
Deepen your knowledge of flexible information architecture, focusing on databases, events, services, URLs, and data plurality.
20.
Chaos Engineering
8 Lessons
Follow the process of using chaos engineering to enhance resilience in distributed systems.
Certificate of Completion
Showcase your accomplishment by sharing your certificate of completion.
Course Author:
Developed by MAANG Engineers
Trusted by 2.8 million developers working at companies
"These are high-quality courses. Trust me the price is worth it for the content quality. Educative came at the right time in my career. I'm understanding topics better than with any book or online video tutorial I've done. Truly made for developers. Thanks"
Anthony Walker
@_webarchitect_
"Just finished my first full #ML course: Machine learning for Software Engineers from Educative, Inc. ... Highly recommend!"
Evan Dunbar
ML Engineer
"You guys are the gold standard of crash-courses... Narrow enough that it doesn't need years of study or a full blown book to get the gist, but broad enough that an afternoon of Googling doesn't cut it."
Software Developer
Carlos Matias La Borde
"I spend my days and nights on Educative. It is indispensable. It is such a unique and reader-friendly site"
Souvik Kundu
Front-end Developer
"Your courses are simply awesome, the depth they go into and the breadth of coverage is so good that I don't have to refer to 10 different websites looking for interview topics and content."
Vinay Krishnaiah
Software Developer
Hands-on Learning Powered by AI
See how Educative uses AI to make your learning more immersive than ever before.
AI Prompt
Code Feedback
Explain with AI
AI Code Mentor
Free Resources