Bird
Raised Fist0
Microservicessystem_design~12 mins

Event schema design in Microservices - Architecture Diagram

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
System Overview - Event schema design

This system handles event-driven communication between microservices. It ensures that events are structured with a clear schema for consistency and easy integration. Key requirements include schema validation, versioning, and reliable event delivery.

Architecture Diagram
User
  |
  v
Event Producer Service
  |
  v
Message Broker (Event Bus)
  |
  v
Event Consumer Service
  |
  v
Schema Registry
Components
User
actor
Initiates actions that generate events
Event Producer Service
service
Generates events following a defined schema
Message Broker (Event Bus)
message_queue
Transports events asynchronously between services
Event Consumer Service
service
Receives and processes events based on schema
Schema Registry
service
Stores and manages event schemas for validation and versioning
Request Flow - 6 Hops
UserEvent Producer Service
Event Producer ServiceSchema Registry
Event Producer ServiceMessage Broker (Event Bus)
Message Broker (Event Bus)Event Consumer Service
Event Consumer ServiceSchema Registry
Event Consumer ServiceEvent Consumer Service
Failure Scenario
Component Fails:Schema Registry
Impact:Event validation fails, causing event production and consumption to halt or process invalid data
Mitigation:Use schema caching in services and deploy schema registry with high availability and replication
Architecture Quiz - 3 Questions
Test your understanding
Which component ensures that events follow a consistent structure?
ASchema Registry
BMessage Broker
CEvent Consumer Service
DUser
Design Principle
This design shows how a schema registry centralizes event format definitions to ensure consistency and compatibility across microservices. Using a message broker decouples services for scalability and reliability.

Practice

(1/5)
1. What is the main purpose of an event schema in microservices?
easy
A. To define the structure and content of messages exchanged between services
B. To store user data in a database
C. To create user interfaces for microservices
D. To manage network connections between services

Solution

  1. Step 1: Understand event schema role

    An event schema defines how messages look when services talk to each other.
  2. Step 2: Identify correct purpose

    It ensures all services understand the message format and data.
  3. Final Answer:

    To define the structure and content of messages exchanged between services -> Option A
  4. Quick Check:

    Event schema = message format [OK]
Hint: Event schema = message format for services [OK]
Common Mistakes:
  • Confusing event schema with database storage
  • Thinking event schema manages UI or network
  • Assuming event schema is about service deployment
2. Which of the following is a correct JSON snippet for an event schema with type and timestamp?
easy
A. {eventType: "OrderCreated", "timestamp": "2024-06-01T12:00:00Z"}
B. {"eventType": OrderCreated, "timestamp": 2024-06-01T12:00:00Z}
C. {"eventType": "OrderCreated", timestamp: "2024-06-01T12:00:00Z"}
D. {"eventType": "OrderCreated", "timestamp": "2024-06-01T12:00:00Z"}

Solution

  1. Step 1: Check JSON syntax rules

    Keys and string values must be in double quotes; commas separate pairs.
  2. Step 2: Validate each option

    {"eventType": "OrderCreated", "timestamp": "2024-06-01T12:00:00Z"} uses correct quotes and format; others miss quotes or have invalid syntax.
  3. Final Answer:

    {"eventType": "OrderCreated", "timestamp": "2024-06-01T12:00:00Z"} -> Option D
  4. Quick Check:

    Valid JSON = {"eventType": "OrderCreated", "timestamp": "2024-06-01T12:00:00Z"} [OK]
Hint: JSON keys and strings need double quotes [OK]
Common Mistakes:
  • Missing quotes around keys or string values
  • Using unquoted date/time strings
  • Omitting commas between pairs
3. Given this event schema snippet:
{"eventType": "UserSignedUp", "timestamp": "2024-06-01T10:00:00Z", "data": {"userId": 123, "email": "user@example.com"}}

What will be the value of data.email in the event?
medium
A. 123
B. "UserSignedUp"
C. "user@example.com"
D. 2024-06-01T10:00:00Z

Solution

  1. Step 1: Locate the data field in the event

    The event has a nested object under "data" with keys "userId" and "email".
  2. Step 2: Identify the value of data.email

    The value for "email" is "user@example.com" as a string.
  3. Final Answer:

    "user@example.com" -> Option C
  4. Quick Check:

    data.email = "user@example.com" [OK]
Hint: Look inside data object for email key [OK]
Common Mistakes:
  • Confusing userId with email
  • Picking eventType or timestamp instead
  • Ignoring nested structure
4. Identify the error in this event schema:
{"eventType": "PaymentProcessed", "timestamp": "2024-06-01T15:00:00Z", "data": {"amount": 100, "currency": USD}}
medium
A. Missing comma after amount key
B. Missing quotes around the currency value USD
C. timestamp format is incorrect
D. eventType should be lowercase

Solution

  1. Step 1: Check JSON value types

    String values must be in double quotes; USD is unquoted here.
  2. Step 2: Verify other parts

    Comma after amount is present, timestamp format is ISO standard, eventType case is allowed.
  3. Final Answer:

    Missing quotes around the currency value USD -> Option B
  4. Quick Check:

    Strings need quotes [OK]
Hint: String values must have quotes in JSON [OK]
Common Mistakes:
  • Ignoring missing quotes on string values
  • Thinking timestamp format is wrong
  • Assuming key case matters in JSON
5. You want to design an event schema for a microservice that sends user profile updates. Which design choice improves schema flexibility for future changes?
hard
A. Include a 'metadata' field to hold optional extra info
B. Fix the schema to only allow 'name' and 'email' fields
C. Use a flat schema without nested objects
D. Exclude timestamps to reduce message size

Solution

  1. Step 1: Understand schema flexibility needs

    Flexible schemas allow adding new info without breaking existing services.
  2. Step 2: Evaluate options for flexibility

    Adding a 'metadata' field lets you add optional data later safely.
  3. Final Answer:

    Include a 'metadata' field to hold optional extra info -> Option A
  4. Quick Check:

    Optional metadata = flexible schema [OK]
Hint: Add metadata field for optional future data [OK]
Common Mistakes:
  • Fixing schema too rigidly limits future changes
  • Removing timestamps loses event timing info
  • Avoiding nested objects reduces clarity