Christian Zommerfelds

D2L

Christian is a software developer with a passion for big data and machine learning problems. At D2L, he and his team is building products using pure managed services such as AWS Lambda and DynamoDB. He has a passion for automating development and deployment pipelines using tools such as Terraform, which strengthens the DevOps model. Christian has a Master’s Degree in Computer Science at EPFL in Switzerland.

When Serverless Gets In the Way of Scalability

In the age of countless cloud service offerings we often live in an idealized bubble where everything can auto-scale infinitely. In particular, serverless computing enables automatic fast provisioning/deprovisioning of server resources. However, scaling your compute power this quickly is not always beneficial and can even break your entire system. For example, storage systems may have fixed capacity; even with auto-scaling, the scaling takes longer time, resulting in unbalanced capacity between computing power and storage. This will make the storage systems the bottlenecks in the system. Therefore, a design without proper capacity management may lead to complete failure of the system under increasing load.

At D2L we have been developing microservices using serveless technologies. In this talk, you will learn: * the challenges we have faced in scaling serverless applications. We will demonstrate real-world examples. * various approaches we used to overcome the scalability challenges, including concurrency limit, backoff and retry and TCP-like congestion control. We will compare the pro. and cons. of each approach and give advice on best practices.