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 Jaime Orts-Caroff Jaime Orts-Caroff I'm a Senior Android developer, open to work in various fields Dor Yaloz Dor Yaloz SW engineer with 6+ years of experience, I worked with React/Node/Python did projects with React+Capacitor.js for ios Supabase expert 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.** Luca Liberati Luca Liberati I work on monoliths and microservices, backends and frontends, manage K8s clusters and love to design apps architecture rayush33 rayush33 JavaScript (React.js, React Native, Node.js) Developer with demonstrated industry experience of 4+ years, actively looking for opportunities to hone my skills as well as help small-scale business owners with solutions to technical problems Nam Tran Nam Tran 10 years as fullstack developer Bastien Labelle Bastien Labelle Full stack dev w/ 20+ years of experience Milan Surelia Milan Surelia Milan Surelia is a Mobile App Developer with 5+ years of experience crafting scalable, cross-platform apps at 7Span and Meticha. At 7Span, he engineers feature-rich Flutter apps with smooth performance and modern UI. As the Co-Founder of Meticha, he builds open-source tools and developer-focused products that solve real-world problems. Expertise: 💡 Developing cross-platform apps using Flutter, Dart, and Jetpack Compose for Android, iOS, and Web. 🖋️ Sharing insights through technical writing, blogging, and open-source contributions. 🤝 Collaborating closely with designers, PMs, and developers to build seamless mobile experiences. Notable Achievements: 🎯 Revamped the Vepaar app into Vepaar Store & CRM with a 2x performance boost and smoother UX. 🚀 Launched Compose101 — a Jetpack Compose starter kit to speed up Android development. 🌟 Open source contributions on Github & StackOverflow for Flutter & Dart 🎖️ Worked on improving app performance and user experience with smart solutions. Milan is always happy to connect, work on new ideas, and explore the latest in technology. Matthew Jordan Matthew Jordan I've been working at a large software company named Kainos for 2 years, and mainly specialise in Platform Engineering. I regularly enjoy working on software products outside of work, and I'm a huge fan of game development using Unity. I personally enjoy Python & C# in my spare time, but I also specialise in multiple different platform-related technologies from my day job.

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