Interview kitsBlog

Your dream job? Lets Git IT.
Interactive technical interview preparation platform designed for modern developers.

XGitHub

Platform

  • Categories

Resources

  • Blog
  • About the app
  • FAQ
  • Feedback

Legal

  • Privacy Policy
  • Terms of Service

© 2026 LetsGit.IT. All rights reserved.

LetsGit.IT/Categories/Monoliths
Monolithshard

What is a “distributed monolith” and how do you avoid it?

Tags
#distributed-monolith#coupling#microservices
Back to categoryPractice quiz

Answer

It’s a system split into services, but still tightly coupled (shared DB, synchronous chatty calls, coordinated deployments). Avoid it by clear ownership, async where appropriate, stable contracts, and independent deployability.

Advanced answer

Deep dive

Expanding on the short answer — what usually matters in practice:

  • Context (tags): distributed-monolith, coupling, microservices
  • Scaling: what scales horizontally vs vertically, where bottlenecks appear.
  • Reliability: retries/circuit breakers/idempotency, observability (logs/metrics/traces).
  • Evolution: keep changes cheap (boundaries, contracts, tests).
  • Explain the "why", not just the "what" (intuition + consequences).
  • Trade-offs: what you gain/lose (time, memory, complexity, risk).
  • Edge cases: empty inputs, large inputs, invalid inputs, concurrency.

Examples

A tiny example (an explanation template):

// Example: discuss trade-offs for "what-is-a-“distributed-monolith”-and-how-do-you-"
function explain() {
  // Start from the core idea:
  // It’s a system split into services, but still tightly coupled (shared DB, synchronous chatt
}

Common pitfalls

  • Too generic: no concrete trade-offs or examples.
  • Mixing average-case and worst-case (e.g., complexity).
  • Ignoring constraints: memory, concurrency, network/disk costs.

Interview follow-ups

  • When would you choose an alternative and why?
  • What production issues show up and how do you diagnose them?
  • How would you test edge cases?

Related questions

Monoliths
What is a “big ball of mud” and how can you recognize it?
#maintainability#coupling#code-smell
Monoliths
Strangler Fig migration — outline the steps.
#strangler-fig#migration#microservices
Monoliths
When is a monolith a better choice than microservices?
#monolith#microservices
#team-size
Monoliths
Strategies to migrate from a monolith to microservices?
#migration#strangler-fig#microservices
Testing
What is contract testing and when is it useful?
#contract-testing#api#microservices
Microservices
Trace context propagation: what is the `traceparent` header and why should services forward it?
#microservices#observability#tracing