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

PDF
Updating materialized views and caches using kafka
PDF
FITC presents: Mobile & offline data synchronization in Angular JS
ODP
Redis IU
PPTX
MongoDB
PDF
Electron, databases, and RxDB
PPTX
MongoDB basics & Introduction
PPTX
Mongo db
PPTX
Mongo db nosql (1)
Updating materialized views and caches using kafka
FITC presents: Mobile & offline data synchronization in Angular JS
Redis IU
MongoDB
Electron, databases, and RxDB
MongoDB basics & Introduction
Mongo db
Mongo db nosql (1)

What's hot (20)

PDF
Mongo db basics
PDF
Mongo presentation conf
PPTX
Introduction to MongoDB
PPTX
MongoDB
PDF
Webtech Conference: NoSQL and Web scalability
ODP
PDF
MongoDB - An Introduction
PPTX
The Basics of MongoDB
PPTX
Mongo DB 102
PPTX
MongoDB 101
PPTX
MongoDB
PPTX
Mongo DB Presentation
PPTX
MongoDB for Beginners
PPTX
Mongo db1
PDF
MongoDB World 2019: Lessons Learned: Migrating Buffer's Production Database t...
PPT
Connecting to a REST API in iOS
PDF
U C2007 My S Q L Performance Cookbook
PPTX
MongoDB Schema Design by Examples
PDF
VBA API for scriptDB primer
Mongo db basics
Mongo presentation conf
Introduction to MongoDB
MongoDB
Webtech Conference: NoSQL and Web scalability
MongoDB - An Introduction
The Basics of MongoDB
Mongo DB 102
MongoDB 101
MongoDB
Mongo DB Presentation
MongoDB for Beginners
Mongo db1
MongoDB World 2019: Lessons Learned: Migrating Buffer's Production Database t...
Connecting to a REST API in iOS
U C2007 My S Q L Performance Cookbook
MongoDB Schema Design by Examples
VBA API for scriptDB primer
Ad

Similar to Replicating application data into materialized views (20)

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

Recently uploaded (20)

PPTX
Programs and apps: productivity, graphics, security and other tools
PDF
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
PDF
Building Integrated photovoltaic BIPV_UPV.pdf
PDF
Reach Out and Touch Someone: Haptics and Empathic Computing
PDF
cuic standard and advanced reporting.pdf
PPTX
20250228 LYD VKU AI Blended-Learning.pptx
PPTX
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
PDF
Agricultural_Statistics_at_a_Glance_2022_0.pdf
PDF
NewMind AI Weekly Chronicles - August'25 Week I
PPTX
ACSFv1EN-58255 AWS Academy Cloud Security Foundations.pptx
PPTX
Detection-First SIEM: Rule Types, Dashboards, and Threat-Informed Strategy
PDF
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
PDF
Diabetes mellitus diagnosis method based random forest with bat algorithm
PDF
Dropbox Q2 2025 Financial Results & Investor Presentation
PDF
Electronic commerce courselecture one. Pdf
PDF
Encapsulation theory and applications.pdf
PPTX
Digital-Transformation-Roadmap-for-Companies.pptx
PDF
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
PDF
Review of recent advances in non-invasive hemoglobin estimation
PDF
KodekX | Application Modernization Development
Programs and apps: productivity, graphics, security and other tools
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
Building Integrated photovoltaic BIPV_UPV.pdf
Reach Out and Touch Someone: Haptics and Empathic Computing
cuic standard and advanced reporting.pdf
20250228 LYD VKU AI Blended-Learning.pptx
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
Agricultural_Statistics_at_a_Glance_2022_0.pdf
NewMind AI Weekly Chronicles - August'25 Week I
ACSFv1EN-58255 AWS Academy Cloud Security Foundations.pptx
Detection-First SIEM: Rule Types, Dashboards, and Threat-Informed Strategy
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
Diabetes mellitus diagnosis method based random forest with bat algorithm
Dropbox Q2 2025 Financial Results & Investor Presentation
Electronic commerce courselecture one. Pdf
Encapsulation theory and applications.pdf
Digital-Transformation-Roadmap-for-Companies.pptx
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
Review of recent advances in non-invasive hemoglobin estimation
KodekX | Application Modernization Development

Replicating application data into materialized views