2016-09-26 93 views
3

我很惊讶,当我在执行更多组件后运行polymer build时,内存不足。这怎么可能?我不会考虑我的网站/应用很大尚未...聚合物CLI构建内存不足

info: Building application... 
info: Generating build/unbundled... 
info: Generating build/bundled... 

<--- Last few GCs ---> 

    105411 ms: Mark-sweep 1343.6 (1434.7) -> 1343.0 (1434.7) MB, 1430.6/0 ms [allocation failure] [GC in old space requested]. 
    106857 ms: Mark-sweep 1343.0 (1434.7) -> 1343.0 (1434.7) MB, 1446.6/0 ms [allocation failure] [GC in old space requested]. 
    108349 ms: Mark-sweep 1343.0 (1434.7) -> 1343.0 (1434.7) MB, 1491.5/0 ms [last resort gc]. 
    109808 ms: Mark-sweep 1343.0 (1434.7) -> 1342.6 (1434.7) MB, 1459.5/0 ms [last resort gc]. 


<--- JS stacktrace ---> 

==== JS stack trace ========================================= 

Security context: 0x24b44a0c9e31 <JS Object> 
    2: nextToken [/Users/limjiewmeng/.nvm/versions/node/v6.4.0/lib/node_modules/polymer-cli/node_modules/acorn/dist/acorn.js:~2459] [pc=0x313c0f47bb3b] (this=0x3618e7c0f981 <a Parser with map 0x18a29db9aa01>) 
    3: next [/Users/limjiewmeng/.nvm/versions/node/v6.4.0/lib/node_modules/polymer-cli/node_modules/acorn/dist/acorn.js:2413] [pc=0x313c0ee10d47] (this=0x3618e7c0f981 <a Parser with map 0x... 

FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 
1: node::Abort() [/Users/limjiewmeng/.nvm/versions/node/v6.4.0/bin/node] 
2: node::FatalException(v8::Isolate*, v8::Local<v8::Value>, v8::Local<v8::Message>) [/Users/limjiewmeng/.nvm/versions/node/v6.4.0/bin/node] 
3: v8::internal::V8::FatalProcessOutOfMemory(char const*, bool) [/Users/limjiewmeng/.nvm/versions/node/v6.4.0/bin/node] 
4: v8::internal::Factory::NewFixedArray(int, v8::internal::PretenureFlag) [/Users/limjiewmeng/.nvm/versions/node/v6.4.0/bin/node] 
5: v8::internal::FullCodeGenerator::PopulateDeoptimizationData(v8::internal::Handle<v8::internal::Code>) [/Users/limjiewmeng/.nvm/versions/node/v6.4.0/bin/node] 
6: v8::internal::FullCodeGenerator::MakeCode(v8::internal::CompilationInfo*) [/Users/limjiewmeng/.nvm/versions/node/v6.4.0/bin/node] 
7: v8::internal::Compiler::EnsureDeoptimizationSupport(v8::internal::CompilationInfo*) [/Users/limjiewmeng/.nvm/versions/node/v6.4.0/bin/node] 
8: v8::internal::OptimizedCompileJob::CreateGraph() [/Users/limjiewmeng/.nvm/versions/node/v6.4.0/bin/node] 
9: v8::internal::Compiler::GetOptimizedCode(v8::internal::Handle<v8::internal::JSFunction>, v8::internal::Compiler::ConcurrencyMode, v8::internal::BailoutId, v8::internal::JavaScriptFrame*) [/Users/limjiewmeng/.nvm/versions/node/v6.4.0/bin/node] 
10: v8::internal::(anonymous namespace)::CompileOptimized(v8::internal::Isolate*, v8::internal::Handle<v8::internal::JSFunction>, v8::internal::Compiler::ConcurrencyMode) [/Users/limjiewmeng/.nvm/versions/node/v6.4.0/bin/node] 
11: v8::internal::Runtime_CompileOptimized_Concurrent(int, v8::internal::Object**, v8::internal::Isolate*) [/Users/limjiewmeng/.nvm/versions/node/v6.4.0/bin/node] 
12: 0x313c0e50961b 
13: 0x313c0e538279 
[1] 8057 abort  polymer build 

运行在冗长模式给了我一些线索:

debug: accept: bower_components/iron-behaviors/iron-control-state.html 
debug: accept: bower_components/paper-ripple/paper-ripple.html 
debug: accept: bower_components/paper-styles/color.html 
debug: accept: bower_components/iron-a11y-keys-behavior/iron-a11y-keys-behavior.html 
debug: accept: bower_components/iron-behaviors/iron-control-state.html 
debug: accept: bower_components/paper-ripple/paper-ripple.html 
debug: accept: bower_components/paper-styles/color.html 
debug: accept: bower_components/iron-a11y-keys-behavior/iron-a11y-keys-behavior.html 
debug: accept: bower_components/iron-behaviors/iron-control-state.html 
debug: accept: bower_components/paper-ripple/paper-ripple.html 
debug: accept: bower_components/paper-styles/color.html 
debug: accept: bower_components/iron-a11y-keys-behavior/iron-a11y-keys-behavior.html 

看起来似乎在循环中运行?

UPDATE

我发现,如果我从polymer.json删除一些组件,将建立,但它不是我真正想要什么?

更新2:可能的解决方法

不要分段一切。内联一些进口。考虑一下这个问题,因为构建工具更有可能在“更大”的包中找到类似的依赖关系,并能够将它们组合在一起。而不必将它们包含在所有包中。

+0

也许值得在[聚合物构建](https://github.com/Polymer/polymer-build)上提出一个问题 –

回答

0

只是为了让我可以关闭它。

看来问题在于创建了太多的包。因此,不是动态地加载(几乎)每一个组件,我后来知道这可能不是一个好主意,但我开始将类似的东西组合在一起以包含在一个包中。这为我解决了这个问题。

+0

如何增加 - 聚合物中的最大空间尺寸??因为我们不'有没有package.json我们可以设置内存大小? –