Claude Code integration

Docker Compose Services Fail to Connect Due to Wrong Names

Your Docker Compose setup generated by Claude Code has services that fail to connect to each other. The application container can't reach the database, the backend can't connect to Redis, or the worker can't find the message broker. Everything works when running services individually but fails in Docker Compose.

Docker Compose creates a network where services can reach each other by their service name. When the application code uses 'localhost' or hardcoded IPs instead of service names, or when service names in docker-compose.yml don't match what the application expects, connections fail.

This is especially frustrating because the error messages often just say 'connection refused' or 'host not found' without indicating that the issue is a name mismatch.

Error Messages You Might See

Error: connect ECONNREFUSED 127.0.0.1:5432 psql: could not connect to server: Connection refused redis.exceptions.ConnectionError: Error connecting to redis:6379 getaddrinfo ENOTFOUND database Name or service not known
Error: connect ECONNREFUSED 127.0.0.1:5432psql: could not connect to server: Connection refusedredis.exceptions.ConnectionError: Error connecting to redis:6379getaddrinfo ENOTFOUND databaseName or service not known

Common Causes

  • Using localhost instead of service name — Application code connects to localhost:5432 but the database is in a separate container reachable by its service name
  • Service name mismatch — docker-compose.yml defines the service as 'postgres' but the app config references 'db' or 'database'
  • Missing depends_on — The app container starts before the database is ready to accept connections
  • Wrong port mapping confusion — Using the host-mapped port (5433) instead of the container's internal port (5432)
  • Custom network not shared — Services in different docker-compose files or custom networks can't see each other

How to Fix It

  1. Replace localhost with service names — Change database URLs from localhost:5432 to postgres:5432 (matching the service name in docker-compose.yml)
  2. Use environment variables for hostnames — Define DB_HOST, REDIS_HOST as environment variables in docker-compose.yml pointing to the correct service names
  3. Add proper health checks — Use healthcheck in docker-compose.yml and depends_on with condition: service_healthy to wait for dependencies
  4. Use internal container ports — Between containers, always use the internal port (5432), not the host-mapped port (5433:5432)
  5. Verify with docker compose exec — Shell into a container and try to ping or connect to the service name to debug networking

Real developers can help you.

legrab legrab I'll fill this later Prakash Prajapati Prakash Prajapati I’m a Senior Python Developer specializing in building secure, scalable, and highly available systems. I work primarily with Python, Django, FastAPI, Docker, PostgreSQL, and modern AI tooling such as PydanticAI, focusing on clean architecture, strong design principles, and reliable DevOps practices. I enjoy solving complex engineering problems and designing systems that are maintainable, resilient, and built to scale. Omar Faruk Omar Faruk As a Product Engineer at Klasio, I contributed to end-to-end product development, focusing on scalability, performance, and user experience. My work spanned building and refining core features, developing dynamic website templates, integrating secure and reliable payment gateways, and optimizing the overall system architecture. I played a key role in creating a scalable and maintainable platform to support educators and learners globally. I'm enthusiastic about embracing new challenges and making meaningful contributions. hanson1014 hanson1014 Full-stack developer experienced in fixing and deploying AI-generated apps from Lovable, Bolt.new, Cursor, and Replit. I specialize in debugging Supabase integration issues (auth flows, RLS policies, database connections), fixing broken deployments, resolving routing/blank screen problems, and cleaning up messy React/Vite codebases. I also build production apps with the Claude API and have shipped a Mac desktop dev tool (Nexterm from scratch. Based in Hong Kong, fast turnaround. Tejas Chokhawala Tejas Chokhawala Full-stack engineer with 5 years experience building production web apps using React, Next.js and TypeScript. Focused on performance, clean architecture and shipping fast. Experienced with Supabase/Postgres backends, Stripe billing, and building AI-assisted developer tools. Matthew Butler Matthew Butler Systems Development Engineer @ Amazon Web Services Caio Rodrigues Caio Rodrigues I'm a full-stack developer focused on building practical and scalable web applications. My main experience is with **React, TypeScript, and modern frontend architectures**, where I prioritize clean code, component reusability, and maintainable project structures. I have strong experience working with **dynamic forms, state management (Redux / React Hook Form), and complex data-driven interfaces**. I enjoy solving real-world problems by turning ideas into reliable software that companies can actually use in their daily operations. Beyond coding, I care about **software quality and architecture**, following best practices for componentization, code organization, and performance optimization. I'm also comfortable working across the stack when needed, integrating APIs, handling business logic, and helping transform prototypes into production-ready systems. My goal is always to deliver solutions that are **simple, efficient, and genuinely useful for the people using them.** Pratik Pratik SWE with 15+ years of experience building and maintaining web apps and extensive BE infrastructure Antriksh Narang Antriksh Narang 5 years+ Experienced Dev (Specially in Web Development), can help in python, javascript, react, next.js and full stack web dev technologies. Nam Tran Nam Tran 10 years as fullstack developer

You don't need to be technical. Just describe what's wrong and a verified developer will handle the rest.

Get Help

Frequently Asked Questions

Why can't my app container connect to the database using localhost?

In Docker Compose, each service runs in its own container with its own network namespace. localhost refers to the container itself, not other containers. Use the service name defined in docker-compose.yml (e.g., 'postgres') as the hostname.

How do I wait for the database to be ready before starting my app?

Use depends_on with a health check. Define a healthcheck on the database service (e.g., pg_isready) and set depends_on: postgres: condition: service_healthy on your app service.

Related Claude Code Issues

Can't fix it yourself?
Real developers can help.

You don't need to be technical. Just describe what's wrong and a verified developer will handle the rest.

Get Help