|
Two phase commit Failures in a distributed system
|
tarix | 29.12.2016 | ölçüsü | 489 Kb. | | #3850 |
|
Failures in a distributed system Consistency requires agreement among multiple servers - Is transaction X committed?
- Have all servers applied update X to a replica?
Achieving agreement w/ failures is hard - Impossible to distinguish host vs. network failures
This class: - all-or-nothing atomicity in distributed systems
Example Clients want all-or-nothing transactions - Transfer either happens or not at all
Strawman solution
Strawman solution
Reasoning about correctness TC, A, B each has a notion of committing Correctness: - If one commits, no one aborts
- If one aborts, no one commits
Performance: - If no failures, A and B can commit, then commit
- If failures happen, find out outcome soon
Correctness first
Performance Issues What about timeouts? - TC times out waiting for A’s response
- A times out waiting for TC’s outcome message
What about reboots? - How does a participant clean up?
Handling timeout on A/B TC times out waiting for A (or B)’s “yes/no” response Can TC unilaterally decide to commit? Can TC unilaterally decide to abort?
Handling timeout on TC If B responded with “no” … - Can it unilaterally abort?
If B responded with “yes” … - Can it unilaterally abort?
- Can it unilaterally commit?
Possible termination protocol Execute termination protocol if B times out on TC and has voted “yes” B sends “status” message to A - If A has received “commit”/”abort” from TC …
- If A has not responded to TC, …
- If A has responded with “no”, …
- If A has responded with “yes”, …
Handling crash and reboot Nodes cannot back out if commit is decided TC crashes just after deciding “commit” A/B crashes after sending “yes” - Cannot forget about their response after reboot
Handling crash and reboot All nodes must log protocol progress What and when does TC log to disk? What and when does A/B log to disk?
Recovery upon reboot If TC finds no “commit” on disk, abort If TC finds “commit”, commit If A/B finds no “yes” on disk, abort If A/B finds “yes”, run termination protocol to decide
Summary: two-phase commit All nodes that decide reach the same decision No commit unless everyone says "yes". No failures and all "yes", then commit. If failures, then repair, wait long enough for recovery, then some decision.
What problem is Sinfonia addressing? Targeted uses - systems or infrastructural apps within a data center
Sinfonia: a shared data service - Span multiple nodes
- Replicated with consistency guarantees
Goal: reduce development efforts for system programmers
Sinfonia architecture
Sinfonia mini-transactions Provide all-or-nothing atomic operations - as well as before-after atomicity (using locks)
Trade off expressiveness for efficiency - fewer network roundtrips to execute
- Less flexible, general-purpose than traditional transactions
Result - a lightweight, short-lived type of transaction
- over unstructured data
Mini-transaction details Mini-transaction - Check compare items
- If match, retrieve data in read items, modify data in write items
Example:
Sinfonia uses 2P commit
Potential uses of mini-transactions 1. atomic swap operation 2. atomic read of many data 4. try to acquire multiple leases atomically 5. change data if lease is held 6. validate cache then change data
Sinfonia’s 2P protocol Transaction coordinator is at application node instead of memory node Problems: crashed TC blocks transaction progress - App nodes are less reliable than memory nodes
Sinfonia’s 2P protocol TC keeps no log A transaction is committed iff all participants have “yes” in their logs - Ask all participants for existing vote (or vote “no” if not voted yet)
- Commit iff all vote “yes”
Transaction blocks if a memory node crashes - Must wait for memory node to recovery from disk
Sinfonia applications SinfoniaFS - hosts share the same set of files, files stored in Sinfonia
- scalable: performance improves with more memory nodes
- fault tolerant
SinfoniaFS exports a NFS interface - Each NFS op corresponds to 1 mini-transaction
SinfoniaFS architecture
General use of mini-transaction in SinfoniaFS If local cache is empty, load it Make modifications to local cache Issue a mini-transaction to check the validity of cache, apply modification If mini-transaction fails, reload cached item and try again
More examples: append to file Find a free block in cached freemap Issue mini-transaction with If mini-transaction fails, reload cache
Sinfonia’s mini-transaction is fast
Dostları ilə paylaş: |
|
|