为啥在将应用程序部署到 Heroku 时出现此错误?

Posted

技术标签:

【中文标题】为啥在将应用程序部署到 Heroku 时出现此错误?【英文标题】:Why do I obtain this error when deploying app to Heroku?为什么在将应用程序部署到 Heroku 时出现此错误? 【发布时间】:2016-04-10 10:27:18 【问题描述】:

使用 git hub 将我的应用程序部署到 heroku 时出现某种错误。问题是,我不了解 heroku 日志和相关错误。这是heroku日志:

Marcuss-MacBook-Pro:Weather-App marcushurney$ heroku logs
2016-01-05T14:37:27.798077+00:00 app[web.1]: npm ERR! Please include the following file with any support request:
2016-01-05T14:37:27.798377+00:00 app[web.1]: npm ERR!     /app/npm-debug.log
2016-01-05T14:37:27.786949+00:00 app[web.1]: npm ERR! node v5.1.1
2016-01-05T14:37:27.786556+00:00 app[web.1]: npm ERR! argv "/app/.heroku/node/bin/node" "/app/.heroku/node/bin/npm" "start"
2016-01-05T14:37:27.787856+00:00 app[web.1]: npm ERR! npm  v3.3.12
2016-01-05T14:37:28.776245+00:00 heroku[web.1]: Process exited with status 1
2016-01-05T14:37:28.789412+00:00 heroku[web.1]: State changed from starting to crashed
2016-01-05T17:27:16.684869+00:00 heroku[web.1]: State changed from crashed to starting
2016-01-05T17:27:17.853743+00:00 heroku[web.1]: Starting process with command `npm start`
2016-01-05T17:27:20.423495+00:00 app[web.1]: npm ERR! node v5.1.1
2016-01-05T17:27:20.423130+00:00 app[web.1]: npm ERR! argv "/app/.heroku/node/bin/node" "/app/.heroku/node/bin/npm" "start"
2016-01-05T17:27:20.424111+00:00 app[web.1]: npm ERR! npm  v3.3.12
2016-01-05T17:27:20.425937+00:00 app[web.1]: npm ERR! missing script: start
2016-01-05T17:27:20.422441+00:00 app[web.1]: npm ERR! Linux 3.13.0-71-generic
2016-01-05T17:27:20.426242+00:00 app[web.1]: npm ERR! 
2016-01-05T17:27:20.426432+00:00 app[web.1]: npm ERR! If you need help, you may report this error at:
2016-01-05T17:27:20.426634+00:00 app[web.1]: npm ERR!     <https://github.com/npm/npm/issues>

【问题讨论】:

【参考方案1】:

我使用的是 nodemon.js,所以我将它包含在 package.json 中,如下所示: “脚本”

 "scripts": 
        "test": "echo \"Error: no test specified\" && exit 1",
        "dev": "nodemon index.js",
     ,

但是我得到了这个 Heroku 错误:

2022-01-06T11:51:55.044364+00:00 heroku[web.1]:启动过程 命令npm start 2022-01-06T11:51:57.390306+00:00 app[web.1]: npm 呃!缺少脚本:开始 2022-01-06T11:51:57.398106+00:00 应用 [web.1]:2022-01-06T11:51:57.398334+00:00 应用 [web.1]:npm 错误!一种 此运行的完整日志可在以下位置找到: 2022-01-06T11:51:57.398402+00:00 app[web.1]: npm ERR! /app/.npm/_logs/2022-01-06T11_51_57_391Z-debug.log 2022-01-06T11:51:57.598054+00:00 heroku[web.1]:进程退出 状态 1 2022-01-06T11:51:57.882212+00:00 heroku[web.1]:状态已更改 从开始到崩溃 2022-01-06T11:51:57.953568+00:00 heroku[web.1]:状态从崩溃变为开始 2022-01-06T11:52:00.240909+00:00 heroku[web.1]:启动过程 命令npm start 2022-01-06T11:52:02.010859+00:00 app[web.1]: npm 呃!缺少脚本:开始 2022-01-06T11:52:02.014370+00:00 应用[web.1]:2022-01-06T11:52:02.014567+00:00 应用[web.1]:npm 错误!一种 此运行的完整日志可在以下位置找到: ..................................等等

我发现 Heroku 使用“npm start”来运行我们的应用程序,而我没有将它包含在 package.json 中;因此将其包括在以下内容中:

"scripts": 
    "test": "echo \"Error: no test specified\" && exit 1",
    "dev": "nodemon index.js",
    "start": "node index.js"
  ,

然后重启git进程:

-heroku restart
-heroku git:remote -a app_name
-git add .
-git commit -am "Your commit"
-git push heroku master

一切都很顺利。

【讨论】:

【参考方案2】:

经过几次故障排除后,我在尝试使用 heroku 部署服务器时遇到了同样的问题。我对 package.json 所做的更改包括在脚本中创建 start 属性;

"scripts": 
  "test": "echo \"Error: no test specified\" && exit 1",
  "start": "node app.js"
,

进行更改后,确保您的 Procfile 没有扩展名有这一行;

  web: node app.js (Depends on your server file).

然后您可以继续提交您的文件。

希望这会有所帮助

【讨论】:

【参考方案3】:

由于某种原因将启动脚本推到顶部修复了问题

所以不是

"scripts": 
    "test": "jest",
    "start": "node app.js"

我做到了

"scripts": 
    "start": "node app.js",
    "test": "jest"


【讨论】:

【参考方案4】:

我的愚蠢错误是我将主分支推送到 Heroku,而我的更改在另一个分支中!

确保首先将最新分支与主分支合并

> git checkout master

> git merge your-latest-branch

> git push heroku master

【讨论】:

【参考方案5】:

我的 node js 应用在发布到 heroku.com 时也遇到了类似的错误

首先创建一个procfile,procfile是一个简单的文本文件,没有任何扩展名。

目前只在 procfile 中放置一行。

web: npm start

现在使用命令创建 package.json 文件

npm init

创建 package.json 文件后,请将 start 属性放在脚本中。

"scripts": 
    "start": "node app.js",
    "test": "echo \"Error: no test specified\" && exit 1"
  ,

现在提交所有 (procfile/package.json) 待处理文件。并再次从 heroku 部署应用程序。

【讨论】:

【参考方案6】:

就我而言,changing 这个:

"scripts": 
     "test": "echo \"Error: no test specified\" && exit 1"
    ,

到这里:

"scripts": 
   "start": "node app.js"
    ,

解决办法

【讨论】:

【参考方案7】:

你必须通知 heroku 从哪里开始:missing script: start。在你的 package.json 中,你应该有类似this:

"scripts": 
  "start": "node index.js"

index.js 是您的入口点。

作为alternative,可以在Procfile中指定:

web: node index.js

【讨论】:

解决了问题! @LMeyer 它仍然没有为我修复它。有任何想法吗?我已经在 package.json 中包含了 start @TheProgrammerG 可以肯定的是,如果您添加了开头,则日志中没有missing script: start。你有什么? 你为我节省了很多时间!谢谢! 如果是typescript + node, express app呢?

以上是关于为啥在将应用程序部署到 Heroku 时出现此错误?的主要内容,如果未能解决你的问题,请参考以下文章

为啥当我的 heroku 应用程序崩溃时出现 mongodb 错误? (在本地工作就好了!)

为啥我在运行时出现整数精度错误:heroku run python manage.py migrate

为啥在尝试将firebase添加到flutter时出现此错误“已弃用的API”

将 Rails 3.1 项目部署到 Heroku 时出现问题:找不到 JavaScript 运行时

为啥在尝试将 UIPopover 附加到不同类中的 UIButton 时出现此构建错误?

将应用程序部署到 Meteor 时出现此错误