mirror of
https://github.com/donnemartin/system-design-primer.git
synced 2025-01-04 10:28:47 +08:00
Add Federation section
This commit is contained in:
parent
d753508b06
commit
18611be86c
21
README.md
21
README.md
@ -948,3 +948,24 @@ Both masters serve reads and writes and coordinate with each other on writes. I
|
||||
|
||||
* [Scalability, availability, stability, patterns](http://www.slideshare.net/jboner/scalability-availability-stability-patterns/)
|
||||
* [Multi-master replication](https://en.wikipedia.org/wiki/Multi-master_replication)
|
||||
|
||||
#### Federation
|
||||
|
||||
<p align="center">
|
||||
<img src="http://i.imgur.com/U3qV33e.png">
|
||||
<br/>
|
||||
<i><a href=https://www.youtube.com/watch?v=vg5onp8TU6Q>Source: Scaling up to your first 10 million users</a></i>
|
||||
</p>
|
||||
|
||||
Federation (or functional partitioning) splits up databases by function. For example, instead of a single, monolithic database, you could have three databases: **forums**, **users**, and **products**, resulting in less read and write traffic to each database and therefore less replication lag. Smaller databases result in more data that can fit in memory, which in turn results in more cache hits due to improved cache locality. With no single central master serializing writes you can write in parallel, increasing throughput.
|
||||
|
||||
##### Disadvantage(s): federation
|
||||
|
||||
* Federation is not effective if your schema requires huge functions or tables.
|
||||
* You'll need to update your application logic to determine which database to read and write.
|
||||
* Joining data from two databases is more complex with a [server link](http://stackoverflow.com/questions/5145637/querying-data-by-joining-two-tables-in-two-database-on-different-servers).
|
||||
* Federation adds more hardware and additional complexity.
|
||||
|
||||
##### Source(s) and further reading: federation
|
||||
|
||||
* [Scaling up to your first 10 million users](https://www.youtube.com/watch?v=vg5onp8TU6Q)
|
||||
|
Loading…
x
Reference in New Issue
Block a user