École Polytechnique Fédérale de Lausanne

Programming Reactive Systems

Roland Kuhn
Konrad Malawski
Martin Odersky

Instructors: Roland Kuhn

Access provided by Palo Alto Networks

3,363 already enrolled

Gain insight into a topic and learn the fundamentals.
3.9

(31 reviews)

Intermediate level

Recommended experience

5 weeks to complete
at 10 hours a week
Flexible schedule
Learn at your own pace
Gain insight into a topic and learn the fundamentals.
3.9

(31 reviews)

Intermediate level

Recommended experience

5 weeks to complete
at 10 hours a week
Flexible schedule
Learn at your own pace

What you'll learn

  • Understand how back-pressure controls flows of data

  • Transform and consume infinite and intermittent streams of data with Akka Stream

  • implement systems that can scale out according to a varying workload

  • Design systems resilient to failures

Details to know

Shareable certificate

Add to your LinkedIn profile

Taught in English

See how employees at top companies are mastering in-demand skills

 logos of Petrobras, TATA, Danone, Capgemini, P&G and L'Oreal

There are 7 modules in this course

This module shows you how to get started with the course. After setting up your machine to work on and to submit assignments, it will provide you with a recap of the basics of the Scala language. Finally, you will encounter the first topic of the course, asynchronous programming with Futures.

What's included

5 videos9 readings3 programming assignments

This module presents the Actor model: after analyzing its advantages and strengths, you will learn the semantics and design principles of actor systems before learn how to concretely test actor-based programs

What's included

5 videos2 programming assignments

This module further explores the Actor model by showing useful patterns used to create complex and resilient programs

What's included

3 videos2 programming assignments

Actors allow you to decouple a program in units that can be distributed on a single or on multiple machines. This module elaborates on the power and the consequences of distributed computation

What's included

6 videos

Now that you are familiar with the Actor model, this module shows how to leverage Scala's powerful type system to write programs with more confidence by using typed actor descriptions

What's included

6 videos2 programming assignments

This module introduces the concept of data streams and the basic semantics of stream processing before showing how the Akka framework can be used to tackle common challenges in this domain

What's included

4 videos2 programming assignments

This final module elaborates on more complex and powerful patterns in stream processing as well as how to the integrate the actor model to create custom nodes of data processing

What's included

4 videos2 programming assignments

Instructors

Instructor ratings
3.9 (19 ratings)
Roland Kuhn
École Polytechnique Fédérale de Lausanne
2 Courses4,047 learners
Konrad Malawski
École Polytechnique Fédérale de Lausanne
2 Courses4,047 learners
Martin Odersky
École Polytechnique Fédérale de Lausanne
6 Courses235,356 learners

Why people choose Coursera for their career

Felipe M.
Learner since 2018
"To be able to take courses at my own pace and rhythm has been an amazing experience. I can learn whenever it fits my schedule and mood."
Jennifer J.
Learner since 2020
"I directly applied the concepts and skills I learned from my courses to an exciting new project at work."
Larry W.
Learner since 2021
"When I need courses on topics that my university doesn't offer, Coursera is one of the best places to go."
Chaitanya A.
"Learning isn't just about being better at your job: it's so much more than that. Coursera allows me to learn without limits."

Learner reviews

3.9

31 reviews

  • 5 stars

    48.38%

  • 4 stars

    22.58%

  • 3 stars

    12.90%

  • 2 stars

    6.45%

  • 1 star

    9.67%

Showing 3 of 31

BB
4

Reviewed on Aug 4, 2023

BH
4

Reviewed on Feb 5, 2025

Explore more from Computer Science