Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Heroku says : Cannot find module 'socket.io'

I'm deploying an node.js app with deps/modules like : stylus, express, socket.io on heroku.

The beginning of the server.js

/**
 * Bootstrap app.
 */

// I've tried with and without that line... not sure what it does
require.paths.unshift(__dirname + '/../../lib/');



/**
 * Module dependencies.
 */

// I've tried with "socket.io", "./socket.io" and "Socket.IO"
var express = require('express')
  , stylus = require('stylus')
  , nib = require('nib')
  , sio = require('socket.io');

The file package.json

{ "name": "test.io" , "description": "blabla" , "version": "0.0.1" , "dependencies": { "express": "2.3.11" , "jade": "0.12.1" , "stylus": "0.13.3" , "nib": "0.0.8" } }

So the one and only heroku web worker crash. Here's the log :

2011-10-24T09:15:27+00:00 heroku[slugc]: Slug compilation finished
2011-10-24T09:15:35+00:00 heroku[web.1]: Unidling
2011-10-24T09:15:35+00:00 heroku[web.1]: State changed from down to created
2011-10-24T09:15:35+00:00 heroku[web.1]: State changed from created to starting
2011-10-24T09:15:39+00:00 heroku[web.1]: State changed from starting to crashed
2011-10-24T09:15:39+00:00 heroku[web.1]: State changed from crashed to created
2011-10-24T09:15:39+00:00 heroku[web.1]: State changed from created to starting
2011-10-24T09:15:41+00:00 heroku[web.1]: Starting process with command `node app.js`
2011-10-24T09:15:41+00:00 app[web.1]: 
2011-10-24T09:15:41+00:00 app[web.1]: node.js:134
2011-10-24T09:15:41+00:00 app[web.1]:         throw e; // process.nextTick error, or 'error' event on first tick
2011-10-24T09:15:41+00:00 app[web.1]:         ^
2011-10-24T09:15:41+00:00 app[web.1]: Error: Cannot find module 'socket.io'
2011-10-24T09:15:41+00:00 app[web.1]:     at Function._resolveFilename (module.js:320:11)
2011-10-24T09:15:41+00:00 app[web.1]:     at Function._load (module.js:266:25)
2011-10-24T09:15:41+00:00 app[web.1]:     at require (module.js:348:19)
2011-10-24T09:15:41+00:00 app[web.1]:     at Object.<anonymous> (/app/app.js:18:11)
2011-10-24T09:15:41+00:00 app[web.1]:     at Module._compile (module.js:404:26)
2011-10-24T09:15:41+00:00 app[web.1]:     at Object..js (module.js:410:10)
2011-10-24T09:15:41+00:00 app[web.1]:     at Module.load (module.js:336:31)
2011-10-24T09:15:41+00:00 app[web.1]:     at Function._load (module.js:297:12)
2011-10-24T09:15:41+00:00 app[web.1]:     at Array.<anonymous> (module.js:423:10)
2011-10-24T09:15:41+00:00 app[web.1]:     at EventEmitter._tickCallback (node.js:126:26)
2011-10-24T09:15:41+00:00 heroku[web.1]: Process exited
2011-10-24T09:15:44+00:00 heroku[web.1]: State changed from starting to crashed

So, any ideas ? Ever happened to anyone ?

like image 412
Marcel Falliere Avatar asked Jan 18 '23 10:01

Marcel Falliere


1 Answers

I believe you should add socket.io in dependencies in package.json.

{ "name": "test.io" , "description": "blabla" , "version": "0.0.1" , "dependencies": { "express": "2.3.11" , "jade": "0.12.1" , "stylus": "0.13.3" , "nib": "0.0.8" , "socket.io" : "0.8.5" } }

Or just do this:

npm install socket.io --save

Which will install the latest version of socket.io and add it to the dependencies.

like image 97
Farid Nouri Neshat Avatar answered Jan 25 '23 16:01

Farid Nouri Neshat