sh: 1: nuxt: не найден (Heroku/Nuxt)

#vue.js #express #heroku #nuxt.js

Вопрос:

У меня проблема, я наконец-то развертываю серверное приложение nuxt (с экспресс-сервером). Я создал Героку. Сборка завершается успешно, но затем, когда она пытается запуститься, она дает мне:

 2021-07-29T18:13:38.000000 00:00 app[api]: Build succeeded
2021-07-29T18:13:42.050534 00:00 heroku[web.1]: Process exited with status 1
2021-07-29T18:13:42.139623 00:00 heroku[web.1]: State changed from starting to crashed
2021-07-29T18:13:41.793565 00:00 app[web.1]: 
2021-07-29T18:13:41.793587 00:00 app[web.1]: > nuxt-express@1.0.0 start /app
2021-07-29T18:13:41.793588 00:00 app[web.1]: > nuxt start
2021-07-29T18:13:41.793588 00:00 app[web.1]:
2021-07-29T18:13:41.814774 00:00 app[web.1]: sh: 1: nuxt: not found
2021-07-29T18:13:41.822159 00:00 app[web.1]: npm ERR! code ELIFECYCLE
2021-07-29T18:13:41.822579 00:00 app[web.1]: npm ERR! syscall spawn
2021-07-29T18:13:41.822774 00:00 app[web.1]: npm ERR! file sh
2021-07-29T18:13:41.823001 00:00 app[web.1]: npm ERR! errno ENOENT
2021-07-29T18:13:41.834748 00:00 app[web.1]: npm ERR! nuxt-express@1.0.0 start: `nuxt start`
2021-07-29T18:13:41.834966 00:00 app[web.1]: npm ERR! spawn ENOENT
2021-07-29T18:13:41.835206 00:00 app[web.1]: npm ERR!
2021-07-29T18:13:41.835433 00:00 app[web.1]: npm ERR! Failed at the nuxt-express@1.0.0 start script.
 

Я не уверен, в чем я ошибаюсь в этом. Нужно ли мне создавать его перед развертыванием с помощью интерфейса командной строки Heroku? Это проблема с моим экспресс-сервером (так как он говорит, что он вышел из строя в nuxt-express. Я просто не уверен, что происходит, если бы кто-нибудь мог помочь, это очень помогло бы мне! Спасибо!

Вот мой пакет.json, если это поможет:

 {
    "name": "p-live",
    "version": "1.0.0",
    "private": true,
    "scripts": {
    "dev": "nuxt",
    "build": "nuxt build",
    "start": "nuxt start",
    "generate": "nuxt generate",
    "heroku-postbuild": "npm run build"
    },
    "dependencies": {
    "@nuxt/http": "latest",
    "@nuxtjs/firebase": "^7.5.0",
    "cookie-universal-nuxt": "^2.1.5",
    "dotenv": "^10.0.0",
    "express": "latest",
    "firebase": "^8.3.1",
    "jsforce": "^1.10.1",
    "nuxt": "latest"
    },
    "devDependencies": {
    "@nuxtjs/moment": "^1.6.1",
    "@nuxtjs/pwa": "^3.3.5",
    "@nuxtjs/tailwindcss": "^3.4.2",
    "@tailwindcss/custom-forms": "^0.2.1",
    "@tailwindcss/postcss7-compat": "^2.0.3",
    "autoprefixer": "^9.8.6",
    "babel-eslint": "^10.1.0",
    "eslint": "^7.20.0",
    "eslint-plugin-nuxt": "^2.0.0",
    "postcss": "^7.0.35",
    "tailwindcss": "npm:@tailwindcss/postcss7-compat@^2.0.3"
    }
}
 

Ответ №1:

Попробуйте изменить свой сценарий запуска, чтобы он был путем для nuxt/bin предоставления

При необходимости, если у вас все еще возникают проблемы, рассмотрите возможность добавления -c флага с относительным путем к вашему nuxt.config.js файлу.

Сделайте то же самое для сборки.

  "scripts": {
    "dev": "nuxt",
    "build": "nuxt build",
    "start": "nuxt start",
    "generate": "nuxt generate",
    "heroku-postbuild": "npm run build"
  },
 

Для

  "scripts": {
    "dev": "nuxt",
    "build": "node_modules/nuxt/bin/nuxt.js build -c ./nuxt.config.js",
    "start": "node_modules/nuxt/bin/nuxt.js start -c ./nuxt.config.js",
    "generate": "nuxt generate",
    "heroku-postbuild": "npm run build"
  },