Ошибка при развертывании node.js приложение к heroku (не удается найти модуль dotenv и ОШИБКА npm! ошибка 1)

#node.js #heroku #deployment #errno #dotenv

#node.js #heroku #развертывание #ошибка #dotenv

Вопрос:

Я пытаюсь загрузить свой первый node.js приложение к heroku. Сборка выполнена успешно, но приложение не может быть открыто в браузере. Вот хвост журнала развертывания. Я не совсем уверен, в чем проблема (проблемы). Все маршруты локального хоста фактически работают при тестировании с postman. Я использую экспресс-генератор, поэтому ПОРТ объявлен в .bin/www. Я также использую .env. Я немного растерялся, где искать дальше. Есть предложения? Большое спасибо!

 2021-01-11T22:10:14.214188 00:00 app[web.1]: > finale-backend@0.0.0 start /app
2021-01-11T22:10:14.214189 00:00 app[web.1]: > node ./bin/www
2021-01-11T22:10:14.214189 00:00 app[web.1]: 
2021-01-11T22:10:14.285451 00:00 app[web.1]: internal/modules/cjs/loader.js:818
2021-01-11T22:10:14.285453 00:00 app[web.1]: throw err;
2021-01-11T22:10:14.285453 00:00 app[web.1]: ^
2021-01-11T22:10:14.285454 00:00 app[web.1]: 
2021-01-11T22:10:14.285454 00:00 app[web.1]: Error: Cannot find module 'dotenv'
2021-01-11T22:10:14.285454 00:00 app[web.1]: Require stack:
2021-01-11T22:10:14.285455 00:00 app[web.1]: - /app/app.js
2021-01-11T22:10:14.285455 00:00 app[web.1]: - /app/bin/www
2021-01-11T22:10:14.285456 00:00 app[web.1]: at Function.Module._resolveFilename (internal/modules/cjs/loader.js:815:15)
2021-01-11T22:10:14.285456 00:00 app[web.1]: at Function.Module._load (internal/modules/cjs/loader.js:667:27)
2021-01-11T22:10:14.285457 00:00 app[web.1]: at Module.require (internal/modules/cjs/loader.js:887:19)
2021-01-11T22:10:14.285457 00:00 app[web.1]: at require (internal/modules/cjs/helpers.js:74:18)
2021-01-11T22:10:14.285458 00:00 app[web.1]: at Object.<anonymous> (/app/app.js:1:1)
2021-01-11T22:10:14.285458 00:00 app[web.1]: at Module._compile (internal/modules/cjs/loader.js:999:30)
2021-01-11T22:10:14.285459 00:00 app[web.1]: at Object.Module._extensions..js (internal/modules/cjs/loader.js:1027:10)
2021-01-11T22:10:14.285459 00:00 app[web.1]: at Module.load (internal/modules/cjs/loader.js:863:32)
2021-01-11T22:10:14.285459 00:00 app[web.1]: at Function.Module._load (internal/modules/cjs/loader.js:708:14)
2021-01-11T22:10:14.285460 00:00 app[web.1]: at Module.require (internal/modules/cjs/loader.js:887:19) {
2021-01-11T22:10:14.285460 00:00 app[web.1]: code: 'MODULE_NOT_FOUND',
2021-01-11T22:10:14.285461 00:00 app[web.1]: requireStack: [ '/app/app.js', '/app/bin/www' ]
2021-01-11T22:10:14.285461 00:00 app[web.1]: }
2021-01-11T22:10:14.301983 00:00 app[web.1]: npm ERR! code ELIFECYCLE
2021-01-11T22:10:14.302357 00:00 app[web.1]: npm ERR! errno 1
2021-01-11T22:10:14.309690 00:00 app[web.1]: npm ERR! finale-backend@0.0.0 start: `node ./bin/www`
2021-01-11T22:10:14.309804 00:00 app[web.1]: npm ERR! Exit status 1
2021-01-11T22:10:14.309965 00:00 app[web.1]: npm ERR!
2021-01-11T22:10:14.310034 00:00 app[web.1]: npm ERR! Failed at the finale-backend@0.0.0 start script.
2021-01-11T22:10:14.310119 00:00 app[web.1]: npm ERR! This is probably not a problem with npm. There is likely additional logging output above.
2021-01-11T22:10:14.317026 00:00 app[web.1]: 
2021-01-11T22:10:14.317243 00:00 app[web.1]: npm ERR! A complete log of this run can be found in:
2021-01-11T22:10:14.317339 00:00 app[web.1]: npm ERR!     /app/.npm/_logs/2021-01-11T22_10_14_310Z-debug.log
2021-01-11T22:10:14.361923 00:00 heroku[web.1]: Process exited with status 1
2021-01-11T22:10:14.435764 00:00 heroku[web.1]: State changed from starting to crashed
2021-01-11T22:10:14.439118 00:00 heroku[web.1]: State changed from crashed to starting
2021-01-11T22:10:16.805923 00:00 heroku[web.1]: Starting process with command `npm start`
2021-01-11T22:10:19.751944 00:00 app[web.1]: 
2021-01-11T22:10:19.751961 00:00 app[web.1]: > finale-backend@0.0.0 start /app
2021-01-11T22:10:19.751962 00:00 app[web.1]: > node ./bin/www
2021-01-11T22:10:19.751963 00:00 app[web.1]: 
2021-01-11T22:10:19.808881 00:00 app[web.1]: internal/modules/cjs/loader.js:818
2021-01-11T22:10:19.808883 00:00 app[web.1]: throw err;
2021-01-11T22:10:19.808883 00:00 app[web.1]: ^
2021-01-11T22:10:19.808883 00:00 app[web.1]: 
2021-01-11T22:10:19.808884 00:00 app[web.1]: Error: Cannot find module 'dotenv'
2021-01-11T22:10:19.808884 00:00 app[web.1]: Require stack:
2021-01-11T22:10:19.808884 00:00 app[web.1]: - /app/app.js
2021-01-11T22:10:19.808885 00:00 app[web.1]: - /app/bin/www
2021-01-11T22:10:19.808885 00:00 app[web.1]: at Function.Module._resolveFilename (internal/modules/cjs/loader.js:815:15)
2021-01-11T22:10:19.808885 00:00 app[web.1]: at Function.Module._load (internal/modules/cjs/loader.js:667:27)
2021-01-11T22:10:19.808886 00:00 app[web.1]: at Module.require (internal/modules/cjs/loader.js:887:19)
2021-01-11T22:10:19.808886 00:00 app[web.1]: at require (internal/modules/cjs/helpers.js:74:18)
2021-01-11T22:10:19.808887 00:00 app[web.1]: at Object.<anonymous> (/app/app.js:1:1)
2021-01-11T22:10:19.808887 00:00 app[web.1]: at Module._compile (internal/modules/cjs/loader.js:999:30)
2021-01-11T22:10:19.808887 00:00 app[web.1]: at Object.Module._extensions..js (internal/modules/cjs/loader.js:1027:10)
2021-01-11T22:10:19.808888 00:00 app[web.1]: at Module.load (internal/modules/cjs/loader.js:863:32)
2021-01-11T22:10:19.808888 00:00 app[web.1]: at Function.Module._load (internal/modules/cjs/loader.js:708:14)
2021-01-11T22:10:19.808889 00:00 app[web.1]: at Module.require (internal/modules/cjs/loader.js:887:19) {
2021-01-11T22:10:19.808889 00:00 app[web.1]: code: 'MODULE_NOT_FOUND',
2021-01-11T22:10:19.808889 00:00 app[web.1]: requireStack: [ '/app/app.js', '/app/bin/www' ]
2021-01-11T22:10:19.808890 00:00 app[web.1]: }
2021-01-11T22:10:19.834122 00:00 app[web.1]: npm ERR! code ELIFECYCLE
2021-01-11T22:10:19.834754 00:00 app[web.1]: npm ERR! errno 1
2021-01-11T22:10:19.843644 00:00 app[web.1]: npm ERR! finale-backend@0.0.0 start: `node ./bin/www`
2021-01-11T22:10:19.843996 00:00 app[web.1]: npm ERR! Exit status 1
2021-01-11T22:10:19.844353 00:00 app[web.1]: npm ERR!
2021-01-11T22:10:19.844619 00:00 app[web.1]: npm ERR! Failed at the finale-backend@0.0.0 start script.
2021-01-11T22:10:19.844914 00:00 app[web.1]: npm ERR! This is probably not a problem with npm. There is likely additional logging output above.
2021-01-11T22:10:19.858827 00:00 app[web.1]: 
2021-01-11T22:10:19.859298 00:00 app[web.1]: npm ERR! A complete log of this run can be found in:
2021-01-11T22:10:19.859536 00:00 app[web.1]: npm ERR!     /app/.npm/_logs/2021-01-11T22_10_19_845Z-debug.log
2021-01-11T22:10:19.946324 00:00 heroku[web.1]: Process exited with status 1
2021-01-11T22:10:20.030800 00:00 heroku[web.1]: State changed from starting to crashed
2021-01-11T22:10:22.579029 00:00 heroku[router]: at=error code=H10 desc="App crashed" method=GET path="/" host=XXXXXX.herokuapp.com request_id=28ed0f16-48b7-4edb-a4d4-bf5af57518a5 fwd="91.106.154.160" dyno= connect= service= status=503 bytes= protocol=https
2021-01-11T22:10:23.309377 00:00 heroku[router]: at=error code=H10 desc="App crashed" method=GET path="/favicon.ico" host=XXXXXX.herokuapp.com request_id=967010fc-984e-49c7-a73e-9d9758907f49 fwd="91.106.154.160" dyno= connect= service= status=503 bytes= protocol=https
 

Мой пакет json выглядит следующим образом:

 {
  "name": "finale-backend",
  "version": "0.0.0",
  "private": true,
  "scripts": {
    "start": "node ./bin/www",
    "dev": "nodemon ./bin/www"
  },
  "dependencies": {
    "bcrypt": "^5.0.0",
    "body-parser": "^1.19.0",
    "cookie-parser": "~1.4.4",
    "cors": "^2.8.5",
    "debug": "~2.6.9",
    "express": "~4.16.1",
    "helmet": "^4.3.1",
    "jsonwebtoken": "^8.5.1",
    "logger": "0.0.1",
    "morgan": "~1.9.1",
    "nodemon": "^2.0.7",
    "pg": "^8.5.1"
  },
  "devDependencies": {
    "dotenv": "^8.2.0"
  },
  "engines": {
    "node": "12.x"
  }
}
 

И мне требуется dotenv в моей точке входа app.js вот так

 require('dotenv').config();
const express = require('express');
const path = require('path');
const cookieParser = require('cookie-parser');
const logger = require('morgan');
const cors = require('cors') 
 

Ответ №1:

Похоже, что Heroku не устанавливает devDependencies по умолчанию. Возможно, вы захотите переместить dotenv в dependencies в вашем package.json и повторить попытку.

Если вам не нужен dotenv в вашей производственной среде, вы можете полностью удалить require и использовать другую команду для запуска вашего сервера разработки, как описано здесь:

https://www.npmjs.com/package/dotenv#preload

node -r dotenv/config your_script.js

Это предотвратит сбой вашего сервера в рабочей среде, когда зависимость dotenv не найдена в Heroku.

Комментарии:

1. Большое тебе спасибо, Ральф! Это сработало как по волшебству. : D

Ответ №2:

Причина в том, что вы используете dotenv в devDependencies. Измените зависимость dotenv на зависимости, подобные этой:

  "dependencies": {
...,
"dotenv": "^8.2.0"
  }