The Patterns of Scalable, Reliable, and Performant Large-Scale Systems
Go to file
2018-06-10 11:01:06 +08:00
CONTRIBUTING.md Create CONTRIBUTING.md 2017-12-27 11:48:12 +08:00
README.md Unprivileged Container Builds at Kinvolk 2018-06-10 11:01:06 +08:00

High Scalability, High Availability, High Stability, High Performance, and High Intelligence Back-end Designs

An updated and curated list of selected readings to illustrate best practices in building High Scalability, High Availability, High Stability, High Performance, and High Intelligence back-end systems. Concepts are explained in the articles of prominent engineers and credible references. Case studies are taken from battle-tested systems that serve millions to billions of users.

If your back-end went slow 🚥

Understand your problems: scalability problem (fast for a single user but slow under heavy load) or performance problem (slow for a single user) by reviewing some design principles and checking how scalability and performance problems are solved at tech companies. The section of intelligence are created for those who work with data and machine learning at big (data) and deep (learning) scale.

If your back-end went down 🚧

"Even if you lose all one day, you can build all over again if you retain your calm!" - Thuan Pham, Vietnamese refugee, CTO of Uber Technologies Inc. So, keep calm and mind the availability and stability matters!

If you have an incomming System Design interview 🌊

Look at some interview notes and real-world architectures with completed diagrams to get a comprehensive view before designing your system on whiteboard. You can check some talks of engineers from tech giants to know how they build, scale, and optimize their systems. There are some selected books for you (most of them are free)! Good luck 🍀

If you are building your dream team 🎡

The goal of scaling team is not growing team size but increasing team output and value. The organization section shows how tech companies scale their teams in various aspects: hiring, management, organization, culture, communication.

Community Power 🚠🚡🚠

Contributions are greatly welcome! You may want to take a look at the contribution guidelines.

If you find this project helpful, please share on your chat groups, on Twitter, or on Weibo so more people can be helped! Power is gained by sharing knowledge, not hoarding it. Thank you! 🌺

Contents

Principles

Scalability

Availability

Stability

Performance

Intelligence

Architectures

Interview

Organization

Talks

Books

Special Thanks

License

CC-BY

This repo is created and maintained by Binh Nguyen. Feel free to use it at your convenience! Thanks and Happy Coding ❤️