Building Modern Distributed Systems with Java

Learn how to design large-scale distributed systems with NoSQL databases, messaging queues and cluster coordination

3.85 (172 reviews)
Udemy
platform
English
language
Operating Systems
category
instructor
Building Modern Distributed Systems with Java
1,279
students
4 hours
content
Feb 2022
last update
$59.99
regular price

What you will learn

Design and implement globally-distributed, scalable and fault-tolerant applications

Understanding of common algorithms and techniques used in majority of NoSQL databases and streaming platforms

In-depth knowledge of Apache Cassandra, Apache Kafka and ETCD

Build distributed URL-shorten service

Why take this course?

Significant percentage of large scale enterprises that I have been working with, admitted experiencing performance issues with their business critical applications. Most of production systems have been built on top of legacy, monolith technologies. Recent popularity of micro-services will not fulfill its promise of decoupled, scalable and fault-tolerant systems, unless "done right". While entering the world of micro-services, engineers start building distributed applications, where robust remote procedure calls and cluster coordination are a must.

In this course you will learn about common challenges that appear while designing and implementing large scale distributed systems, and how Big-Tech companies solve those problems.

Technologies, algorithms and design patterns covered in this course:

  • Service Registry and Discovery, Service Mesh

  • Apache Cassandra

  • ETCD (coordinator managing Kubernetes clusters)

  • Apache Kafka

  • Idempotent service design, retry logic

  • Sharding and Consistent Hashing

  • Client-side Load Balancing, Distributed Tracing, Canary Deployment, Sidecar Pattern, Circuit Breaker

Course will teach you the principles of various distributed systems design, for example master-less vs. with leaders, poll-based vs. push-based, immediate vs. eventual consistency. After completing the course, learning new distributed database technology would be easier, because you will know the common re-used techniques, including their pros and cons.

My intention is to keep course content very practical, with lots of code examples and applied best practices. For example, I will cover Service Registry and Discovery to the detail, that you will know how to implement your own framework on top of ETCD. Throughout the course, we are going to build distributed URL shorten service.

The course may be a good recap for people preparing for systems design interview.

Reviews

Cezary
October 27, 2022
Great lecture! This course seems to be short but it covers important topics of distributed systems in compact and understandable way without wasting time on trivial things. It is great example how this udemy courses should look like. Lukas, keep going with next lectures!
Sandra
September 19, 2022
This course is unique! Lucas presents difficult challenges of distributed systems in very practical way. I was amazed how those 4 hours enabled me to rethink refactoring of our monolith application into modular micro services. Thank you.
Onkar
August 24, 2022
course is great. i think he needs to include more topic,..course is very small. I will change the rating once I will get reply from trainer
Marcin
July 14, 2022
Distributed systems is a difficult topic. I would recommend watching the course twice, because I could notice much more important details during second time. I give it 5/5, because learned a lot!
Tirlipirli
June 21, 2022
Temat interesujący, ale brakuje mi transkrypcji - wolałabym sobie szybko przeczytać materiał niż słuchać lektora mówiącego po angielsku z polskim akcentem.
Mikołaj
June 3, 2022
Curse material is difficult and I had to go through it twice, but... I got the job as Java developer that I wanted! Watch the content multiple times, you will understand it better every time.
Mark
March 19, 2022
A lot of the slides aren't readable (the one with small pictures scrunched in a corner). The code screen shares are also hard to read at 720p. Would be nice if the class mentioned about having docker and other things preinstalled.
Neeraj
February 20, 2022
Very deep explanation of Kafka and cassandara in context of distributed system. etcd cluster can be bit more easy to understand as it is more complex to understand. As a whole it's a great course to understand distributed, scalable,fault tolerance and resilience system.
Maciek
December 23, 2021
It is a great lecture which brings up all important topics related to distributed applications and systems in one place. Moreover, it tries to find common implementation elements in distributed system component types and explains core algorithms used.
Ivan
December 20, 2021
I still need to complete Kafka part, but so far, explanation of ETCD and Cassandra was clear and useful. I used Cassandra as a cache in one project, but now I gained more understanding of partition and clustering keys. Thanks a lot for hard work putting this lecture together...
Rohit
November 29, 2021
I really liked Distributed Messaging section. I thought, I knew Apache Kafka pretty well, but after the course, I realized some of the internal mechanisms that I have not explored before. I can easily recommend this lecture!
Kinga
November 23, 2021
Training really covers challenges of distributed systems design that pop up in day-to-day job! For me it was a very good recap before taking interview with new company.
Mateusz
November 22, 2021
The lessons were great, simple and very detailed. The course has covered a lot of necessary topics that can happen in most cases when working with distributed systems as an architect or developer. Thank you for the course, Łukasz. Obviously, I will use this knowledge into my work place!
Lukasz
November 19, 2021
I was finally able to understand more complicated concepts, which I have been struggling to grasp for some time, eg. service mesh.
Patryk
November 13, 2021
I really appreciate practical approach taken by the Author. Highly recommended to anyone working in modern IT landscapes.

Charts

Price

Building Modern Distributed Systems with Java - Price chart

Rating

Building Modern Distributed Systems with Java - Ratings chart

Enrollment distribution

Building Modern Distributed Systems with Java - Distribution chart
4369754
udemy ID
10/27/2021
course created date
11/13/2021
course indexed date
Bot
course submited by