Download 30systems.pps - CMU-CS 15-415/615 Database Applications (Fall

Survey
yes no Was this document useful for you?
   Thank you for your participation!

* Your assessment is very important for improving the workof artificial intelligence, which forms the content of this project

Document related concepts

Signal-flow graph wikipedia , lookup

Corecursion wikipedia , lookup

Transcript
CMU SCS
Carnegie Mellon Univ.
Dept. of Computer Science
15-415/615 - DB Applications
C. Faloutsos – A. Pavlo
Lecture#26: Database Systems
CMU SCS
System Votes
4
2
2
1
1
1
1
Faloutsos/Pavlo
CMU SCS 15-415/615
2
CMU SCS
Two-Phase Commit
OK
Participant
Commit
Request
OK
Application
Server
Node 2
OK
Participant
Coordinator
Phase1: Prepare
Phase2: Commit
OK
Node 1
Faloutsos/Pavlo
Node 3
CMU SCS 15-415/615
3
CMU SCS
Paxos
4
CMU SCS
Paxos
• Consensus protocol where a coordinator
proposes an outcome (e.g., commit or abort)
and then the participants vote on whether
that outcome should succeed.
• Does not block if a majority of participants
are available and has provably minimal
message delays in the best case.
– First correct protocol that was provably
resilient in the face asynchronous networks
Faloutsos/Pavlo
CMU SCS 15-415/615
5
CMU SCS
Paxos
Agree
Accept
Node 2
Agree
Accept
Commit
Node 3
Agree
Accept
Node 1
CMU SCS 15-415/615
Node 4
Acceptor
Proposer
Propose
Acceptor
Application
Server
Faloutsos/Pavlo
Acceptor
Commit
Request
6
CMU SCS
Paxos
Agree
Accept
X
Node 2
Commit
Node 3
Agree
Accept
Node 1
CMU SCS 15-415/615
Node 4
Acceptor
Proposer
Propose
Acceptor
Application
Server
Faloutsos/Pavlo
Acceptor
Commit
Request
7
CMU SCS
Paxos
Proposer
Acceptors
Proposer
Propose(n)
Agree(n)
Propose(n+1)
Commit(n)
Reject(n, n+1)
Agree(n+1)
Commit(n+1)
Accept(n+1)
CMU SCS
2PC vs. Paxos
• 2PC is a degenerate case of Paxos.
– Single coordinator.
– Only works if everybody is up.
• Use leases to determine who is allowed to
propose new updates to avoid continuous
rejection.
Faloutsos/Pavlo
CMU SCS 15-415/615
9
CMU SCS
Google Spanner
• Google’s geo-replicated DBMS (>2011)
• Schematized, semi-relational data model.
• Concurrency Control:
– 2PL + T/O (Pessimistic)
– Externally consistent global write-transactions
with synchronous replication.
– Lock-free read-only transactions.
10
CMU SCS
Google Spanner
CREATE TABLE users {
uid INT NOT NULL,
email VARCHAR,
PRIMARY KEY (uid)
};
CREATE TABLE albums {
uid INT NOT NULL,
aid INT NOT NULL,
name VARCHAR,
PRIMARY KEY (uid, aid)
} INTERLEAVE IN PARENT users
ON DELETE CASCADE;
users(1001)
⤷albums(1001, 9990)
⤷albums(1001, 9991)
users(1002)
⤷albums(1002, 6631)
⤷albums(1002, 6634)
11
CMU SCS
Google Spanner
• Ensures ordering through globally unique
timestamps generated from atomic clocks
and GPS devices.
• Database is broken up into tablets:
– Use Paxos to elect leader in tablet group.
– Use 2PC for txns that span tablets.
• TrueTime API
12
CMU SCS
Google Spanner
Set A=2, B=9
Set A=0, B=7
Application
Server
Application
Server
T1
A=1
T2
NETWORK
B=8
Node 2
Node 1
Paxos or
2PC
13
CMU SCS
Google F1
• OCC engine built on top of Spanner.
– Read phase followed by a write phase
– In the read phase, F1 returns the last modified
timestamp with each row. No locks.
– The timestamp for a row is stored in a hidden
lock column. The client library returns these
timestamps to the F1 server
– If the timestamps differ from the current
timestamps at the time of commit the
transaction is aborted
14
CMU SCS
Redis
• Remote Dictionary Server (2009)
• Key-value data store:
– Values can be strings, hashes, lists, sets and
sorted sets.
– Single-threaded execution engine.
• In-memory storage:
– Snapshots + WAL for persistence.
CMU SCS 15-415/615
15
CMU SCS
Redis
STRING
page:index.html
view_count
→
→
<html><head>…
→
{ 1, 2, 3, 4, 5 }
→
{ 111, 112, 119, … }
→
time => 1430086922
username => tupac
→
odb ~ 11
tupac ~ 12
biggie ~ 19
eazye ~ 20
12345
SET
LIST
latest_post_ids
HASH
user:999:session
SORTED SET
current_user_scores
Values
Keys
users_logged_in
16
CMU SCS
CMU SCS
Redis
• Asynchronous master-slave replication:
– Master sends oplog to downstream replicas.
– Do not wait for acknowledgements.
• Newer version can ensure that at least some
replicas are available before accepting
writes but still not check whether they
received those writes.
CMU SCS 15-415/615
18
CMU SCS
Redis
• Supports some notion of transactions:
– Operations are batched together and executed
serially on server side.
– Allows for compare-and-swap.
• Does not support rollback!
CMU SCS 15-415/615
19
CMU SCS
MongoDB
• Document Data Model
– Think JSON, XML, Python dicts
– Not Microsoft Word documents
• Different terminology:
– Document → Tuple
– Collection → Table/Relation
20
CMU SCS
MongoDB
• JSON-only query API
• Single-document atomicity.
– No server-side joins:
– “Pre-join” collections by embedding related
documents inside of each other.
• No cost-based query planner / optimizer.
21
CMU SCS
MongoDB
• A customer has orders and each order has
order items.
Customers
R1(custId, name, …)
⨝
Orders
R2(orderId, custId, …)
⨝
Order Items
R3(itemId, orderId, …)
22
CMU SCS
MongoDB
• A customer has orders and each order has
order items.
Customers
{ "custId" : 1234,
"custName" : "Christos",
"orders" : [
{ "orderId" : 10001,
"orderItems" : [
{ "itemId" : "XXXX",
"price" : 19.99 },
{ "itemId" : "YYYY",
"price" : 29.99 } ]
},
{ "orderId" : 10050,
"orderItems" : [
{ "itemId" : “ZZZZ",
"price" : 49.99 } ]
} ]
}
Customer
Order
Orders
Order Item
⋮
Order Item
Order Items
23
CMU SCS
MongoDB
• Heterogeneous distributed components.
– Centralized query router.
• Master-slave replication.
• Auto-sharding:
– Define ‘partitioning’ attributes for each
collection (hash or range).
– When a shard gets too big, the DBMS
automatically splits the shard and rebalances.
24
CMU SCS
MongoDB
• Originally used mmap storage manager
– No buffer pool.
– Let the OS decide when to flush pages.
– Single lock per database.
• Version 3 (2015) now supports pluggable
storage managers.
– WiredTiger from BerkeleyDB alumni.
– Fine-grained locking.
25