Bird
Raised Fist0
LLDsystem_design~12 mins

Hotel, Room, Booking classes in LLD - 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 - Hotel, Room, Booking classes

This system manages hotel room bookings. It allows users to view hotels, check room availability, and make bookings. The key requirements are to handle multiple hotels, rooms, and bookings efficiently and ensure data consistency.

Architecture Diagram
User
  |
  v
Load Balancer
  |
  v
API Gateway
  |
  v
Booking Service <-> Hotel Service <-> Room Service
  |                 |                 |
  v                 v                 v
Database           Database         Database
  |                 |                 |
  v                 v                 v
Cache              Cache            Cache
Components
User
client
End user interacting with the system to book rooms
Load Balancer
load_balancer
Distributes incoming user requests evenly across API Gateway instances
API Gateway
api_gateway
Routes requests to appropriate services and handles authentication
Booking Service
service
Manages booking creation, updates, and cancellations
Hotel Service
service
Manages hotel information and details
Room Service
service
Manages room details and availability
Database
database
Stores persistent data for each service
Cache
cache
Speeds up read operations by storing frequently accessed data
Request Flow - 12 Hops
UserLoad Balancer
Load BalancerAPI Gateway
API GatewayBooking Service
Booking ServiceRoom Service
Room ServiceCache
CacheRoom Service
Room ServiceDatabase
DatabaseRoom Service
Booking ServiceDatabase
Booking ServiceCache
Booking ServiceAPI Gateway
API GatewayUser
Failure Scenario
Component Fails:Database
Impact:Booking writes fail, new bookings cannot be saved; reads may still succeed from cache but data may be stale
Mitigation:Use database replication for failover; rely on cache for read operations temporarily; alert system admins for quick recovery
Architecture Quiz - 3 Questions
Test your understanding
Which component first receives the user's booking request?
ALoad Balancer
BAPI Gateway
CBooking Service
DRoom Service
Design Principle
This design uses a layered approach with load balancing, API gateway routing, and dedicated services for hotel, room, and booking management. Caches reduce database load and improve response times. The system separates concerns and ensures scalability and fault tolerance.

Practice

(1/5)
1. Which class is primarily responsible for storing information about individual rooms in a hotel system?
easy
A. Room
B. Hotel
C. Booking
D. Guest

Solution

  1. Step 1: Understand the role of each class

    The Hotel class manages the overall hotel, Booking handles reservations, and Room stores details about each room.
  2. Step 2: Identify which class holds room details

    Since Room is designed to represent individual rooms, it stores room number, type, and availability.
  3. Final Answer:

    Room -> Option A
  4. Quick Check:

    Room class = stores room info [OK]
Hint: Room class holds room details, not Hotel or Booking [OK]
Common Mistakes:
  • Confusing Hotel with Room class
  • Thinking Booking stores room details
  • Assuming Guest class stores room info
2. Which of the following is the correct way to represent a Booking class constructor in Python that takes room, guest, and date as parameters?
easy
A. def __init__(self, room, guest, date):
B. def Booking(room, guest, date):
C. def __booking__(self, room, guest, date):
D. def init(self, room, guest, date):

Solution

  1. Step 1: Recall Python constructor syntax

    Python constructors use the special method __init__ with self as the first parameter.
  2. Step 2: Match the correct method signature

    def __init__(self, room, guest, date): correctly uses def __init__(self, room, guest, date): which is the standard constructor format.
  3. Final Answer:

    def __init__(self, room, guest, date): -> Option A
  4. Quick Check:

    Constructor = __init__ method [OK]
Hint: Python constructors always use __init__(self, ...) [OK]
Common Mistakes:
  • Using method name other than __init__
  • Omitting self parameter
  • Using class name as method name
3. Given the following code snippet, what will be the output?
class Room:
    def __init__(self, number):
        self.number = number
        self.is_available = True

class Booking:
    def __init__(self, room):
        self.room = room
        self.room.is_available = False

room101 = Room(101)
print(room101.is_available)
booking1 = Booking(room101)
print(room101.is_available)
medium
A. True\nTrue
B. False\nTrue
C. False\nFalse
D. True\nFalse

Solution

  1. Step 1: Check initial availability of room101

    When room101 is created, is_available is set to True, so first print outputs True.
  2. Step 2: Booking changes room availability

    Booking constructor sets room101.is_available to False, so second print outputs False.
  3. Final Answer:

    True\nFalse -> Option D
  4. Quick Check:

    Initial True, then set False by Booking [OK]
Hint: Booking sets room availability to False immediately [OK]
Common Mistakes:
  • Assuming availability stays True after booking
  • Confusing order of prints
  • Ignoring side effect on room object
4. Identify the error in the following Booking class code snippet:
class Room:
    def __init__(self, number):
        self.number = number
        self.is_available = True

class Booking:
    def __init__(self, room, guest):
        self.room = room
        self.guest = guest
    def book(self):
        if self.room.is_available:
            self.room.is_available = False
            print("Booking successful")
        else:
            print("Room not available")

room = Room(201)
booking = Booking(room)
booking.book()
medium
A. is_available should be a method, not attribute
B. Missing guest argument when creating Booking instance
C. book method should return a value
D. Room class is not defined

Solution

  1. Step 1: Check Booking constructor parameters

    Booking __init__ requires room and guest, but only room is passed when creating booking instance.
  2. Step 2: Identify missing argument error

    Omitting guest argument causes a TypeError at runtime.
  3. Final Answer:

    Missing guest argument when creating Booking instance -> Option B
  4. Quick Check:

    Constructor args mismatch = missing guest [OK]
Hint: Match all constructor parameters when creating objects [OK]
Common Mistakes:
  • Ignoring missing guest argument
  • Assuming book method must return value
  • Thinking is_available must be a method
5. You want to design a system where a Hotel manages multiple Rooms and allows Bookings only if rooms are available. Which design approach best supports scalability and maintainability?
hard
A. Make Booking class manage all Rooms and Guests directly, without Hotel involvement.
B. Store all booking data inside Room class only, without separate Booking class.
C. Have Hotel class contain a list of Room objects, and Booking class references Room and Guest; Hotel checks availability before booking.
D. Use a single class combining Hotel, Room, and Booking functionalities.

Solution

  1. Step 1: Analyze class responsibilities

    Hotel should manage Rooms, Booking should link Rooms and Guests, keeping clear separation.
  2. Step 2: Evaluate design for scalability

    Have Hotel class contain a list of Room objects, and Booking class references Room and Guest; Hotel checks availability before booking. cleanly separates concerns, allowing Hotel to check availability and Booking to handle reservations, supporting easy maintenance and scaling.
  3. Final Answer:

    Hotel manages Rooms; Booking references Room and Guest; Hotel checks availability -> Option C
  4. Quick Check:

    Separation of concerns = Have Hotel class contain a list of Room objects, and Booking class references Room and Guest; Hotel checks availability before booking. [OK]
Hint: Separate Hotel, Room, Booking roles for clean design [OK]
Common Mistakes:
  • Combining all logic in one class
  • Booking managing Rooms directly
  • Ignoring availability checks in Hotel