Skip to content

Latest commit

 

History

History
23 lines (17 loc) · 1.16 KB

41-how-to-scale-a-web-service.md

File metadata and controls

23 lines (17 loc) · 1.16 KB
layout title date comments categories language references
post
How to scale a web service?
2018-09-11 21:32
true
system design
en

There are three directions to scale a web service:

AKF Scale Cube

  1. Scale out: ==Horizontal Duplication== and Cloning (X-Axis). Having a farm of identical and preferably stateless instances behind a load balancer or reverse proxy. Therefore, every request can be served by any of those hosts and there will be no single point of failure.
  2. Decomposition: ==Functional Decomposition== and Segmentation - Microservices (Y-Axis). e.g. auth service, user profile service, photo service, etc
  3. Sharding: ==Horizontal Data Partitioning== - Shards (Z-Axis). Replicate the whole stack to different “pods”. Each pod can target a specific large group of users. For example, Uber had China and US data centers. Each datacenter might have different “pods” for different regions.

Want an example? Go to see how Facebook scale its social graph data store.