NestJs не может найти какой-либо модуль при запуске в Dockerfile

У меня есть этот Dockerfile, который должен запускать мой проект nest.js:

# syntax:docker/dockerfile:1

#base
FROM node:16.14.2-alpine AS base

ENV NODE_ENV=production

WORKDIR /app

RUN npm i -g [email protected] @nestjs/cli

COPY ["./package.json", "./"]

#dev
FROM base AS dev

RUN npm i
COPY . .

CMD ["npm", "run", "start:dev"]

#prod
FROM base AS prod

COPY . .

RUN npm i --frozen-lockfile --production

CMD ["npm", "run", "start:prod"]

и когда я запускаю его с этим docker-compose.yml:

version: '3.9'

services:

  backend:                                      #THE BACKEND SIDE OF OUR APP ITSELF :
    build:
      context: ./back 
      #dockerfile: ./back/Dockerfile
      target: dev #for multi stage
    env_file:
      - ./env/back.env
    ports:
      - 2000:2000
    volumes:
      - ./back:/app
    networks:
      - backend
    depends_on:
      - database
    restart: unless-stopped

  database:                                      #THE POSTGRESQL DATABASE
    image: postgres:latest
    restart: unless-stopped
    ports:
      - 5432:5432
  #  env_file:
  #    - ./env/postgres.env
    environment:
      POSTGRES_USER: transcendeur
      POSTGRES_PASSWORD: bigData
      POSTGRES_DB: transcendb
    networks:
      - backend
    volumes:
      - postgres:/var/lib/postgresql/data

  databaseadmin:                                 #THE DATABASE 'ADMIN GRAPHICAL INTERFACE'
    image: dpage/pgadmin4:latest
    restart: unless-stopped
    ports:
      - 5050:80
    env_file:
      - ./env/pgadmin.env
    environment:
      PGADMIN_DEFAULT_EMAIL: [email protected]
      PGADMIN_DEFAULT_PASSWORD: dimnagp4
    networks:
      - backend
    volumes:
      - ./docker/pgadmin_servers.json:/pgadmin4/servers.json
    depends_on:
      - database
    logging:
      driver: none

  # frontend:                                       #THE FRONTEND SIDE OF OUR APP ITSELF :
  #   build:
  #     dockerfile: front/Dockerfile
  #   env_file:
  #     - ./env/front.env
  #   ports:
  #     - 8080:8080
  #   restart: unless-stopped
  #   networks:
  #     - backend
  #   volumes:
  #     - ./front:/app
  #   depends_on:
  #     - backend
    

volumes:
  postgres:
  back:

networks:
  backend:
    driver: bridge

Все строится нормально до тех пор, пока npm run start:dev, при компиляции мои файлы в папке src не могут разрешить какие-либо модули (например, @nestjs/common не найден)

Вот мой package.json:

{
  "name": "back",
  "version": "0.0.1",
  "description": "",
  "author": "",
  "private": true,
  "license": "UNLICENSED",
  "scripts": {
    "prebuild": "rimraf dist",
    "build": "nest build",
    "format": "prettier --write \"src/**/*.ts\" \"test/**/*.ts\"",
    "start": "DB_ENVFILE=db nest start",
    "start:dev": "DB_ENVFILE=db nest start --watch",
    "start:debug": "DB_ENVFILE=db nest start --debug --watch",
    "start:prod": "DB_ENVFILE=db node dist/main",
    "lint": "eslint \"{src,apps,libs,test}/**/*.ts\" --fix",
    "test": "DB_ENVFILE=db jest",
    "test:watch": "DB_ENVFILE=db jest --watch",
    "test:cov": "DB_ENVFILE=db jest --coverage",
    "test:debug": "DB_ENVFILE=db node --inspect-brk -r tsconfig-paths/register -r ts-node/register node_modules/.bin/jest --runInBand",
    "test:e2e": "DB_ENVFILE=db jest --config ./test/jest-e2e.json"
  },
  "dependencies": {
    "@nestjs/cli": "^9.0.0",
    "@nestjs/common": "^9.0.0",
    "@nestjs/config": "^2.2.0",
    "@nestjs/core": "^9.0.0",
    "@nestjs/mapped-types": "*",
    "@nestjs/platform-express": "^9.0.0",
    "@nestjs/swagger": "^6.1.3",
    "@nestjs/typeorm": "^9.0.1",
    "pg": "^8.8.0",
    "reflect-metadata": "^0.1.13",
    "rimraf": "^3.0.2",
    "rxjs": "^7.2.0",
    "swagger-ui-express": "^4.5.0",
    "typeorm": "^0.3.10"
  },
  "devDependencies": {
    "@nestjs/schematics": "^9.0.0",
    "@nestjs/testing": "^9.0.0",
    "@types/express": "^4.17.13",
    "@types/jest": "28.1.8",
    "@types/multer": "^1.4.7",
    "@types/node": "^16.0.0",
    "@types/supertest": "^2.0.11",
    "@typescript-eslint/eslint-plugin": "^5.0.0",
    "@typescript-eslint/parser": "^5.0.0",
    "eslint": "^8.0.1",
    "eslint-config-prettier": "^8.3.0",
    "eslint-plugin-prettier": "^4.0.0",
    "jest": "28.1.3",
    "prettier": "^2.3.2",
    "source-map-support": "^0.5.20",
    "supertest": "^6.1.3",
    "ts-jest": "28.0.8",
    "ts-loader": "^9.2.3",
    "ts-node": "^10.0.0",
    "tsconfig-paths": "4.1.0",
    "typescript": "^4.7.4"
  },
  "jest": {
    "moduleFileExtensions": [
      "js",
      "json",
      "ts"
    ],
    "rootDir": "src",
    "testRegex": ".*\\.spec\\.ts$",
    "transform": {
      "^.+\\.(t|j)s$": "ts-jest"
    },
    "collectCoverageFrom": [
      "**/*.(t|j)s"
    ],
    "coverageDirectory": "../coverage",
    "testEnvironment": "node"
  }
}

Я застрял на этом с сегодняшнего утра и не могу найти решения в других сообщениях, мой Dockerfile выглядит нормально, я не вижу, в чем может быть проблема.

Обновлено: я забыл сказать, что он отлично работает без докера при выполнении тех же команд

Сообщение об ошибке, которое я получаю, такое же, как если бы я сделал npm run start::dev без папки node_modules

Предоставление явной ошибки было бы полезно

Jay McDoniel 07.11.2022 22:41
Развертывание модели машинного обучения с помощью Flask - Angular в Kubernetes
Развертывание модели машинного обучения с помощью Flask - Angular в Kubernetes
Kubernetes - это портативная, расширяемая платформа с открытым исходным кодом для управления контейнерными рабочими нагрузками и сервисами, которая...
Как создать PHP Image с нуля
Как создать PHP Image с нуля
Сегодня мы создадим PHP Image from Scratch для того, чтобы легко развернуть базовые PHP-приложения. Пожалуйста, имейте в виду, что это разработка для...
0
1
145
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вы сначала копируете package.json, а затем весь код в рабочий каталог (/app) вашего изображения в Dockerfile и запускаете npm i в этом каталоге во время сборки.

Но в вашем docker-compose.yml вы привязываете каталог ./back/ к каталогу /app/ контейнера, что делает предыдущий npm install неактуальным, поскольку теперь содержимое ./back/ находится в этом каталоге, а не в образе.

Поэтому, пока на вашем хосте нет каталога node_modules, модули не могут быть найдены.

Итак, если я просто изменю путь к моему тому, он должен работать без node_modules?

Fayeure 07.11.2022 23:24

Нет, если вы смонтируете каталог ./back в контейнер, чтобы использовать файлы исходного кода непосредственно с хоста во время разработки (что, как я предполагаю, вы хотите сделать), вам также потребуются зависимости, установленные на хосте. Но вы можете использовать npm внутри контейнера, чтобы сделать это один раз, например. с docker-compose run --rm backend npm i.

acran 07.11.2022 23:46

Другие вопросы по теме