Heroku无法启动我的节点应用程序,因为它尝试使用nodemon

And*_*ers 6 heroku node.js nodemon

我正在将我的节点应用程序部署到Heroku,它正在尝试使用nodemon调用它而不是node app.js我已定义的.我的Procfile看起来像这样:

web: npm start
Run Code Online (Sandbox Code Playgroud)

当我推送到heroku时,dyno因此错误而崩溃:

2014-03-24T19:24:59.669412+00:00 app[web.1]: > my-app@0.0.1 start /app
2014-03-24T19:24:59.669412+00:00 app[web.1]: > nodemon app.js
2014-03-24T19:24:59.669412+00:00 app[web.1]:
2014-03-24T19:24:59.669412+00:00 app[web.1]:
2014-03-24T19:24:59.710228+00:00 app[web.1]:
2014-03-24T19:24:59.701246+00:00 app[web.1]: sh: nodemon: not found
Run Code Online (Sandbox Code Playgroud)

我甚至试过npm安装nodemon作为package.json依赖项,并检查node_modules/nodemon但没有运气.(无论如何都需要安装nodemon npm install nodemon -g)

有任何想法吗?

我的package.json:

{
    "name": "my-app",
    "version": "0.0.1",
    "private": true,
    "main": "app.js",
    "scripts": {
        "start": "node app.js"
    },
    "dependencies": {
        "requirejs": "~2.1.10",
        "underscore": "~1.5.2",
        "express": "~3.4.8",
        "ejs": "~0.8.5",
        "less-middleware": "~0.1.15",
        "socket.io": "~0.9.16",
        "tail": "~0.3.5",
        "async": "~0.2.10",
        "mongoose": "~3.8.5",
        "mkdirp": "~0.3.5",
        "ejs-locals": "~1.0.2",
        "aws-sdk": "~2.0.0-rc8",
        "knox": "~0.8.8",
        "connect-multiparty": "~1.0.3",
        "uuid": "~1.4.1",
        "nodemon": "~1.0.14"
    },
    "devDependencies": {
        "grunt": "~0.4.2",
        "grunt-contrib-clean": "~0.5.0",
        "grunt-contrib-copy": "~0.4.1",
        "grunt-contrib-requirejs": "~0.4.1",
        "grunt-recess": "~0.5.0",
        "grunt-contrib-cssmin": "~0.7.0",
        "grunt-mocha-test": "~0.9.0",
        "grunt-forever": "~0.4.1",
        "matchdep": "~0.3.0",
        "jshint": "~2.4.3",
        "precommit-hook": "~0.3.10",
        "mocha": "~1.17.1",
        "supertest": "~0.9.0",
        "chai": "~1.9.0",
        "sinon": "~1.8.2",
        "karma-sinon": "~1.0.2",
        "karma-script-launcher": "~0.1.0",
        "karma-chrome-launcher": "~0.1.2",
        "karma-firefox-launcher": "~0.1.3",
        "karma-requirejs": "~0.2.1",
        "karma-html2js-preprocessor": "~0.1.0",
        "karma-jasmine": "~0.1.5",
        "karma-coffee-preprocessor": "~0.1.3",
        "karma-phantomjs-launcher": "~0.1.2",
        "karma": "~0.10.9",
        "karma-mocha": "~0.1.1",
        "grunt-karma": "~0.6.2",
        "karma-chai": "~0.1.0"
    },
    "config": {
        "precommit": {
            "lint": true
        }
    },
    "engines": {
        "node": "0.10.x"
    }
}
Run Code Online (Sandbox Code Playgroud)

更新

很抱歉让所有人都挂了!如果我没记错的话,我的问题最终是我的buildpack覆盖了web:我的Procfile中的角色.

我已经切换到不同的buildpacks,即:ddollar/heroku-buildpack-multi

使用以下.buildpacks文件:

ryandotsmith/nginx-buildpack
heroku/heroku-buildpack-nodejs
Run Code Online (Sandbox Code Playgroud)

我的Procfile看起来像这样:

web: bin/start-nginx ./node_modules/.bin/forever --minUptime 10000 --spinSleepTime 1000 app.js
Run Code Online (Sandbox Code Playgroud)

dio*_*ney 12

把你Procfile改成这个:

web: node app.js
Run Code Online (Sandbox Code Playgroud)

作为app.js您的应用程序的入口点.

这假设您并不真正需要nodemon在您的应用中,因为您已在package.json您提供的样本中列出它.

  • 请告诉我们你做错了什么. (3认同)