SlideShare a Scribd company logo
Replicating Application Data
Into Materialized Views
-or-
Why You Should Publish
Data Changes to Kafka
Zach Cox @zcox
Jack Henry & Associates
Iowa Code Camp Dec 2015
Replicating application data into materialized views
Replicating application data into materialized views
http://www.nngroup.com/articles/response-times-3-important-limits/
Replicating application data into materialized views
Replicating application data into materialized views
Replicating application data into materialized views
Replicating application data into materialized views
Replicating application data into materialized views
Replicating application data into materialized views
Kafka documentation
I ♥ Logs book
Replicating application data into materialized views
Replicating application data into materialized views
Replicating application data into materialized views
def getUser(id: String): User =
readUserFromCache(id) match {
case Some(user) => user
case None =>
val user = readUserFromDatabase(id)
writeUserToCache(user)
user
}
def getUser(id: String): User =
readUserFromCache(id) match {
case Some(user) => user
case None => //cache miss!
val user = readUserFromDatabase(id)
writeUserToCache(user)
user
}
def getUser(id: String): User =
readUserFromCache(id) match {
case Some(user) => user //stale?
case None => //cache miss!
val user = readUserFromDatabase(id)
writeUserToCache(user)
user
}
def getUser(id: String): User =
readUserFromCache(id) match { //network latency
case Some(user) => user //stale?
case None => //cache miss!
val user = readUserFromDatabase(id)
writeUserToCache(user)
user
}
RocksDB
Bottled Water
Replicating application data into materialized views
Replicating application data into materialized views
Elasticsearch
https://github.com/zcox/data-replication-example

More Related Content

What's hot (20)

PDF
Mongo db basics
Harischandra M K
 
PDF
Mongo presentation conf
Shridhar Joshi
 
PPTX
Introduction to MongoDB
NodeXperts
 
PPTX
MongoDB
Ganesh Kunwar
 
PDF
Webtech Conference: NoSQL and Web scalability
Luca Bonmassar
 
ODP
Lokijs
Joe Minichino
 
PDF
MongoDB - An Introduction
sethfloydjr
 
PPTX
The Basics of MongoDB
valuebound
 
PPTX
Mongo DB 102
Abhijeet Vaikar
 
PPTX
MongoDB 101
Abhijeet Vaikar
 
PPTX
MongoDB
nikhil2807
 
PPTX
Mongo DB Presentation
Jaya Naresh Kovela
 
PPTX
MongoDB for Beginners
Enoch Joshua
 
PPTX
Mongo db1
VandanaKukreja
 
PDF
MongoDB World 2019: Lessons Learned: Migrating Buffer's Production Database t...
MongoDB
 
PPT
Connecting to a REST API in iOS
gillygize
 
PDF
U C2007 My S Q L Performance Cookbook
guestae36d0
 
PPTX
MongoDB Schema Design by Examples
Hadi Ariawan
 
PDF
VBA API for scriptDB primer
Bruce McPherson
 
Mongo db basics
Harischandra M K
 
Mongo presentation conf
Shridhar Joshi
 
Introduction to MongoDB
NodeXperts
 
MongoDB
Ganesh Kunwar
 
Webtech Conference: NoSQL and Web scalability
Luca Bonmassar
 
MongoDB - An Introduction
sethfloydjr
 
The Basics of MongoDB
valuebound
 
Mongo DB 102
Abhijeet Vaikar
 
MongoDB 101
Abhijeet Vaikar
 
MongoDB
nikhil2807
 
Mongo DB Presentation
Jaya Naresh Kovela
 
MongoDB for Beginners
Enoch Joshua
 
Mongo db1
VandanaKukreja
 
MongoDB World 2019: Lessons Learned: Migrating Buffer's Production Database t...
MongoDB
 
Connecting to a REST API in iOS
gillygize
 
U C2007 My S Q L Performance Cookbook
guestae36d0
 
MongoDB Schema Design by Examples
Hadi Ariawan
 
VBA API for scriptDB primer
Bruce McPherson
 

Similar to Replicating application data into materialized views (20)

PPTX
Hack an ASP .NET website? Hard, but possible!
Vladimir Kochetkov
 
PDF
Framework agnostic application Will it fit with Symfony? - Symfony live warsa...
Dariusz Drobisz
 
KEY
Couchdb: No SQL? No driver? No problem
delagoya
 
PDF
Dependency Injection
Alena Holligan
 
PPT
How Not to Build a WordPress Plugin
Will Norris
 
PPTX
Tools for Making Machine Learning more Reactive
Jeff Smith
 
PPTX
Big Data Day LA 2015 - Compiling DSLs for Diverse Execution Environments by Z...
Data Con LA
 
PPTX
David Keeney - SQL Database Server Requests from the Browser @ Postgres Open
PostgresOpen
 
PDF
Event Sourcing - what could go wrong - Devoxx BE
Andrzej Ludwikowski
 
PDF
4069180 Caching Performance Lessons From Facebook
guoqing75
 
PPTX
Transients are good for you - WordCamp London 2016
Julio Potier
 
PDF
Kicking off with Zend Expressive and Doctrine ORM (PHP UK 2017)
James Titcumb
 
PPTX
SCULPT! YOUR! TESTS!
Taras Oleksyn
 
PDF
Event sourcing - what could possibly go wrong ? Devoxx PL 2021
Andrzej Ludwikowski
 
PDF
Solr's Search Relevancy (Understand Solr's query debug)
Wongnai
 
PDF
Kicking off with Zend Expressive and Doctrine ORM (PHP Srbija 2017)
James Titcumb
 
PPTX
Practical OData
Vagif Abilov
 
PDF
Apidays Paris 2023 - Forget TypeScript, Choose Rust to build Robust, Fast and...
apidays
 
PDF
Facebook的缓存系统
yiditushe
 
PDF
Andrzej Ludwikowski - Event Sourcing - what could possibly go wrong? - Codemo...
Codemotion
 
Hack an ASP .NET website? Hard, but possible!
Vladimir Kochetkov
 
Framework agnostic application Will it fit with Symfony? - Symfony live warsa...
Dariusz Drobisz
 
Couchdb: No SQL? No driver? No problem
delagoya
 
Dependency Injection
Alena Holligan
 
How Not to Build a WordPress Plugin
Will Norris
 
Tools for Making Machine Learning more Reactive
Jeff Smith
 
Big Data Day LA 2015 - Compiling DSLs for Diverse Execution Environments by Z...
Data Con LA
 
David Keeney - SQL Database Server Requests from the Browser @ Postgres Open
PostgresOpen
 
Event Sourcing - what could go wrong - Devoxx BE
Andrzej Ludwikowski
 
4069180 Caching Performance Lessons From Facebook
guoqing75
 
Transients are good for you - WordCamp London 2016
Julio Potier
 
Kicking off with Zend Expressive and Doctrine ORM (PHP UK 2017)
James Titcumb
 
SCULPT! YOUR! TESTS!
Taras Oleksyn
 
Event sourcing - what could possibly go wrong ? Devoxx PL 2021
Andrzej Ludwikowski
 
Solr's Search Relevancy (Understand Solr's query debug)
Wongnai
 
Kicking off with Zend Expressive and Doctrine ORM (PHP Srbija 2017)
James Titcumb
 
Practical OData
Vagif Abilov
 
Apidays Paris 2023 - Forget TypeScript, Choose Rust to build Robust, Fast and...
apidays
 
Facebook的缓存系统
yiditushe
 
Andrzej Ludwikowski - Event Sourcing - what could possibly go wrong? - Codemo...
Codemotion
 
Ad

Recently uploaded (20)

PDF
Reverse Engineering of Security Products: Developing an Advanced Microsoft De...
nwbxhhcyjv
 
PDF
Staying Human in a Machine- Accelerated World
Catalin Jora
 
DOCX
Python coding for beginners !! Start now!#
Rajni Bhardwaj Grover
 
PDF
Transcript: Book industry state of the nation 2025 - Tech Forum 2025
BookNet Canada
 
PDF
Go Concurrency Real-World Patterns, Pitfalls, and Playground Battles.pdf
Emily Achieng
 
PDF
What’s my job again? Slides from Mark Simos talk at 2025 Tampa BSides
Mark Simos
 
PDF
LOOPS in C Programming Language - Technology
RishabhDwivedi43
 
PPTX
MuleSoft MCP Support (Model Context Protocol) and Use Case Demo
shyamraj55
 
PDF
The Rise of AI and IoT in Mobile App Tech.pdf
IMG Global Infotech
 
DOCX
Cryptography Quiz: test your knowledge of this important security concept.
Rajni Bhardwaj Grover
 
PPTX
Q2 FY26 Tableau User Group Leader Quarterly Call
lward7
 
PDF
SIZING YOUR AIR CONDITIONER---A PRACTICAL GUIDE.pdf
Muhammad Rizwan Akram
 
PDF
The 2025 InfraRed Report - Redpoint Ventures
Razin Mustafiz
 
PDF
Automating Feature Enrichment and Station Creation in Natural Gas Utility Net...
Safe Software
 
PDF
Newgen Beyond Frankenstein_Build vs Buy_Digital_version.pdf
darshakparmar
 
PDF
CIFDAQ Market Wrap for the week of 4th July 2025
CIFDAQ
 
PDF
“Squinting Vision Pipelines: Detecting and Correcting Errors in Vision Models...
Edge AI and Vision Alliance
 
PDF
Bitcoin for Millennials podcast with Bram, Power Laws of Bitcoin
Stephen Perrenod
 
PDF
How do you fast track Agentic automation use cases discovery?
DianaGray10
 
PPTX
New ThousandEyes Product Innovations: Cisco Live June 2025
ThousandEyes
 
Reverse Engineering of Security Products: Developing an Advanced Microsoft De...
nwbxhhcyjv
 
Staying Human in a Machine- Accelerated World
Catalin Jora
 
Python coding for beginners !! Start now!#
Rajni Bhardwaj Grover
 
Transcript: Book industry state of the nation 2025 - Tech Forum 2025
BookNet Canada
 
Go Concurrency Real-World Patterns, Pitfalls, and Playground Battles.pdf
Emily Achieng
 
What’s my job again? Slides from Mark Simos talk at 2025 Tampa BSides
Mark Simos
 
LOOPS in C Programming Language - Technology
RishabhDwivedi43
 
MuleSoft MCP Support (Model Context Protocol) and Use Case Demo
shyamraj55
 
The Rise of AI and IoT in Mobile App Tech.pdf
IMG Global Infotech
 
Cryptography Quiz: test your knowledge of this important security concept.
Rajni Bhardwaj Grover
 
Q2 FY26 Tableau User Group Leader Quarterly Call
lward7
 
SIZING YOUR AIR CONDITIONER---A PRACTICAL GUIDE.pdf
Muhammad Rizwan Akram
 
The 2025 InfraRed Report - Redpoint Ventures
Razin Mustafiz
 
Automating Feature Enrichment and Station Creation in Natural Gas Utility Net...
Safe Software
 
Newgen Beyond Frankenstein_Build vs Buy_Digital_version.pdf
darshakparmar
 
CIFDAQ Market Wrap for the week of 4th July 2025
CIFDAQ
 
“Squinting Vision Pipelines: Detecting and Correcting Errors in Vision Models...
Edge AI and Vision Alliance
 
Bitcoin for Millennials podcast with Bram, Power Laws of Bitcoin
Stephen Perrenod
 
How do you fast track Agentic automation use cases discovery?
DianaGray10
 
New ThousandEyes Product Innovations: Cisco Live June 2025
ThousandEyes
 
Ad

Replicating application data into materialized views