找不到模块'./collection/batch/unordered' - Heroku上的Node JS

时间:2014-04-26 16:41:26

标签: node.js mongodb heroku

我有一个问题让我疯了两天了。我在heroku上部署了一个运行良好的节点应用程序。两天前,我对模块进行了更新(我不是100%确定它与我的问题直接相关),并且因为我在日志中不断收到此消息:

             Error: Cannot find module './collection/batch/unordered'
                  at Function.Module._resolveFilename (module.js:338:15)
                  at Function.Module._load (module.js:280:25)
                  at Module.require (module.js:364:17)
                  at require (module.js:380:17)
                  at Object.<anonymous> (/app/node_modules/mongodb/lib/mongodb/collection.js:21:17)
                  at Module._compile (module.js:456:26)
                  at Object.Module._extensions..js (module.js:474:10)
                  at Module.load (module.js:356:32)
                  at Function.Module._load (module.js:312:12)
                  at Module.require (module.js:364:17)
              Failed to load c++ bson extension, using pure JS version

在本地,该应用程序运行良好。

我试图将版本更改回原来的版本,但没有成功。

所以我检查了node_modules / mongodb / lib / mongodb,实际上我没有找到&#34;批次&#34;文件夹,因此是node_modules / mongodb / lib / mongodb / collection.js文件所需的unordered.js文件。

我尝试卸载并重新安装mongodb。批处理文件夹和unordered.js确实出现了。但错误仍然存​​在。如果我在Heroku上重新部署,批处理文件夹将再次丢失。

我完全不知道现在该尝试什么,我会非常感谢一些帮助。谢谢!

编辑:

这是我的packages.json:

  {
    "name": "Killerapp",
    "version": "0.0.1",
    "private": true,
    "scripts": {
    "start": "node app.js"
   },
    "engines": {
       "node": "0.10.26" 
    },
    "dependencies": {
       "express": "3.5.1",
       "ejs" : "~0.8.5",
       "mongodb": "1.4.2",
       "mongoose": "3.8.8",
       "connect-mongo": "*", 
       "passport" : "~0.1.17",     
       "connect-flash" : "~0.1.1",   
       "bcrypt-nodejs" : "latest",
       "moment" : "latest"
       }
     }

1 个答案:

答案 0 :(得分:0)

您是否有理由在依赖项中硬编码mongodb版本?我相信猫鼬会拉出合适的版本......

尝试从package.json中删除mongodb,从git中删除node_modules,然后推送到heroku。