SlideShare a Scribd company logo
Avro
Avro and its awesomeness
Avro and its awesomeness
Topic <=> DB Table
Schema <=> DB Column metadata
Model
• Data safety
• Data compressed automatically
• Documentation
• Cross language portability
• Evolution
• Many tools and moving parts
• Learning curve
• Difficult to debug
• Complexity (comes with Kafka)
+
-
Avro Schema
Demo
Avro and its awesomeness
Avro and its awesomeness
Compatibility Type Changes allowed Check against which schemas Upgrade first
BACKWARD
•Delete fields
•Add optional fields
Last version Consumers
BACKWARD_TRANSITIVE
•Delete fields
•Add optional fields
All previous versions Consumers
FORWARD
•Add fields
•Delete optional fields
Last version Producers
FORWARD_TRANSITIVE
•Add fields
•Delete optional fields
All previous versions Producers
FULL
•Add optional fields
•Delete optional fields
Last version Any order
FULL_TRANSITIVE
•Add optional fields
•Delete optional fields
All previous versions Any order
NONE •All changes are accepted Compatibility checking disabled Depends
C1 P1
Schema Evolutions
V1
C1 P1
Schema-Forward
V1 V2
C1 P1
Schema-Forward(Broken)
C2 C2
V1 V2
C1 P1
Schema-Forward(Fixed by Backward)
C2 C2
V1 V2
C1 P1
Schema-Forward(Delete)
V1
C1 P1
Schema-Forward(Delete)
V1 V2
C1 P1
Schema-Forward(Delete)
V1 V2
C2
C1 P1
Schema
V1
C2 P2
V2
C1 P1
Schema-Backward
V1
C2 P2
V2
C1 P1
Schema-Backward(fixed)
V1
C2 P2
V2
Schema-Transitive(Forward)
V1
V3
• Java-Avro codegen
• Reflect
• And why reflect?

More Related Content

PDF
JAZOON'13 - Nikita Salnikov-Tarnovski - Multiplatform Java application develo...
PPTX
Domain Specific Development using T4
PPTX
WEPA - Webdriver Enhanced Platform for Automation - WEPATest
PDF
Introduction to Scala for Java Developers
PDF
Enterprise messaging
PDF
CBDW2014 - Down the RabbitMQ hole with ColdFusion
PDF
PHP, the GraphQL ecosystem and GraphQLite
PPT
Java SE 7 New Features and Enhancements
JAZOON'13 - Nikita Salnikov-Tarnovski - Multiplatform Java application develo...
Domain Specific Development using T4
WEPA - Webdriver Enhanced Platform for Automation - WEPATest
Introduction to Scala for Java Developers
Enterprise messaging
CBDW2014 - Down the RabbitMQ hole with ColdFusion
PHP, the GraphQL ecosystem and GraphQLite
Java SE 7 New Features and Enhancements

Similar to Avro and its awesomeness (19)

PDF
The Good, The Bad, and The Avro (Graham Stirling, Saxo Bank and David Navalho...
PDF
Evolve Your Schemas in a Better Way! A Deep Dive into Avro Schema Compatibili...
PPTX
Apach avro
PPTX
Efficient Schemas in Motion with Kafka and Schema Registry
PPTX
End-to-end Data Governance with Apache Avro and Atlas
PDF
3 avro hug-2010-07-21
PDF
Data Evolution on HBase with Kiji
PDF
Data Evolution on HBase (with Kiji)
PPTX
Avro intro
PDF
Streaming Operational Data with MariaDB MaxScale
PDF
Type safe, versioned, and rewindable stream processing with Apache {Avro, K...
PDF
mypipe: Buffering and consuming MySQL changes via Kafka
PPTX
HBase Data Modeling and Access Patterns with Kite SDK
PDF
Kafka Summit SF 2017 - Efficient Schemas in Motion with Kafka and Schema Regi...
PPTX
HBaseCon 2012 | Living Data: Applying Adaptable Schemas to HBase - Aaron Kimb...
PPTX
avrointroduction-150325003254-conversion-gate01.pptx
PDF
Real-time, real estate listings with Apache Kafka
PPTX
Avro introduction
PPTX
Change data capture
The Good, The Bad, and The Avro (Graham Stirling, Saxo Bank and David Navalho...
Evolve Your Schemas in a Better Way! A Deep Dive into Avro Schema Compatibili...
Apach avro
Efficient Schemas in Motion with Kafka and Schema Registry
End-to-end Data Governance with Apache Avro and Atlas
3 avro hug-2010-07-21
Data Evolution on HBase with Kiji
Data Evolution on HBase (with Kiji)
Avro intro
Streaming Operational Data with MariaDB MaxScale
Type safe, versioned, and rewindable stream processing with Apache {Avro, K...
mypipe: Buffering and consuming MySQL changes via Kafka
HBase Data Modeling and Access Patterns with Kite SDK
Kafka Summit SF 2017 - Efficient Schemas in Motion with Kafka and Schema Regi...
HBaseCon 2012 | Living Data: Applying Adaptable Schemas to HBase - Aaron Kimb...
avrointroduction-150325003254-conversion-gate01.pptx
Real-time, real estate listings with Apache Kafka
Avro introduction
Change data capture
Ad

Recently uploaded (20)

PPTX
Chapter 5: Probability Theory and Statistics
PDF
From MVP to Full-Scale Product A Startup’s Software Journey.pdf
PDF
Hybrid model detection and classification of lung cancer
PPTX
TLE Review Electricity (Electricity).pptx
PDF
ENT215_Completing-a-large-scale-migration-and-modernization-with-AWS.pdf
PPTX
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
PDF
Enhancing emotion recognition model for a student engagement use case through...
PPTX
Tartificialntelligence_presentation.pptx
PDF
Heart disease approach using modified random forest and particle swarm optimi...
PDF
Accuracy of neural networks in brain wave diagnosis of schizophrenia
PDF
Transform Your ITIL® 4 & ITSM Strategy with AI in 2025.pdf
PDF
Building Integrated photovoltaic BIPV_UPV.pdf
PDF
A comparative study of natural language inference in Swahili using monolingua...
PDF
Mushroom cultivation and it's methods.pdf
PPTX
cloud_computing_Infrastucture_as_cloud_p
PDF
Assigned Numbers - 2025 - Bluetooth® Document
PPTX
SOPHOS-XG Firewall Administrator PPT.pptx
PPTX
Group 1 Presentation -Planning and Decision Making .pptx
PDF
Video forgery: An extensive analysis of inter-and intra-frame manipulation al...
PDF
gpt5_lecture_notes_comprehensive_20250812015547.pdf
Chapter 5: Probability Theory and Statistics
From MVP to Full-Scale Product A Startup’s Software Journey.pdf
Hybrid model detection and classification of lung cancer
TLE Review Electricity (Electricity).pptx
ENT215_Completing-a-large-scale-migration-and-modernization-with-AWS.pdf
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
Enhancing emotion recognition model for a student engagement use case through...
Tartificialntelligence_presentation.pptx
Heart disease approach using modified random forest and particle swarm optimi...
Accuracy of neural networks in brain wave diagnosis of schizophrenia
Transform Your ITIL® 4 & ITSM Strategy with AI in 2025.pdf
Building Integrated photovoltaic BIPV_UPV.pdf
A comparative study of natural language inference in Swahili using monolingua...
Mushroom cultivation and it's methods.pdf
cloud_computing_Infrastucture_as_cloud_p
Assigned Numbers - 2025 - Bluetooth® Document
SOPHOS-XG Firewall Administrator PPT.pptx
Group 1 Presentation -Planning and Decision Making .pptx
Video forgery: An extensive analysis of inter-and intra-frame manipulation al...
gpt5_lecture_notes_comprehensive_20250812015547.pdf
Ad

Avro and its awesomeness