SlideShare a Scribd company logo
WiredTiger Internals
2
I'm Excited
3
Benefits
4
Performance!
5
Compression in Action
(Flights database, ht Asya)
6
Agenda
Storage Engine API
WiredTiger Architecture
Overall Benefits
http://www.livingincebuforums.com/ipb/uploads/monthly_10_2011/post-198-0-67871200-1318223706.jpg
Pluggable Storage Engine API
8
MongoDB Architecture
Content
Repo
IoT Sensor
Backend
Ad Service
Customer
Analytics
Archive
MongoDB Query Language (MQL) + Native Drivers
MongoDB Document Data Model
MMAP V1 WT In-Memory ? ?
Supported in MongoDB 3.0 Future Possible Storage Engines
Management
Security
Example Future State
Beta
9
Storage Engine API
•  Allows to "plug-in" different storage engines
–  Different use cases require different performance characteristics
–  mmapv1 is not ideal for all workloads
–  More flexibility
•  Can mix storage engines on same replica set/sharded cluster
•  Opportunity to integrate further ( HDFS, native encrypted, hardware
optimized …)
Storage Engines
2 Storage Engines Available
… and more in the making!
MMAPv1 WiredTiger
12
MongoDB Architecture
Content
Repo
IoT Sensor
Backend
Ad Service
Customer
Analytics
Archive
MongoDB Query Language (MQL) + Native Drivers
MongoDB Document Data Model
MMAP V1 WT In-Memory ? ?
Supported in MongoDB 3.0 Future Possible Storage Engines
Management
Security
Example Future State
Beta
MMAPv1
https://angrytechnician.files.wordpress.com/2009/05/memory.jpg
14
MMAPv1
15
MMAPv1
•  Improved concurrency control
•  Great performance on read-heavy workloads
•  Data & Indexes memory mapped into virtual address space
•  Data access is paged into RAM
•  OS evicts using LRU
•  More frequently used pages stay in RAM
3.0 Default
http://cdn.theatlantic.com/static/infocus/ngt051713/n10_00203194.jpg
WiredTiger
mongod --storageEngine wiredTiger
18
What is WiredTiger?
•  Storage engine company founded by BerkeleyDB alums
•  Recently acquired by MongoDB
•  Available as a storage engine option in MongoDB 3.0
19
Motivation for WiredTiger
•  Take advantage of modern hardware:
–  many CPU cores
–  lots of RAM
•  Minimize contention between threads
–  lock-free algorithms, e.g., hazard pointers
–  eliminate blocking due to concurrency control
•  Hotter cache and more work per I/O
–  compact file formats
–  compression
WiredTiger Architecture
WiredTiger Architecture
WiredTiger Engine
Schema &
Cursors
Python API C API Java API
Database
Files
Transactions
Page
read/write
Logging
Column
storage
Block
management
Row
storage
Snapshots
Log Files
Cache
WiredTiger Sessions
Document Data Model
WiredTiger Engine
Transactions
Snapshosts
Page
read/write
WAL
Cache
Schema &
Cursors
Row
Storage
Block
Management
DB Files Journal
Your App
Driver
connection (mongod)
Session
Cursor
Session
Session
Cursor
Cursor
WiredTiger Sessions
Document Data Model
WiredTiger Engine
Transactions
Snapshosts
Page
read/write
WAL
Cache
Schema &
Cursors
Row
Storage
Block
Management
DB Files Journal
Your App
Driver
•  3 main purposes
•  Schema Operations
•  Transaction Management
•  Cursor Creation
WiredTiger Schema & Cursors
Document Data Model
WiredTiger Engine
Transactions
Snapshosts
Page
read/write
WAL
Cache
Schema &
Cursors
Row
Storage
Block
Management
DB Files Journal
db.createCollection("somecollection")
db.somecollection.drop()
db.somecollection.find({...})
db.somecollection.remove({_id:111})
db.somecollection.stats()
db.somecollection.explain().find({_id:111})
WiredTiger Schema & Cursors
Document Data Model
WiredTiger Engine
Transactions
Snapshosts
Page
read/write
Logging
Cache
Schema &
Cursors
Row
Storage
Block
Management
DB Files Log Files
•  Schema Operations
•  create, drop, truncate, verify …
•  Cursors
•  CRUD
•  Data iteration
•  Statistics
Collection
WiredTiger Transactions
Document Data Model
WiredTiger Engine
Transactions
Snapshosts
Page
read/write
WAL
Cache
Schema &
Cursors
Row
Storage
Block
Management
DB Files Journal
COMMAND INSERT
{
"_id": 111,
"name": "Spock",
"message": "Live Long and Prosper!"
}
Index
{_id: 1}
Index
{name: 1}
Index
{message: "text"}
WiredTiger Transactions
Document Data Model
WiredTiger Engine
Transactions
Snapshosts
Page
read/write
WAL
Cache
Schema &
Cursors
Row
Storage
Block
Management
DB Files Journal
•  Transaction per Session
close, open, commit, rollback
•  Ensures the atomicity/consistency of
MongoDB operations
•  Updates / Writes documents
•  Updates indexes
This is not multi-document
transaction support!
In-memory Performance
Traditional B+tree (ht wikipedia)
Trees in cache
non-resident
child
ordinary pointer
root page
internal
page
internal
page
root page
leaf page
leaf page leaf page leaf page
Cache
Page in Disk
root page
leaf page
Disk
Page not in
memory
File Read
Cache
Page in Memory
root page
Internal Page
Internal Page
Internal Page
Internal Page
Leaf Page Leaf Page Leaf Page Leaf Page
Traditional B-tree
root page
Internal Page
Internal Page
Internal Page
Internal Page
Leaf Page Leaf Page Leaf Page Leaf Page
Deadlock Avoidance
root page
Internal Page
Internal Page
Internal Page
Internal Page
Leaf Page Leaf Page Leaf Page Leaf Page
Cache
Page in Memory
root page
Internal Page
Internal Page
Internal Page
Internal Page
Leaf Page Leaf Page Leaf Page Leaf Page
Doc1Doc0 Doc5Doc2 Doc3 Doc4
Writer
Reader
Standard
pointers
between
tree levels
instead of
traditional
files system
offset
pointers
Page in Cache
Disk
Page images
Page images
Page images
on-disk Page
Image
index
Update
on-disk Page
Image
index
Updates
db.collection.insert( {"_id": 123})
Clean
Page
Dirty
Page
Eviction
Thread
Page in Cache
Disk
Page images
Page images
Page images
on-disk Page
Image
index
Update
on-disk Page
Image
index
Updates
db.collection.insert( {"_id": 123})
Clean
Page
Dirty
Page
Index is build
during read
Page in Cache
Disk
Page images
Page images
Page images
on-disk Page
Image
index
Updates'
db.collection.insert( {"_id": 123})
Dirty
Page
Updates are
held in a skip
list Updates''
db.collection.insert( {"_id": 125})
Updates'''
db.collection.insert( {"_id": 124})
Time
Reconciliation
Disk
Page images
Page images
Page images
on-disk Page
Image
index
Updates'
Dirty
Page
Eviction
Thread
Updates''
Updates'''
Reconciliation
Cache full
After X operations
On a checkpoint
40
In-memory performance
•  Trees in cache are optimized for in-memory access
•  Follow pointers to traverse a tree
– no locking to access pages in cache
•  Keep updates separate from clean data
•  Do structural changes (eviction, splits) in background threads
41
Takeaways
•  Page and tree access is optimized
•  Allows concurrent operations – updates skip lists
•  Tuning options that you should be aware of:
–  storage.wiredTiger.engineConfig.cacheSizeGB
•  You can determine the space allocated for your cache
•  Makes your deployment and sizing more predictable
https://docs.mongodb.org/manual/reference/configuration-options/#storage.wiredTiger.engineConfig.cacheSizeGB
Wiredtiger cache! MongoDB
uses more memory than just
the Storage Engine needs!
Document-level Concurrency
43
What is Concurrency Control?
•  Computers have
– multiple CPU cores
– multiple I/O paths
•  To make the most of the hardware, software has to execute
multiple operations in parallel
•  Concurrency control has to keep data consistent
•  Common approaches:
– locking
– keeping multiple versions of data (MVCC)
MVCC
on-disk Page
Image
index
WRITE B txn(1)
Updates'''Updates'
WRITE A txn(2)
Updates''
Time
WRITE A txn(3)
Conflict
Detection!
45
Multiversion Concurrency Control (MVCC)
•  Multiple versions of records kept in cache
•  Readers see the committed version before the transaction started
– MongoDB “yields” turn large operations into small transactions
•  Writers can create new versions concurrent with readers
•  Concurrent updates to a single record cause write conflicts
– MongoDB retries with back-off
MVCC
on-disk Page
Image
index
Updates'
WRITE B txn(1)
Updates''
Updates'''
WRITE A txn(2)
Time
WRITE A
txn(3)
READ A
Compression
48
WiredTiger Page IO
Document Data Model
WiredTiger Engine
Transactions
Snapshosts
Page
read/write
WAL
Cache
Schema &
Cursors
Row
Storage
Block
Management
DB Files Journal
on-disk Page
Image
index
Updates'''
Disk
Page
Reconciliation
Page Allocation
Splitting
49
WiredTiger Page IO
Document Data Model
WiredTiger Engine
Transactions
Snapshosts
Page
read/write
WAL
Cache
Schema &
Cursors
Row
Storage
Block
Management
DB Files Journal
on-disk Page
Image
index
Updates'''
Disk
Page'
Reconciliation
Page Allocation
Splitting
Page''
50
WiredTiger Page IO
Document Data Model
WiredTiger Engine
Transactions
Snapshosts
Page
read/write
WAL
Cache
Schema &
Cursors
Row
Storage
Block
Management
DB Files Journal
on-disk Page
Image
index
Updates'''
Disk
Reconciliation
Page Allocation
Splitting
Page
Compression
-  snappy (default)
-  zlib
-  none
51
Compression
•  WiredTiger uses snappy compression by default in MongoDB
•  Supported compression algorithms:
–  snappy [default]: good compression, low overhead
–  zlib: better compression, more CPU
–  none
•  Indexes also use prefix compression
–  stays compressed in memory
52
Checksums
•  A checksum is stored with every uncompressed page
•  Checksums are validated during page read
–  detects filesystem corruption, random bitflips
•  WiredTiger stores the checksum with the page address (typically
in a parent page)
–  extra safety against reading a stale page image
53
Compression in Action
(Flights database, ht Asya)
54
Takeaway
•  Main feature that impacts the vast majority of MongoDB projects / use cases
•  CPU bound
•  Different algorithms for different workloads
–  Collection level compression tuning
•  Smaller Data Faster IO
–  Not only improves the disk space footprint
–  also IO
–  and index traversing
Other Gems of WiredTiger
56
Index per Directory
•  Use different drives for collections and indexes
–  Parallelization of write operations
–  MMAPv1 only allows directoryPerDatabase
mongod
Collection A
Index
"name
"
Collection B
Index
"_id"
57
Consistency without Journaling
•  MMAPv1 uses write-ahead log (journal) to guarantee consistency
•  WT doesn't have this need: no in-place updates
–  Write-ahead log committed at checkpoints and with j:true
–  Better for insert-heavy workloads
–  By default journaling is enabled!
•  Replication guarantees the durability
What's Next
59
60
What’s next for WiredTiger?
•  Tune for (many) more workloads
– avoid stalls during checkpoints with 100GB+ caches
– make capped collections (including oplog) more efficient
•  Adding encryption
•  More advanced transactional semantics in the storage engine API
61
Updates and Upgrades
•  Can not
–  Can't copy database files
–  Can't just restart w/ same dbpath
•  Yes we can!
–  Initial sync from replica set works perfectly!
–  mongodump/restore
•  Rolling upgrade of replica set to WT:
–  Shutdown secondary
–  Delete dbpath
–  Relaunch w/ --storageEngine=wiredTiger
–  Wait for resync
–  Rollover
https://tingbudongchine.files.wordpress.com/2012/08/lemonde1.jpeg
Summary
63
MongoDB 3.0
•  Pluggable Storage Engine API
•  Storage Engines
•  Large Replica Sets
•  Big Polygon
•  Security Enhancements – SCRAM
•  Audit Trail
•  Simplified Operations – Ops Manager
•  Tools Rewrite
64
3.2 is coming!
65
Performance!
http://www.mongodb.com/lp/white-paper/benchmark-report
http://cl.jroo.me/z3/v/D/C/e/a.baa-Too-many-bicycles-on-the-van.jpg
Norberto Leite
Technical Evangelist
norberto@mongodb.com
@nleite
Obrigado!

More Related Content

What's hot

The Apache Spark File Format Ecosystem
The Apache Spark File Format EcosystemThe Apache Spark File Format Ecosystem
The Apache Spark File Format Ecosystem
Databricks
 
The columnar roadmap: Apache Parquet and Apache Arrow
The columnar roadmap: Apache Parquet and Apache ArrowThe columnar roadmap: Apache Parquet and Apache Arrow
The columnar roadmap: Apache Parquet and Apache Arrow
DataWorks Summit
 
PostgreSQL and Benchmarks
PostgreSQL and BenchmarksPostgreSQL and Benchmarks
PostgreSQL and Benchmarks
Jignesh Shah
 
Introduction to MongoDB
Introduction to MongoDBIntroduction to MongoDB
Introduction to MongoDB
Dineesha Suraweera
 
MongodB Internals
MongodB InternalsMongodB Internals
MongodB Internals
Norberto Leite
 
Postgresql database administration volume 1
Postgresql database administration volume 1Postgresql database administration volume 1
Postgresql database administration volume 1
Federico Campoli
 
RocksDB detail
RocksDB detailRocksDB detail
RocksDB detail
MIJIN AN
 
MySQL Advanced Administrator 2021 - 네오클로바
MySQL Advanced Administrator 2021 - 네오클로바MySQL Advanced Administrator 2021 - 네오클로바
MySQL Advanced Administrator 2021 - 네오클로바
NeoClova
 
MySQL Administrator 2021 - 네오클로바
MySQL Administrator 2021 - 네오클로바MySQL Administrator 2021 - 네오클로바
MySQL Administrator 2021 - 네오클로바
NeoClova
 
The Full MySQL and MariaDB Parallel Replication Tutorial
The Full MySQL and MariaDB Parallel Replication TutorialThe Full MySQL and MariaDB Parallel Replication Tutorial
The Full MySQL and MariaDB Parallel Replication Tutorial
Jean-François Gagné
 
OLTP+OLAP=HTAP
 OLTP+OLAP=HTAP OLTP+OLAP=HTAP
OLTP+OLAP=HTAP
EDB
 
Mongo db intro.pptx
Mongo db intro.pptxMongo db intro.pptx
Mongo db intro.pptx
JWORKS powered by Ordina
 
MongoDB Memory Management Demystified
MongoDB Memory Management DemystifiedMongoDB Memory Management Demystified
MongoDB Memory Management DemystifiedMongoDB
 
An Enterprise Architect's View of MongoDB
An Enterprise Architect's View of MongoDBAn Enterprise Architect's View of MongoDB
An Enterprise Architect's View of MongoDB
MongoDB
 
Mongo DB
Mongo DB Mongo DB
From cache to in-memory data grid. Introduction to Hazelcast.
From cache to in-memory data grid. Introduction to Hazelcast.From cache to in-memory data grid. Introduction to Hazelcast.
From cache to in-memory data grid. Introduction to Hazelcast.
Taras Matyashovsky
 
RocksDB Performance and Reliability Practices
RocksDB Performance and Reliability PracticesRocksDB Performance and Reliability Practices
RocksDB Performance and Reliability Practices
Yoshinori Matsunobu
 
mongodb와 mysql의 CRUD 연산의 성능 비교
mongodb와 mysql의 CRUD 연산의 성능 비교mongodb와 mysql의 CRUD 연산의 성능 비교
mongodb와 mysql의 CRUD 연산의 성능 비교Woo Yeong Choi
 
Modeling Data and Queries for Wide Column NoSQL
Modeling Data and Queries for Wide Column NoSQLModeling Data and Queries for Wide Column NoSQL
Modeling Data and Queries for Wide Column NoSQL
ScyllaDB
 
Mongodb basics and architecture
Mongodb basics and architectureMongodb basics and architecture
Mongodb basics and architecture
Bishal Khanal
 

What's hot (20)

The Apache Spark File Format Ecosystem
The Apache Spark File Format EcosystemThe Apache Spark File Format Ecosystem
The Apache Spark File Format Ecosystem
 
The columnar roadmap: Apache Parquet and Apache Arrow
The columnar roadmap: Apache Parquet and Apache ArrowThe columnar roadmap: Apache Parquet and Apache Arrow
The columnar roadmap: Apache Parquet and Apache Arrow
 
PostgreSQL and Benchmarks
PostgreSQL and BenchmarksPostgreSQL and Benchmarks
PostgreSQL and Benchmarks
 
Introduction to MongoDB
Introduction to MongoDBIntroduction to MongoDB
Introduction to MongoDB
 
MongodB Internals
MongodB InternalsMongodB Internals
MongodB Internals
 
Postgresql database administration volume 1
Postgresql database administration volume 1Postgresql database administration volume 1
Postgresql database administration volume 1
 
RocksDB detail
RocksDB detailRocksDB detail
RocksDB detail
 
MySQL Advanced Administrator 2021 - 네오클로바
MySQL Advanced Administrator 2021 - 네오클로바MySQL Advanced Administrator 2021 - 네오클로바
MySQL Advanced Administrator 2021 - 네오클로바
 
MySQL Administrator 2021 - 네오클로바
MySQL Administrator 2021 - 네오클로바MySQL Administrator 2021 - 네오클로바
MySQL Administrator 2021 - 네오클로바
 
The Full MySQL and MariaDB Parallel Replication Tutorial
The Full MySQL and MariaDB Parallel Replication TutorialThe Full MySQL and MariaDB Parallel Replication Tutorial
The Full MySQL and MariaDB Parallel Replication Tutorial
 
OLTP+OLAP=HTAP
 OLTP+OLAP=HTAP OLTP+OLAP=HTAP
OLTP+OLAP=HTAP
 
Mongo db intro.pptx
Mongo db intro.pptxMongo db intro.pptx
Mongo db intro.pptx
 
MongoDB Memory Management Demystified
MongoDB Memory Management DemystifiedMongoDB Memory Management Demystified
MongoDB Memory Management Demystified
 
An Enterprise Architect's View of MongoDB
An Enterprise Architect's View of MongoDBAn Enterprise Architect's View of MongoDB
An Enterprise Architect's View of MongoDB
 
Mongo DB
Mongo DB Mongo DB
Mongo DB
 
From cache to in-memory data grid. Introduction to Hazelcast.
From cache to in-memory data grid. Introduction to Hazelcast.From cache to in-memory data grid. Introduction to Hazelcast.
From cache to in-memory data grid. Introduction to Hazelcast.
 
RocksDB Performance and Reliability Practices
RocksDB Performance and Reliability PracticesRocksDB Performance and Reliability Practices
RocksDB Performance and Reliability Practices
 
mongodb와 mysql의 CRUD 연산의 성능 비교
mongodb와 mysql의 CRUD 연산의 성능 비교mongodb와 mysql의 CRUD 연산의 성능 비교
mongodb와 mysql의 CRUD 연산의 성능 비교
 
Modeling Data and Queries for Wide Column NoSQL
Modeling Data and Queries for Wide Column NoSQLModeling Data and Queries for Wide Column NoSQL
Modeling Data and Queries for Wide Column NoSQL
 
Mongodb basics and architecture
Mongodb basics and architectureMongodb basics and architecture
Mongodb basics and architecture
 

Similar to MongoDB WiredTiger Internals

WiredTiger & What's New in 3.0
WiredTiger & What's New in 3.0WiredTiger & What's New in 3.0
WiredTiger & What's New in 3.0
MongoDB
 
MongoDB Evenings DC: Get MEAN and Lean with Docker and Kubernetes
MongoDB Evenings DC: Get MEAN and Lean with Docker and KubernetesMongoDB Evenings DC: Get MEAN and Lean with Docker and Kubernetes
MongoDB Evenings DC: Get MEAN and Lean with Docker and Kubernetes
MongoDB
 
Dynamodb Presentation
Dynamodb PresentationDynamodb Presentation
Dynamodb Presentation
advaitdeo
 
Configuring workload-based storage and topologies
Configuring workload-based storage and topologiesConfiguring workload-based storage and topologies
Configuring workload-based storage and topologies
MariaDB plc
 
Azure: Lessons From The Field
Azure: Lessons From The FieldAzure: Lessons From The Field
Azure: Lessons From The Field
Rob Gillen
 
A Technical Deep Dive on Protecting Acropolis Workloads with Rubrik
A Technical Deep Dive on Protecting Acropolis Workloads with RubrikA Technical Deep Dive on Protecting Acropolis Workloads with Rubrik
A Technical Deep Dive on Protecting Acropolis Workloads with Rubrik
NEXTtour
 
Improving web site performance and scalability while saving
Improving web site performance and scalability while savingImproving web site performance and scalability while saving
Improving web site performance and scalability while savingmdc11
 
MongoDB World 2016: Get MEAN and Lean with MongoDB and Kubernetes
MongoDB World 2016: Get MEAN and Lean with MongoDB and KubernetesMongoDB World 2016: Get MEAN and Lean with MongoDB and Kubernetes
MongoDB World 2016: Get MEAN and Lean with MongoDB and Kubernetes
MongoDB
 
Sharepoint Performance - part 2
Sharepoint Performance - part 2Sharepoint Performance - part 2
Sharepoint Performance - part 2Regroove
 
Rdbms
Rdbms Rdbms
Bquery Reporting & Analytics Architecture
Bquery Reporting & Analytics ArchitectureBquery Reporting & Analytics Architecture
Bquery Reporting & Analytics Architecture
Carst Vaartjes
 
AWS Analytics
AWS AnalyticsAWS Analytics
AWS Analytics
Amazon Web Services
 
Using MongoDB to Build a Fast and Scalable Content Repository
Using MongoDB to Build a Fast and Scalable Content RepositoryUsing MongoDB to Build a Fast and Scalable Content Repository
Using MongoDB to Build a Fast and Scalable Content Repository
MongoDB
 
Dynamo DB & RDS Deep Dive - AWS India Summit 2012
Dynamo DB & RDS Deep Dive - AWS India Summit 2012Dynamo DB & RDS Deep Dive - AWS India Summit 2012
Dynamo DB & RDS Deep Dive - AWS India Summit 2012
Amazon Web Services
 
thinking in key value stores
thinking in key value storesthinking in key value stores
thinking in key value stores
Bhasker Kode
 
Top 8 WCM Trends 2010
Top 8 WCM Trends 2010Top 8 WCM Trends 2010
Top 8 WCM Trends 2010
David Nuescheler
 
TechEd NZ 2014: Azure and Sharepoint
TechEd NZ 2014: Azure and SharepointTechEd NZ 2014: Azure and Sharepoint
TechEd NZ 2014: Azure and Sharepoint
Intergen
 
01 - Web Programming Intro.pptx
01 - Web Programming Intro.pptx01 - Web Programming Intro.pptx
01 - Web Programming Intro.pptx
Karina González
 
MongoDB 3.4 webinar
MongoDB 3.4 webinarMongoDB 3.4 webinar
MongoDB 3.4 webinar
Andrew Morgan
 
Silverlight Development & The Model-View-ViewModel Pattern
Silverlight Development & The Model-View-ViewModel PatternSilverlight Development & The Model-View-ViewModel Pattern
Silverlight Development & The Model-View-ViewModel Pattern
Derek Novavi
 

Similar to MongoDB WiredTiger Internals (20)

WiredTiger & What's New in 3.0
WiredTiger & What's New in 3.0WiredTiger & What's New in 3.0
WiredTiger & What's New in 3.0
 
MongoDB Evenings DC: Get MEAN and Lean with Docker and Kubernetes
MongoDB Evenings DC: Get MEAN and Lean with Docker and KubernetesMongoDB Evenings DC: Get MEAN and Lean with Docker and Kubernetes
MongoDB Evenings DC: Get MEAN and Lean with Docker and Kubernetes
 
Dynamodb Presentation
Dynamodb PresentationDynamodb Presentation
Dynamodb Presentation
 
Configuring workload-based storage and topologies
Configuring workload-based storage and topologiesConfiguring workload-based storage and topologies
Configuring workload-based storage and topologies
 
Azure: Lessons From The Field
Azure: Lessons From The FieldAzure: Lessons From The Field
Azure: Lessons From The Field
 
A Technical Deep Dive on Protecting Acropolis Workloads with Rubrik
A Technical Deep Dive on Protecting Acropolis Workloads with RubrikA Technical Deep Dive on Protecting Acropolis Workloads with Rubrik
A Technical Deep Dive on Protecting Acropolis Workloads with Rubrik
 
Improving web site performance and scalability while saving
Improving web site performance and scalability while savingImproving web site performance and scalability while saving
Improving web site performance and scalability while saving
 
MongoDB World 2016: Get MEAN and Lean with MongoDB and Kubernetes
MongoDB World 2016: Get MEAN and Lean with MongoDB and KubernetesMongoDB World 2016: Get MEAN and Lean with MongoDB and Kubernetes
MongoDB World 2016: Get MEAN and Lean with MongoDB and Kubernetes
 
Sharepoint Performance - part 2
Sharepoint Performance - part 2Sharepoint Performance - part 2
Sharepoint Performance - part 2
 
Rdbms
Rdbms Rdbms
Rdbms
 
Bquery Reporting & Analytics Architecture
Bquery Reporting & Analytics ArchitectureBquery Reporting & Analytics Architecture
Bquery Reporting & Analytics Architecture
 
AWS Analytics
AWS AnalyticsAWS Analytics
AWS Analytics
 
Using MongoDB to Build a Fast and Scalable Content Repository
Using MongoDB to Build a Fast and Scalable Content RepositoryUsing MongoDB to Build a Fast and Scalable Content Repository
Using MongoDB to Build a Fast and Scalable Content Repository
 
Dynamo DB & RDS Deep Dive - AWS India Summit 2012
Dynamo DB & RDS Deep Dive - AWS India Summit 2012Dynamo DB & RDS Deep Dive - AWS India Summit 2012
Dynamo DB & RDS Deep Dive - AWS India Summit 2012
 
thinking in key value stores
thinking in key value storesthinking in key value stores
thinking in key value stores
 
Top 8 WCM Trends 2010
Top 8 WCM Trends 2010Top 8 WCM Trends 2010
Top 8 WCM Trends 2010
 
TechEd NZ 2014: Azure and Sharepoint
TechEd NZ 2014: Azure and SharepointTechEd NZ 2014: Azure and Sharepoint
TechEd NZ 2014: Azure and Sharepoint
 
01 - Web Programming Intro.pptx
01 - Web Programming Intro.pptx01 - Web Programming Intro.pptx
01 - Web Programming Intro.pptx
 
MongoDB 3.4 webinar
MongoDB 3.4 webinarMongoDB 3.4 webinar
MongoDB 3.4 webinar
 
Silverlight Development & The Model-View-ViewModel Pattern
Silverlight Development & The Model-View-ViewModel PatternSilverlight Development & The Model-View-ViewModel Pattern
Silverlight Development & The Model-View-ViewModel Pattern
 

More from Norberto Leite

Data Modelling for MongoDB - MongoDB.local Tel Aviv
Data Modelling for MongoDB - MongoDB.local Tel AvivData Modelling for MongoDB - MongoDB.local Tel Aviv
Data Modelling for MongoDB - MongoDB.local Tel Aviv
Norberto Leite
 
Avoid Query Pitfalls
Avoid Query PitfallsAvoid Query Pitfalls
Avoid Query Pitfalls
Norberto Leite
 
MongoDB and Spark
MongoDB and SparkMongoDB and Spark
MongoDB and Spark
Norberto Leite
 
Mongo db 3.4 Overview
Mongo db 3.4 OverviewMongo db 3.4 Overview
Mongo db 3.4 Overview
Norberto Leite
 
MongoDB Certification Study Group - May 2016
MongoDB Certification Study Group - May 2016MongoDB Certification Study Group - May 2016
MongoDB Certification Study Group - May 2016
Norberto Leite
 
Geospatial and MongoDB
Geospatial and MongoDBGeospatial and MongoDB
Geospatial and MongoDB
Norberto Leite
 
MongoDB 3.2 Feature Preview
MongoDB 3.2 Feature PreviewMongoDB 3.2 Feature Preview
MongoDB 3.2 Feature Preview
Norberto Leite
 
Mongodb Spring
Mongodb SpringMongodb Spring
Mongodb Spring
Norberto Leite
 
MongoDB on Azure
MongoDB on AzureMongoDB on Azure
MongoDB on Azure
Norberto Leite
 
MongoDB: Agile Combustion Engine
MongoDB: Agile Combustion EngineMongoDB: Agile Combustion Engine
MongoDB: Agile Combustion Engine
Norberto Leite
 
MongoDB Capacity Planning
MongoDB Capacity PlanningMongoDB Capacity Planning
MongoDB Capacity Planning
Norberto Leite
 
Spark and MongoDB
Spark and MongoDBSpark and MongoDB
Spark and MongoDB
Norberto Leite
 
Analyse Yourself
Analyse YourselfAnalyse Yourself
Analyse Yourself
Norberto Leite
 
Python and MongoDB
Python and MongoDB Python and MongoDB
Python and MongoDB
Norberto Leite
 
Strongly Typed Languages and Flexible Schemas
Strongly Typed Languages and Flexible SchemasStrongly Typed Languages and Flexible Schemas
Strongly Typed Languages and Flexible Schemas
Norberto Leite
 
Effectively Deploying MongoDB on AEM
Effectively Deploying MongoDB on AEMEffectively Deploying MongoDB on AEM
Effectively Deploying MongoDB on AEM
Norberto Leite
 
Advanced applications with MongoDB
Advanced applications with MongoDBAdvanced applications with MongoDB
Advanced applications with MongoDB
Norberto Leite
 
MongoDB and Node.js
MongoDB and Node.jsMongoDB and Node.js
MongoDB and Node.js
Norberto Leite
 
MongoDB + Spring
MongoDB + SpringMongoDB + Spring
MongoDB + Spring
Norberto Leite
 
MongoDB on Financial Services Sector
MongoDB on Financial Services SectorMongoDB on Financial Services Sector
MongoDB on Financial Services Sector
Norberto Leite
 

More from Norberto Leite (20)

Data Modelling for MongoDB - MongoDB.local Tel Aviv
Data Modelling for MongoDB - MongoDB.local Tel AvivData Modelling for MongoDB - MongoDB.local Tel Aviv
Data Modelling for MongoDB - MongoDB.local Tel Aviv
 
Avoid Query Pitfalls
Avoid Query PitfallsAvoid Query Pitfalls
Avoid Query Pitfalls
 
MongoDB and Spark
MongoDB and SparkMongoDB and Spark
MongoDB and Spark
 
Mongo db 3.4 Overview
Mongo db 3.4 OverviewMongo db 3.4 Overview
Mongo db 3.4 Overview
 
MongoDB Certification Study Group - May 2016
MongoDB Certification Study Group - May 2016MongoDB Certification Study Group - May 2016
MongoDB Certification Study Group - May 2016
 
Geospatial and MongoDB
Geospatial and MongoDBGeospatial and MongoDB
Geospatial and MongoDB
 
MongoDB 3.2 Feature Preview
MongoDB 3.2 Feature PreviewMongoDB 3.2 Feature Preview
MongoDB 3.2 Feature Preview
 
Mongodb Spring
Mongodb SpringMongodb Spring
Mongodb Spring
 
MongoDB on Azure
MongoDB on AzureMongoDB on Azure
MongoDB on Azure
 
MongoDB: Agile Combustion Engine
MongoDB: Agile Combustion EngineMongoDB: Agile Combustion Engine
MongoDB: Agile Combustion Engine
 
MongoDB Capacity Planning
MongoDB Capacity PlanningMongoDB Capacity Planning
MongoDB Capacity Planning
 
Spark and MongoDB
Spark and MongoDBSpark and MongoDB
Spark and MongoDB
 
Analyse Yourself
Analyse YourselfAnalyse Yourself
Analyse Yourself
 
Python and MongoDB
Python and MongoDB Python and MongoDB
Python and MongoDB
 
Strongly Typed Languages and Flexible Schemas
Strongly Typed Languages and Flexible SchemasStrongly Typed Languages and Flexible Schemas
Strongly Typed Languages and Flexible Schemas
 
Effectively Deploying MongoDB on AEM
Effectively Deploying MongoDB on AEMEffectively Deploying MongoDB on AEM
Effectively Deploying MongoDB on AEM
 
Advanced applications with MongoDB
Advanced applications with MongoDBAdvanced applications with MongoDB
Advanced applications with MongoDB
 
MongoDB and Node.js
MongoDB and Node.jsMongoDB and Node.js
MongoDB and Node.js
 
MongoDB + Spring
MongoDB + SpringMongoDB + Spring
MongoDB + Spring
 
MongoDB on Financial Services Sector
MongoDB on Financial Services SectorMongoDB on Financial Services Sector
MongoDB on Financial Services Sector
 

Recently uploaded

Beyond Event Sourcing - Embracing CRUD for Wix Platform - Java.IL
Beyond Event Sourcing - Embracing CRUD for Wix Platform - Java.ILBeyond Event Sourcing - Embracing CRUD for Wix Platform - Java.IL
Beyond Event Sourcing - Embracing CRUD for Wix Platform - Java.IL
Natan Silnitsky
 
Navigating the Metaverse: A Journey into Virtual Evolution"
Navigating the Metaverse: A Journey into Virtual Evolution"Navigating the Metaverse: A Journey into Virtual Evolution"
Navigating the Metaverse: A Journey into Virtual Evolution"
Donna Lenk
 
Globus Compute wth IRI Workflows - GlobusWorld 2024
Globus Compute wth IRI Workflows - GlobusWorld 2024Globus Compute wth IRI Workflows - GlobusWorld 2024
Globus Compute wth IRI Workflows - GlobusWorld 2024
Globus
 
Dominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdf
Dominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdfDominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdf
Dominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdf
AMB-Review
 
How Recreation Management Software Can Streamline Your Operations.pptx
How Recreation Management Software Can Streamline Your Operations.pptxHow Recreation Management Software Can Streamline Your Operations.pptx
How Recreation Management Software Can Streamline Your Operations.pptx
wottaspaceseo
 
Large Language Models and the End of Programming
Large Language Models and the End of ProgrammingLarge Language Models and the End of Programming
Large Language Models and the End of Programming
Matt Welsh
 
Enterprise Resource Planning System in Telangana
Enterprise Resource Planning System in TelanganaEnterprise Resource Planning System in Telangana
Enterprise Resource Planning System in Telangana
NYGGS Automation Suite
 
AI Pilot Review: The World’s First Virtual Assistant Marketing Suite
AI Pilot Review: The World’s First Virtual Assistant Marketing SuiteAI Pilot Review: The World’s First Virtual Assistant Marketing Suite
AI Pilot Review: The World’s First Virtual Assistant Marketing Suite
Google
 
top nidhi software solution freedownload
top nidhi software solution freedownloadtop nidhi software solution freedownload
top nidhi software solution freedownload
vrstrong314
 
May Marketo Masterclass, London MUG May 22 2024.pdf
May Marketo Masterclass, London MUG May 22 2024.pdfMay Marketo Masterclass, London MUG May 22 2024.pdf
May Marketo Masterclass, London MUG May 22 2024.pdf
Adele Miller
 
A Sighting of filterA in Typelevel Rite of Passage
A Sighting of filterA in Typelevel Rite of PassageA Sighting of filterA in Typelevel Rite of Passage
A Sighting of filterA in Typelevel Rite of Passage
Philip Schwarz
 
Orion Context Broker introduction 20240604
Orion Context Broker introduction 20240604Orion Context Broker introduction 20240604
Orion Context Broker introduction 20240604
Fermin Galan
 
Corporate Management | Session 3 of 3 | Tendenci AMS
Corporate Management | Session 3 of 3 | Tendenci AMSCorporate Management | Session 3 of 3 | Tendenci AMS
Corporate Management | Session 3 of 3 | Tendenci AMS
Tendenci - The Open Source AMS (Association Management Software)
 
Accelerate Enterprise Software Engineering with Platformless
Accelerate Enterprise Software Engineering with PlatformlessAccelerate Enterprise Software Engineering with Platformless
Accelerate Enterprise Software Engineering with Platformless
WSO2
 
Quarkus Hidden and Forbidden Extensions
Quarkus Hidden and Forbidden ExtensionsQuarkus Hidden and Forbidden Extensions
Quarkus Hidden and Forbidden Extensions
Max Andersen
 
Innovating Inference - Remote Triggering of Large Language Models on HPC Clus...
Innovating Inference - Remote Triggering of Large Language Models on HPC Clus...Innovating Inference - Remote Triggering of Large Language Models on HPC Clus...
Innovating Inference - Remote Triggering of Large Language Models on HPC Clus...
Globus
 
Understanding Globus Data Transfers with NetSage
Understanding Globus Data Transfers with NetSageUnderstanding Globus Data Transfers with NetSage
Understanding Globus Data Transfers with NetSage
Globus
 
How to Position Your Globus Data Portal for Success Ten Good Practices
How to Position Your Globus Data Portal for Success Ten Good PracticesHow to Position Your Globus Data Portal for Success Ten Good Practices
How to Position Your Globus Data Portal for Success Ten Good Practices
Globus
 
RISE with SAP and Journey to the Intelligent Enterprise
RISE with SAP and Journey to the Intelligent EnterpriseRISE with SAP and Journey to the Intelligent Enterprise
RISE with SAP and Journey to the Intelligent Enterprise
Srikant77
 
Graphic Design Crash Course for beginners
Graphic Design Crash Course for beginnersGraphic Design Crash Course for beginners
Graphic Design Crash Course for beginners
e20449
 

Recently uploaded (20)

Beyond Event Sourcing - Embracing CRUD for Wix Platform - Java.IL
Beyond Event Sourcing - Embracing CRUD for Wix Platform - Java.ILBeyond Event Sourcing - Embracing CRUD for Wix Platform - Java.IL
Beyond Event Sourcing - Embracing CRUD for Wix Platform - Java.IL
 
Navigating the Metaverse: A Journey into Virtual Evolution"
Navigating the Metaverse: A Journey into Virtual Evolution"Navigating the Metaverse: A Journey into Virtual Evolution"
Navigating the Metaverse: A Journey into Virtual Evolution"
 
Globus Compute wth IRI Workflows - GlobusWorld 2024
Globus Compute wth IRI Workflows - GlobusWorld 2024Globus Compute wth IRI Workflows - GlobusWorld 2024
Globus Compute wth IRI Workflows - GlobusWorld 2024
 
Dominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdf
Dominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdfDominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdf
Dominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdf
 
How Recreation Management Software Can Streamline Your Operations.pptx
How Recreation Management Software Can Streamline Your Operations.pptxHow Recreation Management Software Can Streamline Your Operations.pptx
How Recreation Management Software Can Streamline Your Operations.pptx
 
Large Language Models and the End of Programming
Large Language Models and the End of ProgrammingLarge Language Models and the End of Programming
Large Language Models and the End of Programming
 
Enterprise Resource Planning System in Telangana
Enterprise Resource Planning System in TelanganaEnterprise Resource Planning System in Telangana
Enterprise Resource Planning System in Telangana
 
AI Pilot Review: The World’s First Virtual Assistant Marketing Suite
AI Pilot Review: The World’s First Virtual Assistant Marketing SuiteAI Pilot Review: The World’s First Virtual Assistant Marketing Suite
AI Pilot Review: The World’s First Virtual Assistant Marketing Suite
 
top nidhi software solution freedownload
top nidhi software solution freedownloadtop nidhi software solution freedownload
top nidhi software solution freedownload
 
May Marketo Masterclass, London MUG May 22 2024.pdf
May Marketo Masterclass, London MUG May 22 2024.pdfMay Marketo Masterclass, London MUG May 22 2024.pdf
May Marketo Masterclass, London MUG May 22 2024.pdf
 
A Sighting of filterA in Typelevel Rite of Passage
A Sighting of filterA in Typelevel Rite of PassageA Sighting of filterA in Typelevel Rite of Passage
A Sighting of filterA in Typelevel Rite of Passage
 
Orion Context Broker introduction 20240604
Orion Context Broker introduction 20240604Orion Context Broker introduction 20240604
Orion Context Broker introduction 20240604
 
Corporate Management | Session 3 of 3 | Tendenci AMS
Corporate Management | Session 3 of 3 | Tendenci AMSCorporate Management | Session 3 of 3 | Tendenci AMS
Corporate Management | Session 3 of 3 | Tendenci AMS
 
Accelerate Enterprise Software Engineering with Platformless
Accelerate Enterprise Software Engineering with PlatformlessAccelerate Enterprise Software Engineering with Platformless
Accelerate Enterprise Software Engineering with Platformless
 
Quarkus Hidden and Forbidden Extensions
Quarkus Hidden and Forbidden ExtensionsQuarkus Hidden and Forbidden Extensions
Quarkus Hidden and Forbidden Extensions
 
Innovating Inference - Remote Triggering of Large Language Models on HPC Clus...
Innovating Inference - Remote Triggering of Large Language Models on HPC Clus...Innovating Inference - Remote Triggering of Large Language Models on HPC Clus...
Innovating Inference - Remote Triggering of Large Language Models on HPC Clus...
 
Understanding Globus Data Transfers with NetSage
Understanding Globus Data Transfers with NetSageUnderstanding Globus Data Transfers with NetSage
Understanding Globus Data Transfers with NetSage
 
How to Position Your Globus Data Portal for Success Ten Good Practices
How to Position Your Globus Data Portal for Success Ten Good PracticesHow to Position Your Globus Data Portal for Success Ten Good Practices
How to Position Your Globus Data Portal for Success Ten Good Practices
 
RISE with SAP and Journey to the Intelligent Enterprise
RISE with SAP and Journey to the Intelligent EnterpriseRISE with SAP and Journey to the Intelligent Enterprise
RISE with SAP and Journey to the Intelligent Enterprise
 
Graphic Design Crash Course for beginners
Graphic Design Crash Course for beginnersGraphic Design Crash Course for beginners
Graphic Design Crash Course for beginners
 

MongoDB WiredTiger Internals

  • 5. 5 Compression in Action (Flights database, ht Asya)
  • 6. 6 Agenda Storage Engine API WiredTiger Architecture Overall Benefits
  • 8. 8 MongoDB Architecture Content Repo IoT Sensor Backend Ad Service Customer Analytics Archive MongoDB Query Language (MQL) + Native Drivers MongoDB Document Data Model MMAP V1 WT In-Memory ? ? Supported in MongoDB 3.0 Future Possible Storage Engines Management Security Example Future State Beta
  • 9. 9 Storage Engine API •  Allows to "plug-in" different storage engines –  Different use cases require different performance characteristics –  mmapv1 is not ideal for all workloads –  More flexibility •  Can mix storage engines on same replica set/sharded cluster •  Opportunity to integrate further ( HDFS, native encrypted, hardware optimized …)
  • 11. 2 Storage Engines Available … and more in the making! MMAPv1 WiredTiger
  • 12. 12 MongoDB Architecture Content Repo IoT Sensor Backend Ad Service Customer Analytics Archive MongoDB Query Language (MQL) + Native Drivers MongoDB Document Data Model MMAP V1 WT In-Memory ? ? Supported in MongoDB 3.0 Future Possible Storage Engines Management Security Example Future State Beta
  • 15. 15 MMAPv1 •  Improved concurrency control •  Great performance on read-heavy workloads •  Data & Indexes memory mapped into virtual address space •  Data access is paged into RAM •  OS evicts using LRU •  More frequently used pages stay in RAM 3.0 Default
  • 18. 18 What is WiredTiger? •  Storage engine company founded by BerkeleyDB alums •  Recently acquired by MongoDB •  Available as a storage engine option in MongoDB 3.0
  • 19. 19 Motivation for WiredTiger •  Take advantage of modern hardware: –  many CPU cores –  lots of RAM •  Minimize contention between threads –  lock-free algorithms, e.g., hazard pointers –  eliminate blocking due to concurrency control •  Hotter cache and more work per I/O –  compact file formats –  compression
  • 21. WiredTiger Architecture WiredTiger Engine Schema & Cursors Python API C API Java API Database Files Transactions Page read/write Logging Column storage Block management Row storage Snapshots Log Files Cache
  • 22. WiredTiger Sessions Document Data Model WiredTiger Engine Transactions Snapshosts Page read/write WAL Cache Schema & Cursors Row Storage Block Management DB Files Journal Your App Driver connection (mongod) Session Cursor Session Session Cursor Cursor
  • 23. WiredTiger Sessions Document Data Model WiredTiger Engine Transactions Snapshosts Page read/write WAL Cache Schema & Cursors Row Storage Block Management DB Files Journal Your App Driver •  3 main purposes •  Schema Operations •  Transaction Management •  Cursor Creation
  • 24. WiredTiger Schema & Cursors Document Data Model WiredTiger Engine Transactions Snapshosts Page read/write WAL Cache Schema & Cursors Row Storage Block Management DB Files Journal db.createCollection("somecollection") db.somecollection.drop() db.somecollection.find({...}) db.somecollection.remove({_id:111}) db.somecollection.stats() db.somecollection.explain().find({_id:111})
  • 25. WiredTiger Schema & Cursors Document Data Model WiredTiger Engine Transactions Snapshosts Page read/write Logging Cache Schema & Cursors Row Storage Block Management DB Files Log Files •  Schema Operations •  create, drop, truncate, verify … •  Cursors •  CRUD •  Data iteration •  Statistics
  • 26. Collection WiredTiger Transactions Document Data Model WiredTiger Engine Transactions Snapshosts Page read/write WAL Cache Schema & Cursors Row Storage Block Management DB Files Journal COMMAND INSERT { "_id": 111, "name": "Spock", "message": "Live Long and Prosper!" } Index {_id: 1} Index {name: 1} Index {message: "text"}
  • 27. WiredTiger Transactions Document Data Model WiredTiger Engine Transactions Snapshosts Page read/write WAL Cache Schema & Cursors Row Storage Block Management DB Files Journal •  Transaction per Session close, open, commit, rollback •  Ensures the atomicity/consistency of MongoDB operations •  Updates / Writes documents •  Updates indexes This is not multi-document transaction support!
  • 30. Trees in cache non-resident child ordinary pointer root page internal page internal page root page leaf page leaf page leaf page leaf page
  • 31. Cache Page in Disk root page leaf page Disk Page not in memory File Read
  • 32. Cache Page in Memory root page Internal Page Internal Page Internal Page Internal Page Leaf Page Leaf Page Leaf Page Leaf Page
  • 33. Traditional B-tree root page Internal Page Internal Page Internal Page Internal Page Leaf Page Leaf Page Leaf Page Leaf Page
  • 34. Deadlock Avoidance root page Internal Page Internal Page Internal Page Internal Page Leaf Page Leaf Page Leaf Page Leaf Page
  • 35. Cache Page in Memory root page Internal Page Internal Page Internal Page Internal Page Leaf Page Leaf Page Leaf Page Leaf Page Doc1Doc0 Doc5Doc2 Doc3 Doc4 Writer Reader Standard pointers between tree levels instead of traditional files system offset pointers
  • 36. Page in Cache Disk Page images Page images Page images on-disk Page Image index Update on-disk Page Image index Updates db.collection.insert( {"_id": 123}) Clean Page Dirty Page Eviction Thread
  • 37. Page in Cache Disk Page images Page images Page images on-disk Page Image index Update on-disk Page Image index Updates db.collection.insert( {"_id": 123}) Clean Page Dirty Page Index is build during read
  • 38. Page in Cache Disk Page images Page images Page images on-disk Page Image index Updates' db.collection.insert( {"_id": 123}) Dirty Page Updates are held in a skip list Updates'' db.collection.insert( {"_id": 125}) Updates''' db.collection.insert( {"_id": 124}) Time
  • 39. Reconciliation Disk Page images Page images Page images on-disk Page Image index Updates' Dirty Page Eviction Thread Updates'' Updates''' Reconciliation Cache full After X operations On a checkpoint
  • 40. 40 In-memory performance •  Trees in cache are optimized for in-memory access •  Follow pointers to traverse a tree – no locking to access pages in cache •  Keep updates separate from clean data •  Do structural changes (eviction, splits) in background threads
  • 41. 41 Takeaways •  Page and tree access is optimized •  Allows concurrent operations – updates skip lists •  Tuning options that you should be aware of: –  storage.wiredTiger.engineConfig.cacheSizeGB •  You can determine the space allocated for your cache •  Makes your deployment and sizing more predictable https://docs.mongodb.org/manual/reference/configuration-options/#storage.wiredTiger.engineConfig.cacheSizeGB Wiredtiger cache! MongoDB uses more memory than just the Storage Engine needs!
  • 43. 43 What is Concurrency Control? •  Computers have – multiple CPU cores – multiple I/O paths •  To make the most of the hardware, software has to execute multiple operations in parallel •  Concurrency control has to keep data consistent •  Common approaches: – locking – keeping multiple versions of data (MVCC)
  • 44. MVCC on-disk Page Image index WRITE B txn(1) Updates'''Updates' WRITE A txn(2) Updates'' Time WRITE A txn(3) Conflict Detection!
  • 45. 45 Multiversion Concurrency Control (MVCC) •  Multiple versions of records kept in cache •  Readers see the committed version before the transaction started – MongoDB “yields” turn large operations into small transactions •  Writers can create new versions concurrent with readers •  Concurrent updates to a single record cause write conflicts – MongoDB retries with back-off
  • 46. MVCC on-disk Page Image index Updates' WRITE B txn(1) Updates'' Updates''' WRITE A txn(2) Time WRITE A txn(3) READ A
  • 48. 48 WiredTiger Page IO Document Data Model WiredTiger Engine Transactions Snapshosts Page read/write WAL Cache Schema & Cursors Row Storage Block Management DB Files Journal on-disk Page Image index Updates''' Disk Page Reconciliation Page Allocation Splitting
  • 49. 49 WiredTiger Page IO Document Data Model WiredTiger Engine Transactions Snapshosts Page read/write WAL Cache Schema & Cursors Row Storage Block Management DB Files Journal on-disk Page Image index Updates''' Disk Page' Reconciliation Page Allocation Splitting Page''
  • 50. 50 WiredTiger Page IO Document Data Model WiredTiger Engine Transactions Snapshosts Page read/write WAL Cache Schema & Cursors Row Storage Block Management DB Files Journal on-disk Page Image index Updates''' Disk Reconciliation Page Allocation Splitting Page Compression -  snappy (default) -  zlib -  none
  • 51. 51 Compression •  WiredTiger uses snappy compression by default in MongoDB •  Supported compression algorithms: –  snappy [default]: good compression, low overhead –  zlib: better compression, more CPU –  none •  Indexes also use prefix compression –  stays compressed in memory
  • 52. 52 Checksums •  A checksum is stored with every uncompressed page •  Checksums are validated during page read –  detects filesystem corruption, random bitflips •  WiredTiger stores the checksum with the page address (typically in a parent page) –  extra safety against reading a stale page image
  • 53. 53 Compression in Action (Flights database, ht Asya)
  • 54. 54 Takeaway •  Main feature that impacts the vast majority of MongoDB projects / use cases •  CPU bound •  Different algorithms for different workloads –  Collection level compression tuning •  Smaller Data Faster IO –  Not only improves the disk space footprint –  also IO –  and index traversing
  • 55. Other Gems of WiredTiger
  • 56. 56 Index per Directory •  Use different drives for collections and indexes –  Parallelization of write operations –  MMAPv1 only allows directoryPerDatabase mongod Collection A Index "name " Collection B Index "_id"
  • 57. 57 Consistency without Journaling •  MMAPv1 uses write-ahead log (journal) to guarantee consistency •  WT doesn't have this need: no in-place updates –  Write-ahead log committed at checkpoints and with j:true –  Better for insert-heavy workloads –  By default journaling is enabled! •  Replication guarantees the durability
  • 59. 59
  • 60. 60 What’s next for WiredTiger? •  Tune for (many) more workloads – avoid stalls during checkpoints with 100GB+ caches – make capped collections (including oplog) more efficient •  Adding encryption •  More advanced transactional semantics in the storage engine API
  • 61. 61 Updates and Upgrades •  Can not –  Can't copy database files –  Can't just restart w/ same dbpath •  Yes we can! –  Initial sync from replica set works perfectly! –  mongodump/restore •  Rolling upgrade of replica set to WT: –  Shutdown secondary –  Delete dbpath –  Relaunch w/ --storageEngine=wiredTiger –  Wait for resync –  Rollover
  • 63. 63 MongoDB 3.0 •  Pluggable Storage Engine API •  Storage Engines •  Large Replica Sets •  Big Polygon •  Security Enhancements – SCRAM •  Audit Trail •  Simplified Operations – Ops Manager •  Tools Rewrite