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:
- 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.
- Decomposition: ==Functional Decomposition== and Segmentation - Microservices (Y-Axis). e.g. auth service, user profile service, photo service, etc
- 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.