Docker Compose 无法连接到数据库

ara*_*rad 4 docker docker-compose typeorm nestjs

我在后端使用 nestjs,并使用 typeorm 作为 ORM。我试图在 docker-compose 文件中定义我的数据库和我的应用程序。

如果我将我的数据库作为容器运行,而我的应用程序从我的本地机器运行,它运行良好。我的程序连接并创建表等。

但是,如果我尝试从容器内连接数据库或使用 docker-compose up 启动容器,则会失败。

总是得到一个 ECONNREFUSED 错误。

我的错误在哪里?

docker-compose.yml

version: '3.1'
volumes:
 dbdata:

services:
  db:
    image: postgres:10
    volumes:
      - ./dbData/:/var/lib/postgresql/data
    restart: always
    environment:
      - POSTGRES_PASSWORD=${TYPEORM_PASSWORD}
      - POSTGRES_USER=${TYPEORM_USERNAME}
      - POSTGRES_DB=${TYPEORM_DATABASE}
    ports:
      - ${TYPEORM_PORT}:5432

  backend:
    build: .
    ports:
      - "3001:3000"
    command: npm run start
    volumes:
      - .:/src
Run Code Online (Sandbox Code Playgroud)

文件

FROM node:10.5

WORKDIR /home

# Bundle app source
COPY . /home

# Install app dependencies
#RUN npm install -g nodemon
# If you are building your code for production
# RUN npm install --only=production
RUN npm i -g @nestjs/cli
RUN npm install

EXPOSE 3000
Run Code Online (Sandbox Code Playgroud)

.env

# .env
HOST=localhost
PORT=3000
NODE_ENV=development
LOG_LEVEL=debug

TYPEORM_CONNECTION=postgres
TYPEORM_HOST=localhost
TYPEORM_USERNAME=postgres
TYPEORM_PASSWORD=postgres
TYPEORM_DATABASE=mariokart
TYPEORM_PORT=5432
TYPEORM_SYNCHRONIZE=true
TYPEORM_DROP_SCHEMA=true
TYPEORM_LOGGING=all
TYPEORM_ENTITIES=src/database/entity/*.ts
TYPEORM_MIGRATIONS=src/database/migrations/**/*.ts
TYPEORM_SUBSCRIBERS=src/database/subscribers/**/*.ts
Run Code Online (Sandbox Code Playgroud)

我尝试使用链接,但它在容器中不起作用。

Ale*_*hin 13

看看你/etc/hostsbackend容器内部。你会看见

192.0.18.1    dir_db_1
Run Code Online (Sandbox Code Playgroud)

或类似的东西。IP 会有所不同,dir将代表您所在的目录。因此,您必须更改TYPEORM_HOST=localhostTYPEORM_HOST=dir_db_1.

虽然,我建议您为容器设置静态名称。

services:
  db:
    container_name: project_db
    ...
  backend:
    container_name: project_backend
Run Code Online (Sandbox Code Playgroud)

在这种情况下,您始终可以确定您的容器将具有一个静态名称,并且您可以设置TYPEORM_HOST=project_db并且永远不必再担心名称。