PracHub
QuestionsPremiumCoachesLearningGuidesInterview Prep
|Home/System Design/Nordstrom

Design and evolve a reservation system

Last updated: Mar 29, 2026

Quick Overview

This question evaluates a candidate's ability to design scalable, concurrent backend systems, covering data modeling, consistency and concurrency control, API design, capacity and waitlist management, as well as reliability and security considerations.

  • hard
  • Nordstrom
  • System Design
  • Software Engineer

Design and evolve a reservation system

Company: Nordstrom

Role: Software Engineer

Category: System Design

Difficulty: hard

Interview Round: Onsite

Design an online reservation system that supports creating, modifying, and canceling reservations while preventing double-booking. Specify APIs, data model, consistency guarantees, idempotency, concurrency control, and handling of capacity limits, waitlists, and expiration/TTL. Discuss trade-offs between alternative approaches (e.g., optimistic vs. pessimistic locking; relational vs. NoSQL; centralized vs. sharded inventory). Explain how you would scale the design as traffic grows (partitioning, caching, queues, rate limiting, backpressure, monitoring, failure recovery). Identify key security and privacy concerns and mitigations. Which deployment strategy (blue/green, canary, rolling) would you choose and why? When designing features or services in general, what principles and risks do you prioritize first?

Quick Answer: This question evaluates a candidate's ability to design scalable, concurrent backend systems, covering data modeling, consistency and concurrency control, API design, capacity and waitlist management, as well as reliability and security considerations.

Nordstrom logo
Nordstrom
Jul 17, 2025, 12:00 AM
Software Engineer
Onsite
System Design
7
0

System Design: Online Reservation System

You are designing a backend platform to book time-based slots for services or events (e.g., appointments, classes, tables). Each resource offers time slots with a fixed capacity. The system must prevent double-booking under high concurrency and support lifecycle operations.

Assume a single region to start, with the need to scale reads (availability lookups) more than writes (bookings). Payments are out of scope; focus on reservation integrity.

Requirements

  1. Core capabilities
    • Create, modify, and cancel reservations.
    • Prevent double-booking and overselling capacity.
  2. APIs
    • Specify external-facing endpoints and request/response behaviors.
    • Define idempotency strategy for write APIs.
  3. Data model
    • Entities, relationships, and key indexes/constraints.
  4. Consistency and concurrency
    • Consistency guarantees for reads/writes.
    • Concurrency control approach to avoid double-booking.
  5. Capacity, waitlists, and expiration
    • Capacity checks, holds, waitlist mechanics, and TTL/expiration handling.
  6. Trade-offs
    • Optimistic vs. pessimistic locking.
    • Relational vs. NoSQL stores.
    • Centralized vs. sharded inventory.
  7. Scaling and reliability
    • Partitioning, caching, queues, rate limiting, backpressure.
    • Monitoring, alerting, and failure recovery patterns.
  8. Security and privacy
    • Key risks and mitigations.
  9. Deployment
    • Choose between blue/green, canary, and rolling; justify your choice.
  10. Product engineering principles
  • What principles and risks do you prioritize when designing features/services?

Solution

Show

Submit Your Answer

Sign in to leave a comment

Loading comments...

Browse More Questions

More System Design•More Nordstrom•More Software Engineer•Nordstrom Software Engineer•Nordstrom System Design•Software Engineer System Design
PracHub

Master your tech interviews with 8,500+ real questions from top companies.

Product

  • Questions
  • Learning Tracks
  • Interview Guides
  • Resources
  • Premium
  • For Universities
  • Student Access

Browse

  • By Company
  • By Role
  • By Category
  • Topic Hubs
  • SQL Questions
  • Compare Platforms
  • Discord Community

Support

  • support@prachub.com
  • (916) 541-4762

Legal

  • Privacy Policy
  • Terms of Service
  • About Us

© 2026 PracHub. All rights reserved.