无法使用npm重建依赖关系 [英] Failed to rebuild dependencies with npm

查看:153
本文介绍了无法使用npm重建依赖关系的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

当我试图将可在本地正常运行的nodejs应用推送到heroku时,这是我在终端中得到的内容:

As I am trying to push my nodejs app which is working fine locally to heroku, here is what I get in terminal:

dcaclab@ubuntu:~/RubymineProjects/nodejs_consumer$ git push heroku master
Counting objects: 1417, done.
Compressing objects: 100% (1195/1195), done.
Writing objects: 100% (1417/1417), 2.02 MiB | 22 KiB/s, done.
Total 1417 (delta 247), reused 0 (delta 0)

-----> Node.js app detected
-----> Resolving engine versions
       Using Node.js version: 0.10.6
       Using npm version: 1.2.21
-----> Fetching Node.js binaries
-----> Vendoring node into slug
-----> Installing dependencies with npm
       npm WARN package.json node-example@0.0.1 No repository field.
       npm WARN package.json node-example@0.0.1 No readme data.
       npm WARN package.json node@0.0.0 No repository field.
       npm WARN package.json faye-websocket@0.4.0 No repository field.
       npm WARN package.json faye-websocket@0.4.0 'repositories' (plural) Not supported.
       npm WARN package.json Please pick one as the 'repository' field
       npm WARN package.json rbytes@0.0.2 No repository field.
       npm WARN package.json node-example@0.0.1 No repository field.
       npm WARN package.json node-example@0.0.1 No readme data.
       npm WARN package.json node@0.0.0 No repository field.
       npm WARN package.json faye-websocket@0.4.0 No repository field.
       npm WARN package.json faye-websocket@0.4.0 'repositories' (plural) Not supported.
       npm WARN package.json Please pick one as the 'repository' field
       npm WARN package.json rbytes@0.0.2 No repository field.

       > weak@0.2.2 install /tmp/build_f86ikz343m5u/node_modules/dnode/node_modules/weak
       > node-gyp rebuild

       gyp http GET http://nodejs.org/dist/v0.10.6/node-v0.10.6.tar.gz
       gyp http 200 http://nodejs.org/dist/v0.10.6/node-v0.10.6.tar.gz
       make: Entering directory `/tmp/build_f86ikz343m5u/node_modules/dnode/node_modules/weak/build'
         CXX(target) Release/obj.target/weakref/src/weakref.o
         SOLINK_MODULE(target) Release/obj.target/weakref.node
         SOLINK_MODULE(target) Release/obj.target/weakref.node: Finished
         COPY Release/weakref.node
       make: Leaving directory `/tmp/build_f86ikz343m5u/node_modules/dnode/node_modules/weak/build'

       > rbytes@0.0.2 install /tmp/build_f86ikz343m5u/node_modules/shoe/node_modules/sockjs/node_modules/rbytes
       > node-waf configure build

       sh: node-waf: not found
       npm ERR! weird error 127
       npm ERR! not ok code 0
 !     Failed to rebuild dependencies with npm
 !     Heroku push rejected, failed to compile Node.js app

To git@heroku.com:dcaclab-simulator.git
 ! [remote rejected] master -> master (pre-receive hook declined)
error: failed to push some refs to 'git@heroku.com:dcaclab-simulator.git'

这是我的package.json文件:

here is my package.json file:

{
  "name": "node-example",
  "version": "0.0.1",
  "dependencies": {
    "dnode": "1.0.5",
    "shoe": "0.0.10"
  },
  "engines": {
    "node": "0.10.x",
    "npm": "1.2.x"
  }
}

请问有什么主意吗?

编辑

尝试使用节点0.8,这是我得到的:

Tried to use node 0.8, here is what I got:

dcaclab@ubuntu:~/RubymineProjects/nodejs_consumer$ git push heroku master
Counting objects: 1420, done.
Compressing objects: 100% (1198/1198), done.
Writing objects: 100% (1420/1420), 2.02 MiB | 24 KiB/s, done.
Total 1420 (delta 249), reused 0 (delta 0)

-----> Node.js app detected
-----> Resolving engine versions
       Using Node.js version: 0.8.23
       Using npm version: 1.2.21
-----> Fetching Node.js binaries
-----> Vendoring node into slug
-----> Installing dependencies with npm
       npm WARN package.json node-example@0.0.1 No repository field.
       npm WARN package.json node-example@0.0.1 No readme data.
       npm WARN package.json node@0.0.0 No repository field.
       npm WARN package.json rbytes@0.0.2 No repository field.
       npm WARN package.json faye-websocket@0.4.0 No repository field.
       npm WARN package.json faye-websocket@0.4.0 'repositories' (plural) Not supported.
       npm WARN package.json Please pick one as the 'repository' field
       npm WARN package.json node-example@0.0.1 No repository field.
       npm WARN package.json node-example@0.0.1 No readme data.
       npm WARN package.json node@0.0.0 No repository field.
       npm WARN package.json rbytes@0.0.2 No repository field.
       npm WARN package.json faye-websocket@0.4.0 No repository field.
       npm WARN package.json faye-websocket@0.4.0 'repositories' (plural) Not supported.
       npm WARN package.json Please pick one as the 'repository' field

       > weak@0.2.2 install /tmp/build_1uw8vrtz5u7yu/node_modules/dnode/node_modules/weak
       > node-gyp rebuild

       gyp http GET http://nodejs.org/dist/v0.8.23/node-v0.8.23.tar.gz
       gyp http 200 http://nodejs.org/dist/v0.8.23/node-v0.8.23.tar.gz
       make: Entering directory `/tmp/build_1uw8vrtz5u7yu/node_modules/dnode/node_modules/weak/build'
         CXX(target) Release/obj.target/weakref/src/weakref.o
         SOLINK_MODULE(target) Release/obj.target/weakref.node
         SOLINK_MODULE(target) Release/obj.target/weakref.node: Finished
         COPY Release/weakref.node
       make: Leaving directory `/tmp/build_1uw8vrtz5u7yu/node_modules/dnode/node_modules/weak/build'

       > rbytes@0.0.2 install /tmp/build_1uw8vrtz5u7yu/node_modules/shoe/node_modules/sockjs/node_modules/rbytes
       > node-waf configure build

       Checking for program g++ or c++          : /usr/bin/g++ 
       Checking for program cpp                 : /usr/bin/cpp 
       Checking for program ar                  : /usr/bin/ar 
       Checking for program ranlib              : /usr/bin/ranlib 
       Checking for g++                         : ok  
       Checking for node path                   : not found 
       Checking for node prefix                 : ok /tmp/node-node-Rkll 
       'configure' finished successfully (0.027s)
       Waf: Entering directory `/home/dcaclab/RubymineProjects/nodejs_consumer/node_modules/shoe/node_modules/sockjs/node_modules/rbytes/build'
       Waf: Leaving directory `/home/dcaclab/RubymineProjects/nodejs_consumer/node_modules/shoe/node_modules/sockjs/node_modules/rbytes/build'
       Traceback (most recent call last):
         File "/tmp/node-node-Rkll/bin/node-waf", line 16, in <module>
           Scripting.prepare(t, os.getcwd(), VERSION, wafdir)
         File "/tmp/node-node-Rkll/bin/../lib/node/wafadmin/Scripting.py", line 145, in prepare
           prepare_impl(t, cwd, ver, wafdir)
         File "/tmp/node-node-Rkll/bin/../lib/node/wafadmin/Scripting.py", line 135, in prepare_impl
           main()
         File "/tmp/node-node-Rkll/bin/../lib/node/wafadmin/Scripting.py", line 188, in main
           fun(ctx)
         File "/tmp/node-node-Rkll/bin/../lib/node/wafadmin/Scripting.py", line 386, in build
           return build_impl(bld)
         File "/tmp/node-node-Rkll/bin/../lib/node/wafadmin/Scripting.py", line 405, in build_impl
           bld.compile()
         File "/tmp/node-node-Rkll/bin/../lib/node/wafadmin/Build.py", line 268, in compile
           os.chdir(self.bldnode.abspath())
       OSError: [Errno 2] No such file or directory: '/home/dcaclab/RubymineProjects/nodejs_consumer/node_modules/shoe/node_modules/sockjs/node_modules/rbytes/build'
       npm ERR! weird error 1
       npm ERR! not ok code 0
 !     Failed to rebuild dependencies with npm
 !     Heroku push rejected, failed to compile Node.js app

To git@heroku.com:dcaclab-simulator.git
 ! [remote rejected] master -> master (pre-receive hook declined)
error: failed to push some refs to 'git@heroku.com:dcaclab-simulator.git'

推荐答案

因此rbytes软件包已经两年没有变化,并且在那个时候,节点已从node-waf构建系统切换到了node-gyp.从节点v0.10.0开始,不再包含node-waf,因此出现sh: node-waf: not found错误消息.我认为您有几种选择(按优先顺序排列):

So the rbytes package has been unchanged for 2 years, and in that time node has switched from the node-waf build system to node-gyp. As of node v0.10.0, node-waf is no longer included thus the sh: node-waf: not found error message. I think you have a few options (in order of preference):

  1. 使用更现代的模块代替rbytes
  2. 说服rbytes的作者进行更新以支持最近的节点并发布新版本
  3. 叉个字节并自己修复
  4. 将您的package.json引擎设置为节点0.8,然后重试

编辑

好吧,错误消息2仍然看起来rbytes不能正确构建.我必须深入研究该软件包才能了解错误.不确定在本地如何/为什么为您工作,但是在heroku上遇到问题,但是我认为是rbytes维护人员进行一些维护的时候了.

Well, error message #2 still looks like rbytes doesn't build properly. I'd have to dig into that package particularly to understand the error. Not sure how/why it's working for you locally but having problems on heroku, but I think it's time for the rbytes maintainer to do some maintenance.

这篇关于无法使用npm重建依赖关系的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆