Patterns

  • File Sync Pattern

Expected topics

  • Dropbox
  • File Sync Pattern
  • chunk
  • client
  • server
  • client A
  • client B / C
  • design pattern
  • user
  • conflict

Self-check prompts

  • What users, scale, latency, availability, and consistency requirements should you clarify for Dropbox?
  • What are the main APIs, data model, and request flow?
  • Where is the main bottleneck around File Sync Pattern, chunk, client, and how would you scale it?
  • What failure mode matters most, and how do retry, recovery, and idempotency work?
  • Which trade-off would you choose, what do you lose, and when would you change that decision?

Common mistakes

  • Jumping into vendor names before clarifying requirements and scale.
  • Listing components without explaining the end-to-end request flow.
  • Leaving the bottleneck vague instead of quantifying capacity, partitioning, and recovery behavior.
  • Mentioning trade-offs without choosing an option and explaining the condition that would change the decision.