🌐 Detecting your location…
📢 Advertisement — Configure AdSense in Appearance → Customize → AdSense Settings

2026 में स्थानीय विकास के लिए डॉकर कंपोज़ का उपयोग कैसे करें: संपूर्ण गाइड

⏱️4 min read  ·  699 words

{
“@context”: “https://schema.org”,
“@type”: “TechArticle”,
“headline”: “2026 में स्थानीय विकास के लिए डॉकर कंपोज़ का उपयोग कैसे करें: संपूर्ण गाइड”,
“description”: “2026 में स्थानीय विकास के लिए मास्टर डॉकर कंपोज़ – मल्टी-सर्विस सेटअप, हॉट रीलोड, नेटवर्किंग, वॉल्यूम, रहस्य और उत्पादन समता।”,
“url”: “https://techpulsesite.com/how-to-use-docker-compose-for-local-deve-hi/”,
“datePublished”: “2026-06-28T11:05:00+00:00”,
“dateModified”: “2026-06-29T04:14:18+00:00”,
“author”: {
“@type”: “Organization”,
“name”: “TechPulse Editorial Team”,
“url”: “https://techpulsesite.com”
},
“publisher”: {
“@type”: “Organization”,
“name”: “TechPulse”,
“url”: “https://techpulsesite.com”
},
“inLanguage”: “hi”
}

{
“@context”: “https://schema.org”,
“@type”: “TechArticle”,
“headline”: “2026 में स्थानीय विकास के लिए डॉकर कंपोज़ का उपयोग कैसे करें: संपूर्ण गाइड”,
“description”: “2026 में स्थानीय विकास के लिए मास्टर डॉकर कंपोज़ – मल्टी-सर्विस सेटअप, हॉट रीलोड, नेटवर्किंग, वॉल्यूम, रहस्य और उत्पादन समता।”,
“url”: “https://techpulsesite.com/how-to-use-docker-compose-for-local-deve-hi/”,
“datePublished”: “2026-06-28T11:05:00+00:00”,
“dateModified”: “2026-06-28T18:21:25+00:00”,
“author”: {
“@type”: “Organization”,
“name”: “TechPulse Editorial Team”,
“url”: “https://techpulsesite.com”
},
“publisher”: {
“@type”: “Organization”,
“name”: “TechPulse”,
“url”: “https://techpulsesite.com”
},
“inLanguage”: “hi”
}

डॉकर कम्पोज़ स्थानीय विकास को “मेरी मशीन पर काम करता है” से पुनरुत्पादित, उत्पादन-जैसे वातावरण में बदल देता है जिसे टीम का प्रत्येक सदस्य मिनटों में पूरा कर सकता है। 2026 में, डॉकर डेस्कटॉप और सीएलआई में निर्मित डॉकर कंपोज़ v2 के साथ, बहु-सेवा स्थानीय स्टैक के प्रबंधन के लिए कोई बेहतर उपकरण नहीं है।

विकास के लिए डॉकर कंपोज़ क्यों?

  • एक कमांड के साथ पोस्टग्रेज, रेडिस, अपने एपीआई और एक कतार कार्यकर्ता को स्पिन करें
  • “यह मेरी मशीन पर काम करता है” को हटा दें – प्रत्येक डेवलपर के पास समान वातावरण होते हैं
  • Kubernetes चलाए बिना उत्पादन सेवा टोपोलॉजी का स्थानीय स्तर पर मिलान करें
  • नोड संस्करण, डेटाबेस संस्करण, या सेवा कॉन्फ़िगरेशन के बीच आसानी से स्विच करें

परियोजना सेटअप: पूर्ण-स्टैक अनुप्रयोग

हम इसके लिए एक कंपोज़ सेटअप बनाएंगे: नेक्स्ट.जेएस फ्रंटएंड, फास्टएपीआई बैकएंड, पोस्टग्रेएसक्यूएल, रेडिस और एक सेलेरी वर्कर।

myapp/
├── docker-compose.yml
├── docker-compose.override.yml    # local dev overrides
├── frontend/
│   ├── Dockerfile
│   └── ...
├── backend/
│   ├── Dockerfile
│   └── ...
└── .env.local

कोर docker-compose.yml

version: "3.9"

services:
  # ── PostgreSQL ─────────────────────────────────────────────
  db:
    image: postgres:15-alpine
    environment:
      POSTGRES_DB: ${DB_NAME:-myapp}
      POSTGRES_USER: ${DB_USER:-postgres}
      POSTGRES_PASSWORD: ${DB_PASS:-devpassword}
    volumes:
      - postgres_data:/var/lib/postgresql/data
      - ./backend/scripts/init.sql:/docker-entrypoint-initdb.d/init.sql
    ports:
      - "5432:5432"
    healthcheck:
      test: ["CMD-SHELL", "pg_isready -U postgres"]
      interval: 5s
      timeout: 5s
      retries: 5

  # ── Redis ──────────────────────────────────────────────────
  redis:
    image: redis:7-alpine
    ports:
      - "6379:6379"
    command: redis-server --maxmemory 256mb --maxmemory-policy allkeys-lru

  # ── FastAPI Backend ────────────────────────────────────────
  backend:
    build:
      context: ./backend
      dockerfile: Dockerfile.dev
    volumes:
      - ./backend:/app                    # hot reload: source mounted
    ports:
      - "8000:8000"
    environment:
      DATABASE_URL: postgresql://postgres:devpassword@db:5432/myapp
      REDIS_URL: redis://redis:6379/0
      ENV: development
    depends_on:
      db:
        condition: service_healthy
      redis:
        condition: service_started
    command: uvicorn app.main:app --host 0.0.0.0 --port 8000 --reload

  # ── Celery Worker ──────────────────────────────────────────
  worker:
    build:
      context: ./backend
      dockerfile: Dockerfile.dev
    volumes:
      - ./backend:/app
    environment:
      DATABASE_URL: postgresql://postgres:devpassword@db:5432/myapp
      REDIS_URL: redis://redis:6379/0
    depends_on: [db, redis]
    command: celery -A app.tasks worker --loglevel=info

  # ── Next.js Frontend ───────────────────────────────────────
  frontend:
    build:
      context: ./frontend
      dockerfile: Dockerfile.dev
    volumes:
      - ./frontend:/app
      - /app/node_modules              # anonymous volume prevents override
    ports:
      - "3000:3000"
    environment:
      NEXT_PUBLIC_API_URL: http://localhost:8000
    command: npm run dev

volumes:
  postgres_data:

हॉट रीलोड के लिए डॉकरफाइल का विकास

# backend/Dockerfile.dev
FROM python:3.11-slim
WORKDIR /app
COPY requirements.txt .
RUN pip install -r requirements.txt
# Don't copy source — it's mounted as volume for hot reload
CMD ["uvicorn", "app.main:app", "--host", "0.0.0.0", "--reload"]
# frontend/Dockerfile.dev
FROM node:20-alpine
WORKDIR /app
COPY package*.json ./
RUN npm install
# Source mounted as volume; node_modules stays in container
CMD ["npm", "run", "dev"]

स्थानीय अनुकूलन के लिए फ़ाइल को ओवरराइड करें

# docker-compose.override.yml (not committed to git)
# Each developer's personal overrides

services:
  backend:
    environment:
      DEBUG: "true"
      LOG_LEVEL: debug
    ports:
      - "8000:8000"
      - "5678:5678"    # debugger port

  db:
    ports:
      - "5432:5432"    # expose to host for TablePlus/DBeaver access

डॉकर कंपोज़ स्वचालित रूप से विलीन हो जाता हैdocker-compose.override.yml आधार फ़ाइल के साथ – निर्दिष्ट करने की कोई आवश्यकता नहीं है-f.

आवश्यक आदेश

# Start everything
docker compose up -d

# View logs (all services)
docker compose logs -f

# View logs for one service
docker compose logs -f backend

# Run a command in a service
docker compose exec backend python manage.py migrate
docker compose exec db psql -U postgres -d myapp

# Rebuild a specific service after Dockerfile change
docker compose up -d --build backend

# Stop and remove everything (keep volumes)
docker compose down

# Stop, remove containers AND volumes (fresh slate)
docker compose down -v

# Scale a service
docker compose up -d --scale worker=3

रहस्यों को उचित रूप से प्रबंधित करना

# .env.local (gitignored)
DB_PASS=mylocalsecretpassword
SECRET_KEY=dev-only-not-production

# docker-compose.yml references env vars
environment:
  DB_PASS: ${DB_PASS}

# Or use Docker secrets for production-like setups
secrets:
  db_password:
    file: ./secrets/db_password.txt

services:
  backend:
    secrets: [db_password]

सेवाओं के बीच नेटवर्किंग

समान कंपोज़ फ़ाइल में सेवाएँ सेवा नाम से संचार करती हैं। आपका बैकएंडdb:5432पर PostgreSQL से जुड़ता है , नहींlocalhost:5432. यह उत्पादन कंटेनर नेटवर्किंग से बिल्कुल मेल खाता है:

# backend connects to other services by service name
DATABASE_URL=postgresql://postgres:pass@db:5432/myapp
REDIS_URL=redis://redis:6379/0

# NOT localhost — that would be the container itself
# NOT the host IP — that breaks portability

स्वास्थ्य जांच और सेवा निर्भरताएँ

services:
  backend:
    depends_on:
      db:
        condition: service_healthy    # waits for DB to pass healthcheck
      redis:
        condition: service_started    # just waits for container to start

  db:
    healthcheck:
      test: ["CMD-SHELL", "pg_isready -U postgres"]
      interval: 5s
      retries: 5
      start_period: 10s

उत्पादन बनाम विकास फ़ाइलें लिखें

# Use specific files explicitly
docker compose -f docker-compose.yml up -d                          # dev
docker compose -f docker-compose.yml -f docker-compose.prod.yml up -d  # prod

# In production: remove volume mounts, use built images, add resource limits
# docker-compose.prod.yml
services:
  backend:
    image: myapp-backend:1.2.0    # pinned production image
    restart: unless-stopped
    deploy:
      resources:
        limits:
          memory: 512m

अक्सर पूछे जाने वाले प्रश्न

प्रश्न: स्थानीय विकास के लिए डॉकर कंपोज़ बनाम कुबेरनेट्स?
ए: स्थानीय विकास के लिए डॉकर कंपोज़। उत्पादन के लिए कुबेरनेट्स। Kubernetes कॉन्फ़िगरेशन के स्थानीय स्तर पर परीक्षण के लिए Minikube या k3d। डेव वर्कफ़्लोज़ के लिए कंपोज़ सरल, तेज़ और पर्याप्त है।

प्रश्न: मेरा कोड परिवर्तन वॉल्यूम माउंट के साथ भी प्रतिबिंबित क्यों नहीं होता है?
उत्तर: हॉट रीलोड फ्रेमवर्क (FastAPI –reload, Next.js dev सर्वर) पर निर्भर करता है। यदि काम नहीं कर रहा है, तो जांचें कि वॉल्यूम माउंट पथ सही है और कंटेनर की कार्यशील निर्देशिका मेल खाती है। साथ ही सेवा पुनः आरंभ करें:docker compose restart backend.

प्रश्न: मैं डेटाबेस माइग्रेशन स्वचालित रूप से कैसे चला सकता हूँ?
उ: अपनी सेवा में एक कमांड जोड़ें या एक अलग माइग्रेशन सेवा का उपयोग करें:docker compose run --rm backend alembic upgrade head. या सर्वर शुरू करने से पहले इसे Entrypoint.sh में जोड़ें।

प्रश्न: मैं सेवाओं के बीच डेटा कैसे साझा करूं?
ए: डेटाबेस डेटा के लिए नामित वॉल्यूम के माध्यम से। कॉन्फ़िगरेशन के लिए पर्यावरण चर के माध्यम से। सेवा-से-सेवा संचार के लिए नेटवर्क के माध्यम से। कंटेनरों के बीच बाइंड-माउंटिंग फ़ाइलों से बचें – इसके बजाय सेवा एपीआई का उपयोग करें।

प्रश्न: मैं डॉकर में चल रही सेवा को कैसे डिबग करूं?
उ: अपनी कंपोज़ फ़ाइल में डिबगर पोर्ट को मैप करें, अपनी आईडीई (वीएस कोड का रिमोट – कंटेनर या पायथन डिबगपी) कॉन्फ़िगर करें। या कंटेनर में निष्पादित करें:docker compose exec backend bash.

निष्कर्ष

डॉकर कंपोज़ 2026 में स्थानीय बहु-सेवा विकास के लिए निश्चित उपकरण है। इस गाइड में सेटअप – बेस कंपोज़ फ़ाइल + ओवरराइड फ़ाइल + उचित वॉल्यूम माउंट + हेल्थचेक – आपको स्थानीय स्तर पर उत्पादन समता, तेज़ विकास के लिए हॉट रीलोड और नए टीम के सदस्यों के लिए एक-कमांड शुरुआत देता है। इसे ठीक से सेट करने में 2-3 घंटे का समय लगाएं और “यह मेरी मशीन पर काम करता है” डिबगिंग के सैकड़ों घंटे बचाएं।

✍️ Leave a Comment

Your email address will not be published. Required fields are marked *

🌐 Read in:🇩🇪 Deutsch🇧🇷 Português🇸🇦 العربية🇮🇳 हिन्दी🇧🇩 বাংলা