Webpack крайне медленная сборка

Я использую webpack + typescript + реагировать.

webpack.config.js:

var webpack = require('webpack');
var path = require('path');
var node_modules_dir = path.join(__dirname, 'node_modules');

var deps = [
  'react/react.js',
  'react-dom/react-dom.js',
];

var config = {
    devtool: 'source-map',
    context: __dirname + '/Scripts/ts',
    entry: {
        server: "./server.js",
        client: "./client.ts"
    },
    output: {
        path: path.resolve(__dirname, "Scripts/public/"),
        filename: '[name].bundle.js'
    },
    resolve: {
        alias: {},
        modulesDirectories: ["node_modules"],
        extensions: ['', '.webpack.js', '.web.js', '.ts', '.tsx', '.js']
    },
    module: {
        noParse: [],

        // Use the expose loader to expose the minified React JS
        // distribution. For example react-router requires this
        loaders: [ {
            test: /\.ts(x?)$/,
            exclude: /(node_modules|bower_components)/,
            loader: 'babel-loader?presets[]=es2015&presets[]=react!ts-loader'
        },
        {
            test: path.resolve(node_modules_dir, deps[0]),
            loader: "expose?React"
        },
        ]
    },
    watch: true
};

deps.forEach(function (dep) {
    var depPath = path.resolve(node_modules_dir, dep);
    config.resolve.alias[dep.split(path.sep)[0]] = depPath;
    config.module.noParse.push(depPath);
});

module.exports = config;

Моя проблема - скорость сборки. Начальный процесс занимает около 25 с и инкрементный - 5-6 с. Результат:

webpack --profile --display-modules

является:

ts-loader: Using [email protected] and C:\Users\rylkov.i\Documents\Visual Studio 2013\Projects\react_test_app\react_test_app\tsconfig.json
Hash: d6d85b30dfc16f19f4a6
Version: webpack 1.12.9
Time: 25547ms
               Asset     Size  Chunks             Chunk Names
    client.bundle.js  1.14 MB       0  [emitted]  client
    server.bundle.js  1.14 MB       1  [emitted]  server
client.bundle.js.map  1.31 MB       0  [emitted]  client
server.bundle.js.map  1.31 MB       1  [emitted]  server
   [0] ./client.ts 80 bytes {0} [built]
       factory:38ms building:21905ms dependencies:1ms = 21944ms
   [0] ./server.js 70 bytes {1} [built]
       factory:14ms building:19ms = 33ms
   [1] C:/Users/rylkov.i/Documents/Visual Studio 2013/Projects/react_test_app/react_test_app/~/expose-loader?Components!./components/index.js 179 bytes {0} {1} [built]
       [0] 33ms -> factory:2078ms building:8ms = 2119ms
   [2] C:/Users/rylkov.i/Documents/Visual Studio 2013/Projects/react_test_app/react_test_app/Scripts/ts/components/index.js 210 bytes {0} {1} [built]
       [0] 33ms -> [1] 2086ms -> factory:19832ms building:4ms = 21955ms
   [3] C:/Users/rylkov.i/Documents/Visual Studio 2013/Projects/react_test_app/react_test_app/Scripts/ts/components/main.tsx 4.78 kB {0} {1} [built]
       [0] 33ms -> [1] 2086ms -> [2] 19836ms -> factory:26ms building:331ms dependencies:1ms = 22313ms
   [4] C:/Users/rylkov.i/Documents/Visual Studio 2013/Projects/react_test_app/react_test_app/~/react/react.js 172 bytes {0} {1} [built]
       [0] 33ms -> [1] 2086ms -> [2] 19836ms -> [3] 357ms -> factory:315ms building:0ms = 22627ms
   [5] C:/Users/rylkov.i/Documents/Visual Studio 2013/Projects/react_test_app/react_test_app/~/react/react.js 641 kB {0} {1} [built]
       [0] 33ms -> [1] 2086ms -> [2] 19836ms -> [3] 357ms -> [4] 315ms -> factory:1ms building:86ms = 22714ms
   [6] C:/Users/rylkov.i/Documents/Visual Studio 2013/Projects/react_test_app/react_test_app/Scripts/ts/components/todoItem.tsx 2.81 kB {0} {1} [built]
       [0] 33ms -> [1] 2086ms -> [2] 19836ms -> factory:28ms building:576ms dependencies:70ms = 22629ms
   [7] C:/Users/rylkov.i/Documents/Visual Studio 2013/Projects/react_test_app/react_test_app/Scripts/ts/components/selectControl.tsx 3.44 kB {0} {1} [built]
       [0] 33ms -> [1] 2086ms -> [2] 19836ms -> factory:27ms building:428ms dependencies:218ms = 22628ms
   [8] C:/Users/rylkov.i/Documents/Visual Studio 2013/Projects/react_test_app/react_test_app/~/react-dom/react-dom.js 1.17 kB {0} {1} [built]
       [0] 33ms -> [1] 2086ms -> [2] 19836ms -> [7] 455ms -> factory:215ms building:4ms = 22629ms
   [9] C:/Users/rylkov.i/Documents/Visual Studio 2013/Projects/react_test_app/react_test_app/Scripts/ts/components/selectItem.tsx 2.63 kB {0} {1} [built]
       [0] 33ms -> [1] 2086ms -> [2] 19836ms -> factory:28ms building:502ms dependencies:144ms = 22629ms
  [10] C:/Users/rylkov.i/Documents/Visual Studio 2013/Projects/react_test_app/react_test_app/~/imports-loader?$=jquery!C:/Users/rylkov.i/Documents/Visual Studio 2013/Projects/react_test_app/react_test_app/Scripts/ui-select.js 99.6 kB {0} {1} [built]
       [0] 33ms -> [1] 2086ms -> [2] 19836ms -> [7] 455ms -> factory:150ms building:145ms = 22705ms
  [11] C:/Users/rylkov.i/Documents/Visual Studio 2013/Projects/react_test_app/react_test_app/~/jquery/dist/jquery.js 348 kB {0} {1} [built]
       [0] 33ms -> [1] 2086ms -> [2] 19836ms -> [7] 455ms -> [10] 295ms -> factory:10ms building:211ms = 22926ms

Я думаю, что это очень медленно. react.js и response-dom.js уже скомпилированы js файлы без дополнительных требований. Мои компоненты - просто примеры. Еще одна проблема с webpack:

watch:true

атрибут config. Я не могу понять, почему работает не. Но, возможно, это связано с медленным процессом сборки. Спасибо!

Ответ 1

Вы можете попробовать:

 devtool: 'eval',

Он будет производить значительно больший файл, но в половине случаев. Не рекомендуется для производства.

Ответ 2

Вы объединяетесь в jQuery и React. Чтобы уменьшить размер вашего пакета и свести к минимуму время, затрачиваемое на сборку, я бы рекомендовал установить их как внешние в конфигурации webpack и загрузить их асинхронно через CDN.

Примеры внешних веб-страниц:

externals: {
    react: 'React',
    jquery: 'jQuery'
}

Ответ 3

Удаление dev-tool: source-maps должно ускорить время компиляции. Также важно отметить, что ваши файлы находятся на большей стороне, так как вывод превышает 1 МБ.

Вы также можете добавить флаг cacheDirectory: true в babel-loader. Я обнаружил, что это значительно ускорило мои сборки в моей компании. Ссылка - https://webpack.js.org/loaders/babel-loader/#options

Также я лично использую флаг --watch, когда хочу, чтобы веб-пакет работал в режиме просмотра. Это позволяет мне лучше контролировать, когда я хочу, чтобы он действительно работал.

Ответ 4

Одна вещь, особенно в разработке, не забудьте установить mode:

module.exports = {
  mode: "development"

  // Other options...
}

Если он вообще не установлен (похоже, его нет в конфигурации общего веб-пакета), он по умолчанию будет "production". Это идеально, так как вы хотите, чтобы ваш код запускался в рабочем режиме для развертывания, поскольку он минимизирует, выполняет удаление мертвого кода, некоторые пакеты (например, React) поставляют различные сборки в зависимости от среды, среди прочего.

Тем не менее, если вы находитесь в разработке, работа в рабочем режиме может добавить некоторые затраты времени на сборку, потому что выполнение этого минимизации, устранение мертвого кода и т.д. Увеличивает общее время сборки. Это неизбежно для реального производства, так что это не поможет этому времени сборки, но, если вы создаете значительно больше в процессе разработки, это должно сэкономить некоторое время.

Кроме того, рассмотрите возможность изменения параметра devtool на более дешевый вариант, например cheap-module-eval-source-map, или один из других параметров в документах: https://webpack.js.org/configuration/devtool/. Документы объясняют различия и затраты времени на строительство. Текущая опция source-map - одна из самых медленных.

module.exports = {
  devtool: "cheap-module-eval-source-map"

  // Other options...
}