From a500edd0c2f39ae648510777c75504cde6e5b967 Mon Sep 17 00:00:00 2001 From: Tiago Costa Date: Fri, 7 Feb 2020 04:20:44 +0000 Subject: [PATCH 1/2] chore(NA): removes use of parallel option in the terser minimizer --- src/optimize/base_optimizer.js | 2 +- .../dynamic_dll_plugin/dll_config_model.js | 16 ++++++++++------ 2 files changed, 11 insertions(+), 7 deletions(-) diff --git a/src/optimize/base_optimizer.js b/src/optimize/base_optimizer.js index d9df2a1955df3..539c55c969653 100644 --- a/src/optimize/base_optimizer.js +++ b/src/optimize/base_optimizer.js @@ -459,7 +459,7 @@ export default class BaseOptimizer { optimization: { minimizer: [ new TerserPlugin({ - parallel: this.getThreadLoaderPoolConfig().workers, + parallel: false, sourceMap: false, cache: false, extractComments: false, diff --git a/src/optimize/dynamic_dll_plugin/dll_config_model.js b/src/optimize/dynamic_dll_plugin/dll_config_model.js index 2e74cb6af86d4..9695d5faae369 100644 --- a/src/optimize/dynamic_dll_plugin/dll_config_model.js +++ b/src/optimize/dynamic_dll_plugin/dll_config_model.js @@ -214,16 +214,20 @@ function common(config) { return webpackMerge(generateDLL(config)); } -function optimized(config) { +function optimized() { return webpackMerge({ mode: 'production', optimization: { minimizer: [ new TerserPlugin({ - // Apply the same logic used to calculate the - // threadLoaderPool workers number to spawn - // the parallel processes on terser - parallel: config.threadLoaderPoolConfig.workers, + // NOTE: we should not enable that option for now + // Since 2.0.0 terser-webpack-plugin is using jest-worker + // to run tasks in a pool of workers. Currently it looks like + // is requiring too much memory and break on large entry points + // compilations (like this) one. Also the gain we have enabling + // that option is barely noticed. (1-2s gain) + // https://github.com/webpack-contrib/terser-webpack-plugin/issues/143 + parallel: false, sourceMap: false, cache: false, extractComments: false, @@ -250,5 +254,5 @@ export function configModel(rawConfig = {}) { return webpackMerge(common(config), unoptimized()); } - return webpackMerge(common(config), optimized(config)); + return webpackMerge(common(config), optimized()); } From fd5cb8ebfdc713789f031b78b17765550c7a07da Mon Sep 17 00:00:00 2001 From: Tiago Costa Date: Fri, 7 Feb 2020 04:33:49 +0000 Subject: [PATCH 2/2] docs(NA): update note --- src/optimize/dynamic_dll_plugin/dll_config_model.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/optimize/dynamic_dll_plugin/dll_config_model.js b/src/optimize/dynamic_dll_plugin/dll_config_model.js index 9695d5faae369..9ca6071b8f515 100644 --- a/src/optimize/dynamic_dll_plugin/dll_config_model.js +++ b/src/optimize/dynamic_dll_plugin/dll_config_model.js @@ -225,7 +225,7 @@ function optimized() { // to run tasks in a pool of workers. Currently it looks like // is requiring too much memory and break on large entry points // compilations (like this) one. Also the gain we have enabling - // that option is barely noticed. (1-2s gain) + // that option was barely noticed. // https://github.com/webpack-contrib/terser-webpack-plugin/issues/143 parallel: false, sourceMap: false,