SlideShare a Scribd company logo
Tailoring
For Your Users’ Needs
Adam Lev-Libfeld // Chief Architect // Tamar Labs
Redis Modules
Adam Lev-Libfeld // Tamar Tech Solutions // RedisConf 18
Redis
Modules
Redis Modules
Redis Modules
Tailoring Redis Modules For Your Users’ Needs
Redis Modules
Adam Lev-Libfeld // Tamar Tech Solutions // RedisConf 18
Tailoring Redis Modules For Your Users’ Needs
Tailoring Redis Modules For Your Users’ Needs
Tailoring Redis Modules For Your Users’ Needs
Tailoring Redis Modules For Your Users’ Needs
Redis Modules
Adam Lev-Libfeld // Tamar Tech Solutions // RedisConf 18
NEED
TIMEPRICE
VALUE
GOOD
FASTCHEAP
PRODUCT
FASTCHEAP
SYSTEM
Performance
It’s FAST
Original
code
v0.1.X v0.2.X v0.3.X
Elements
sec
1,000 1,700 265,000 305,000
ReDe
Event dehydration module
https://www.tamarlabs.com/ReDe/
It’s FAST
Original
code
v0.1.X v0.2.X v0.3.X
Elements
sec
1,000 1,700 265,000 305,000
ReDe
Event dehydration module
https://www.tamarlabs.com/ReDe/
Tailoring Redis Modules For Your Users’ Needs
Tailoring Redis Modules For Your Users’ Needs
Tailoring Redis Modules For Your Users’ Needs
Tailoring Redis Modules For Your Users’ Needs
The problem
Tailoring Redis Modules For Your Users’ Needs
04 02
01
response business logic
User action
Intake business logic
Building redis query(ies),
sending, and parsing results 03
Make Redis
understand your data
use case #3
Tailoring Redis Modules For Your Users’ Needs
~1%
Make Redis do your
work
use case #2
𝚺
𝚺
X
𝚺
Tailoring Redis Modules For Your Users’ Needs
Tailoring Redis Modules For Your Users’ Needs
Make Redis do your work
● Simplifies & minimises BL code
● Consolidates code across platforms
● Minimizes network hops
● Simplifies move to concurrent processing
● Enables custom C code as a service
● Moves compute closer to data (CS 101 pro tip)
Make Redis speak
your language
use case #1
Tailoring Redis Modules For Your Users’ Needs
Tailoring Redis Modules For Your Users’ Needs
Tailoring Redis Modules For Your Users’ Needs
*assuming > pipe
Tailoring Redis Modules For Your Users’ Needs
01:00
Your Royal Starship
Naboo
Make Redis speak your language
for scanned_components in r.hscan_iter(“Royal Starship”, match=”*power*”):
for component in scanned_components:
if component[1].get(“status”) != “ok”:
bypass(component[0]) # <- usually main power drive fail
if shield.is_up():
return
r.execute_command(“r2_droids.fix_shield_generator”)
OR
Make Redis speak your language
for scanned_components in r.hscan_iter(“Royal Starship”, match=”*power*”):
for component in scanned_components:
if component[1].get(“status”) != “ok”:
bypass(component[0]) # <- usually main power drive fail
if shield.is_up():
return
r.execute_command(“r2_droids.fix_shield_generator”)
OR
X
Make Redis speak your language
● Enhances code maintainability by simplifying BL code
● Code consolidation across platforms
● Minimizes network hops
But it’s so hard to write!
ReDe - an implementation of the Lawn DS
Original code - Python + Apache Storm ~700 lines (w/o tests)
Final* module - C ~1300 lines of code (incl. tests)
Original
code
v0.1.X v0.2.X v0.3.X
Elements
sec
1,000 1,700 265,000 305,000
line by line
translation
Rewrite to use
module internals
CommentDis - add comments to redis CLI
Make Redis do your work
● Simplifies & minimises BL code
● Consolidates code across platforms
● Minimizes network hops
● Simplifies move to concurrent processing
● Enables custom C code as a service
● Moves compute closer to data (CS 101 pro tip)
Make Redis understand your data
Make Redis speak your language
Redis Modules
Adam Lev-Libfeld // Tamar Tech Solutions // RedisConf 18
www.tamarlabs.com/redisconf
adam@tamarlabs.com
Tell Me What Hurts
Thank You

More Related Content

PDF
RedisConf18 - 2,000 Instances and Beyond
PDF
RedisConf18 - Writing modular & encapsulated Redis code
PDF
RedisConf18 - Microservicesand Redis: A Match made in Heaven
PDF
RedisConf18 - Fail-Safe Starvation-Free Durable Priority Queues in Redis
PPTX
RedisConf18 - Application of Redis in IOT Edge Devices
PDF
RedisConf18 - Open Source Built for Scale: Redis in Amazon ElastiCache Service
PDF
RedisConf18 - Redis at LINE - 25 Billion Messages Per Day
PDF
RedisConf18 - Active-Active Geo-Distributed Apps with Redis CRDTs (conflict f...
RedisConf18 - 2,000 Instances and Beyond
RedisConf18 - Writing modular & encapsulated Redis code
RedisConf18 - Microservicesand Redis: A Match made in Heaven
RedisConf18 - Fail-Safe Starvation-Free Durable Priority Queues in Redis
RedisConf18 - Application of Redis in IOT Edge Devices
RedisConf18 - Open Source Built for Scale: Redis in Amazon ElastiCache Service
RedisConf18 - Redis at LINE - 25 Billion Messages Per Day
RedisConf18 - Active-Active Geo-Distributed Apps with Redis CRDTs (conflict f...

What's hot (20)

PPTX
RedisConf17 - Redis Enterprise: Continuous Availability, Unlimited Scaling, S...
PDF
RedisConf17 - Lyft - Geospatial at Scale - Daniel Hochman
PPTX
High-Volume Data Collection and Real Time Analytics Using Redis
PPTX
RedisConf18 - Serving Automated Home Valuation with Redis & Kafka
PDF
RedisConf18 - Redis Memory Optimization
PPTX
RedisConf17 - Operationalizing Redis at Scale
PPTX
RedisConf18 - Redis Enterprise on Cloud Native Platforms
PPTX
RedisConf18 - Implementing a New Data Structure for Redis
PPTX
What's new with enterprise Redis - Leena Joshi, Redis Labs
PPTX
Managing 50K+ Redis Databases Over 4 Public Clouds ... with a Tiny Devops Team
PDF
RedisConf18 - Ultra Scaling with Redis Enterprise
PPTX
RedisConf18 - Redis as a time-series DB
PPTX
RedisConf17- Using Redis at scale @ Twitter
PDF
HDFS Selective Wire Encryption
PPTX
RedisConf18 - Redis Fault Injection
PPTX
RedisConf17 - Redis Labs - Implementing Real-time Machine Learning with Redis-ML
PDF
RedisConf17 - Searching Billions of Documents with Redis
PPTX
RedisConf17 - Redis in High Traffic Adtech Stack
PPTX
Future Architecture of Streaming Analytics: Capitalizing on the Analytics of ...
PDF
iland Internet Solutions: Leveraging Cassandra for real-time multi-datacenter...
RedisConf17 - Redis Enterprise: Continuous Availability, Unlimited Scaling, S...
RedisConf17 - Lyft - Geospatial at Scale - Daniel Hochman
High-Volume Data Collection and Real Time Analytics Using Redis
RedisConf18 - Serving Automated Home Valuation with Redis & Kafka
RedisConf18 - Redis Memory Optimization
RedisConf17 - Operationalizing Redis at Scale
RedisConf18 - Redis Enterprise on Cloud Native Platforms
RedisConf18 - Implementing a New Data Structure for Redis
What's new with enterprise Redis - Leena Joshi, Redis Labs
Managing 50K+ Redis Databases Over 4 Public Clouds ... with a Tiny Devops Team
RedisConf18 - Ultra Scaling with Redis Enterprise
RedisConf18 - Redis as a time-series DB
RedisConf17- Using Redis at scale @ Twitter
HDFS Selective Wire Encryption
RedisConf18 - Redis Fault Injection
RedisConf17 - Redis Labs - Implementing Real-time Machine Learning with Redis-ML
RedisConf17 - Searching Billions of Documents with Redis
RedisConf17 - Redis in High Traffic Adtech Stack
Future Architecture of Streaming Analytics: Capitalizing on the Analytics of ...
iland Internet Solutions: Leveraging Cassandra for real-time multi-datacenter...
Ad

Similar to Tailoring Redis Modules For Your Users’ Needs (20)

PDF
Paris container day june17
PPTX
TIAD 2016 : Migrating 100% of your production services to containers
PPTX
Developing a Redis Module - Hackathon Kickoff
PDF
Serverless and React
PDF
Extend Redis with Modules
PDF
UKOUG Tech15 - Deploying Oracle 12c Cloud Control in Maximum Availability Arc...
PDF
DCEU 18: Developing with Docker Containers
PDF
Verified CKAD Exam Questions and Answers
PDF
Linux on System z debugging with Valgrind
PDF
MySQL Database Architectures - 2022-08
PDF
Live deployment, ci, drupal
PDF
IBM Systems Technical Symposium Melbourne, 2015
PDF
stackconf 2022: Cluster Management: Heterogeneous, Lightweight, Safe. Pick Three
PPTX
Optimize DR and Cloning with Logical Hostnames in Oracle E-Business Suite (OA...
PDF
MongoDB.local DC 2018: MongoDB Ops Manager + Kubernetes
PDF
Redis Meetup TLV - K8s Session 28/10/2018
PDF
Redis acc
PDF
Oracle Fleet Patching and Provisioning Deep Dive Webcast Slides
PDF
MongoDB.local Austin 2018: MongoDB Ops Manager + Kubernetes
PDF
Orchestrating Redis & K8s Operators
Paris container day june17
TIAD 2016 : Migrating 100% of your production services to containers
Developing a Redis Module - Hackathon Kickoff
Serverless and React
Extend Redis with Modules
UKOUG Tech15 - Deploying Oracle 12c Cloud Control in Maximum Availability Arc...
DCEU 18: Developing with Docker Containers
Verified CKAD Exam Questions and Answers
Linux on System z debugging with Valgrind
MySQL Database Architectures - 2022-08
Live deployment, ci, drupal
IBM Systems Technical Symposium Melbourne, 2015
stackconf 2022: Cluster Management: Heterogeneous, Lightweight, Safe. Pick Three
Optimize DR and Cloning with Logical Hostnames in Oracle E-Business Suite (OA...
MongoDB.local DC 2018: MongoDB Ops Manager + Kubernetes
Redis Meetup TLV - K8s Session 28/10/2018
Redis acc
Oracle Fleet Patching and Provisioning Deep Dive Webcast Slides
MongoDB.local Austin 2018: MongoDB Ops Manager + Kubernetes
Orchestrating Redis & K8s Operators
Ad

More from Redis Labs (20)

PPTX
Redis Day Bangalore 2020 - Session state caching with redis
PPTX
Protecting Your API with Redis by Jane Paek - Redis Day Seattle 2020
PPTX
The Happy Marriage of Redis and Protobuf by Scott Haines of Twilio - Redis Da...
PPTX
SQL, Redis and Kubernetes by Paul Stanton of Windocks - Redis Day Seattle 2020
PPTX
Rust and Redis - Solving Problems for Kubernetes by Ravi Jagannathan of VMwar...
PPTX
Redis for Data Science and Engineering by Dmitry Polyakovsky of Oracle
PPTX
Practical Use Cases for ACLs in Redis 6 by Jamie Scott - Redis Day Seattle 2020
PPTX
Moving Beyond Cache by Yiftach Shoolman Redis Labs - Redis Day Seattle 2020
PPTX
Leveraging Redis for System Monitoring by Adam McCormick of SBG - Redis Day S...
PPTX
JSON in Redis - When to use RedisJSON by Jay Won of Coupang - Redis Day Seatt...
PPTX
Highly Available Persistent Session Management Service by Mohamed Elmergawi o...
PPTX
Anatomy of a Redis Command by Madelyn Olson of Amazon Web Services - Redis Da...
PPTX
Building a Multi-dimensional Analytics Engine with RedisGraph by Matthew Goos...
PPTX
RediSearch 1.6 by Pieter Cailliau - Redis Day Bangalore 2020
PPTX
RedisGraph 2.0 by Pieter Cailliau - Redis Day Bangalore 2020
PPTX
RedisTimeSeries 1.2 by Pieter Cailliau - Redis Day Bangalore 2020
PPTX
RedisAI 0.9 by Sherin Thomas of Tensorwerk - Redis Day Bangalore 2020
PPTX
Rate-Limiting 30 Million requests by Vijay Lakshminarayanan and Girish Koundi...
PDF
Three Pillars of Observability by Rajalakshmi Raji Srinivasan of Site24x7 Zoh...
PPTX
Solving Complex Scaling Problems by Prashant Kumar and Abhishek Jain of Myntr...
Redis Day Bangalore 2020 - Session state caching with redis
Protecting Your API with Redis by Jane Paek - Redis Day Seattle 2020
The Happy Marriage of Redis and Protobuf by Scott Haines of Twilio - Redis Da...
SQL, Redis and Kubernetes by Paul Stanton of Windocks - Redis Day Seattle 2020
Rust and Redis - Solving Problems for Kubernetes by Ravi Jagannathan of VMwar...
Redis for Data Science and Engineering by Dmitry Polyakovsky of Oracle
Practical Use Cases for ACLs in Redis 6 by Jamie Scott - Redis Day Seattle 2020
Moving Beyond Cache by Yiftach Shoolman Redis Labs - Redis Day Seattle 2020
Leveraging Redis for System Monitoring by Adam McCormick of SBG - Redis Day S...
JSON in Redis - When to use RedisJSON by Jay Won of Coupang - Redis Day Seatt...
Highly Available Persistent Session Management Service by Mohamed Elmergawi o...
Anatomy of a Redis Command by Madelyn Olson of Amazon Web Services - Redis Da...
Building a Multi-dimensional Analytics Engine with RedisGraph by Matthew Goos...
RediSearch 1.6 by Pieter Cailliau - Redis Day Bangalore 2020
RedisGraph 2.0 by Pieter Cailliau - Redis Day Bangalore 2020
RedisTimeSeries 1.2 by Pieter Cailliau - Redis Day Bangalore 2020
RedisAI 0.9 by Sherin Thomas of Tensorwerk - Redis Day Bangalore 2020
Rate-Limiting 30 Million requests by Vijay Lakshminarayanan and Girish Koundi...
Three Pillars of Observability by Rajalakshmi Raji Srinivasan of Site24x7 Zoh...
Solving Complex Scaling Problems by Prashant Kumar and Abhishek Jain of Myntr...

Recently uploaded (20)

PDF
Agricultural_Statistics_at_a_Glance_2022_0.pdf
PDF
KodekX | Application Modernization Development
PDF
Mobile App Security Testing_ A Comprehensive Guide.pdf
PDF
Modernizing your data center with Dell and AMD
PDF
Advanced methodologies resolving dimensionality complications for autism neur...
PDF
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
PDF
NewMind AI Weekly Chronicles - August'25 Week I
PDF
Shreyas Phanse Resume: Experienced Backend Engineer | Java • Spring Boot • Ka...
PDF
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
PDF
Bridging biosciences and deep learning for revolutionary discoveries: a compr...
PDF
Diabetes mellitus diagnosis method based random forest with bat algorithm
PPT
Teaching material agriculture food technology
PDF
Building Integrated photovoltaic BIPV_UPV.pdf
PDF
Reach Out and Touch Someone: Haptics and Empathic Computing
DOCX
The AUB Centre for AI in Media Proposal.docx
PDF
Dropbox Q2 2025 Financial Results & Investor Presentation
PDF
Machine learning based COVID-19 study performance prediction
PPT
“AI and Expert System Decision Support & Business Intelligence Systems”
PPTX
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
PDF
Encapsulation_ Review paper, used for researhc scholars
Agricultural_Statistics_at_a_Glance_2022_0.pdf
KodekX | Application Modernization Development
Mobile App Security Testing_ A Comprehensive Guide.pdf
Modernizing your data center with Dell and AMD
Advanced methodologies resolving dimensionality complications for autism neur...
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
NewMind AI Weekly Chronicles - August'25 Week I
Shreyas Phanse Resume: Experienced Backend Engineer | Java • Spring Boot • Ka...
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
Bridging biosciences and deep learning for revolutionary discoveries: a compr...
Diabetes mellitus diagnosis method based random forest with bat algorithm
Teaching material agriculture food technology
Building Integrated photovoltaic BIPV_UPV.pdf
Reach Out and Touch Someone: Haptics and Empathic Computing
The AUB Centre for AI in Media Proposal.docx
Dropbox Q2 2025 Financial Results & Investor Presentation
Machine learning based COVID-19 study performance prediction
“AI and Expert System Decision Support & Business Intelligence Systems”
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
Encapsulation_ Review paper, used for researhc scholars

Tailoring Redis Modules For Your Users’ Needs