在CF / BlueMix

时间:2017-01-01 21:41:57

标签: node.js ibm-cloud cloudfoundry pivotal-cloud-foundry pivotal-web-services

当我尝试将以下repo部署到CF / BlueMix时,我得到了“devDependencies”的错误:

Error: Cannot find module 'webpack' 

如果我将webpack添加到dep我收到错误

Error: Cannot find module 'postcss-cssnext'

继续其他开发者......

devDependencies 的哪一部分,部署不应只安装“prod”依赖项吗?

这是回购:https://github.com/Hashnode/mern-starter

我使用npm run bs在本地运行构建,然后将manifest.yml放入以下

---
applications:
- name: myapp
  buildpack: nodejs_buildpack
  memory: 512M
  command: npm run start:prod
  services:
    - mong

可能导致失去依赖性的原因是什么?

1 个答案:

答案 0 :(得分:0)

  

您是否正在使用项目中的node_modules文件夹推送Bluemix?如果是,请尝试完全删除它并重新推送。

此外,

  

只需在.cfignore文件中添加node_modules行即可忽略node_modules目录。 buildpack将在您的云代工容器中运行节点安装。另外我建议您进行cf删除以将其从缓存中删除,然后再次执行cf push

来源:请参阅此问题的评论:unable to push node.js cloudant app to bluemix

<强>更新

我想我已经重现了这个问题:

2017-01-01T23:12:14.45+0000 [App/0]      ERR Error: Cannot find module 'webpack'
2017-01-01T23:12:14.45+0000 [App/0]      ERR     at Function.Module._resolveFilename (module.js:339:15)
2017-01-01T23:12:14.45+0000 [App/0]      ERR     at Function.Module._load (module.js:290:25)
2017-01-01T23:12:14.45+0000 [App/0]      ERR     at Module.require (module.js:367:17)
2017-01-01T23:12:14.45+0000 [App/0]      ERR     at require (internal/module.js:16:19)
2017-01-01T23:12:14.45+0000 [App/0]      ERR     at Object.defineProperty.value (/home/vcap/app/dist/server.bundle.js:280:19)
2017-01-01T23:12:14.45+0000 [App/0]      ERR     at Object.<anonymous> (/home/vcap/app/dist/server.bundle.js:1930:17)
2017-01-01T23:12:14.45+0000 [App/0]      ERR     at Object.defineProperty.value (/home/vcap/app/dist/server.bundle.js:2074:31)
2017-01-01T23:12:14.45+0000 [App/0]      ERR     at __webpack_require__ (/home/vcap/app/dist/server.bundle.js:20:30)
2017-01-01T23:12:14.45+0000 [App/0]      ERR     at /home/vcap/app/dist/server.bundle.js:40:18
2017-01-01T23:12:14.45+0000 [App/0]      ERR     at Object.<anonymous> (/home/vcap/app/dist/server.bundle.js:43:10)
2017-01-01T23:12:14.45+0000 [App/0]      ERR     at Module._compile (module.js:413:34)
2017-01-01T23:12:14.45+0000 [App/0]      ERR     at Object.Module._extensions..js (module.js:422:10)
2017-01-01T23:12:14.45+0000 [App/0]      ERR     at Module.load (module.js:357:32)
2017-01-01T23:12:14.45+0000 [App/0]      ERR     at Function.Module._load (module.js:314:12)
2017-01-01T23:12:14.45+0000 [App/0]      ERR     at Module.require (module.js:367:17)

webpack导入问题似乎与文件dist/server.bundle.js有关,对我来说这是由命令npm run bs生成的。

dist文件夹上传到Bluemix,似乎是在您的应用启动时导入的。

您可以在.cfignore中排除dist文件夹,并在使用cf push上传您的应用时构建它吗?我不确定你是否在manifest.yml中添加了多个命令,例如

command: npm <<your_new_build_command>> && npm run start:prod

但是,看起来您在新构建命令中所做的任何事情(例如npm run bs:prod)只会在创建dist文件夹时选择生产依赖项。

如果您无法从manifest.yml运行多个命令,则可能需要更改start:prod,以便它还为生产环境执行构建步骤。

更新2

您可以要求节点buildpack不缓存模块,并在每次使用NODE_MODULES_CACHE: false推送时下载它们,例如

applications:
- name: ...
  buildpack: nodejs_buildpack
  memory: 512M
  command: ...
  env:
     NODE_MODULES_CACHE: false