在运行生产过程时,构建失败并显示致命错误:接近堆限制的无效标记压缩分配失败-JavaScript内存不足,在运行开发时,构建失败并通过
我尝试使用set NODE_OPTIONS =-max_old_space_size = 8172 && npm run build:production运行,在这种情况下,构建在本地传递,但同一命令在服务器中不起作用并失败
webpack.config.js
const path = require('path');
const webpack = require('webpack');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const CleanWebpackPlugin = require('clean-webpack-plugin');
const WebpackNotifierPlugin = require('webpack-notifier');
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
const HtmlWebpackHarddiskPlugin = require('html-webpack-harddisk-plugin');
const TerserPlugin = require('terser-webpack-plugin');
const devServerHost = 'localhost';
const devServerPort = 8080;
const isProd = (process.env.NODE_ENV === 'production');
const isDevServer = !isProd && path.basename(require.main.filename) === 'webpack-dev-server.js';
function getPlugins() {
let htmlWebpackOptions = {
inject: false,
filename: "../Index.cshtml",
template: "./Index_Template.cshtml",
isDevServer: false
};
if (!isProd && isDevServer) {
htmlWebpackOptions.alwaysWriteToDisk = true;
htmlWebpackOptions.isDevServer = true;
htmlWebpackOptions.devServerUrlRoot = `http://${devServerHost}:${devServerPort}`;
};
let plugins = [
new CleanWebpackPlugin(),
new webpack.ProvidePlugin({
$: 'jquery',
jQuery: 'jquery',
'window.jQuery': 'jquery',
'window.$': 'jquery',
jquery: 'jquery',
moment: 'moment'
}),
new MiniCssExtractPlugin({
// Options similar to the same options in webpackOptions.output
// both options are optional
filename: isDevServer ? '[name].bundle.css' : '[name].bundle.[contenthash].cs',
chunkFilename: isDevServer ? '[id].css' : '[id].[hash].css'
}),
new webpack.IgnorePlugin(/cptable/),
new HtmlWebpackPlugin(htmlWebpackOptions),
new webpack.ContextReplacementPlugin(
/\@angular(\\|\/)core(\\|\/)fesm5/,
path.resolve(__dirname, 'app'), {}
)
];
if (!isProd) {
if (isDevServer) {
plugins.push(new HtmlWebpackHarddiskPlugin());
}
plugins.push(new WebpackNotifierPlugin({ title: 'ICC Build' }));
}
return plugins;
}
module.exports = {
mode: isProd ? 'production' : 'development',
entry: {
//Order is important to have vendor before app
vendor: ['./Scripts/vendor-bundleconfig.ts'],
app: ['./app/main']
},
output: {
filename: '[name].bundle.[chunkhash].js',
path: path.resolve(__dirname, 'dist'),
libraryTarget: 'var',
library: 'XLSX'
},
plugins: getPlugins(),
// Enable sourcemaps for debugging webpack's output.
devtool: 'source-map',
devServer: {
contentBase: './should_be_empty',
host: devServerHost,
port: devServerPort,
headers: {
'Access-Control-Allow-Origin': '*'
},
historyApiFallback: true
},
resolve: {
// Add '.ts' and '.tsx' as resolvable extensions.
extensions: [".ts", ".tsx", ".js"]
},
module: {
rules: [
// tslint
{ test: /\.ts$/, enforce: "pre", loader: "tslint-loader", exclude: '/node_modules', options: { emitErrors: true, failOnHint: true } },
// All files with a '.ts' or '.tsx' extension will be handled by 'awesome-typescript-loader'.
{ test: /\.tsx?$/, loader: "awesome-typescript-loader", exclude: '/node_modules', },
// All output '.js' files will have any sourcemaps re-processed by 'source-map-loader'.
{
enforce: "pre", test: /\.js$/, loader: "source-map-loader", "exclude": [
// instead of /\/node_modules\//
path.join(process.cwd(), 'node_modules')
]
},
// CSS
{
test: /\.css$/,
use: [
{
loader: 'style-loader'
},
{
loader: 'css-loader'
}
]
},
// CSS
//{ test: /\.css$/, use: MiniCssExtractPlugin.extract({ use: [{ loader: 'css-loader', options: { sourceMap: true, url: true } }] }) },
// Images
{ test: /\.woff2?$|\.ttf$|\.eot$|\.svg$|\.png$|\.gif$/, use: [{ loader: "file-loader", query: { name: "[path][name].[ext]" } }] },
{
// Mark files inside `@angular/core` as using SystemJS style dynamic imports.
// Removing this will cause deprecation warnings to appear.
test: /[\\]@angular[\\]core[\\].+\.js$/,
parser: { system: true }, // enable SystemJS
}
]
},
optimization: {
minimizer: [
new TerserPlugin({
test: /\.js(\?.*)?$/i,
}),
]
},
node: { fs: "empty" },
externals: [
{ './jszip': 'jszip' },
{ './cptable': 'var cptable' },
{ jquery: 'jQuery' }
]
};
我的package.json
{
"name": "Test.online",
"version": "0.0.1",
"description": "",
"scripts": {
"start": "webpack-dev-server --inline --progress --colors --port 8080 --content-base ./should_be_empty",
"build": "rimraf dist && rimraf Index.cshtml && webpack --color",
"build:production": "set NODE_ENV=production&&webpack -p && set NODE_OPTIONS=--max_old_space_size=8172",
"watch": "webpack --watch --color",
"test": "karma start --single-run --browsers ChromeHeadless --reporters=progress karma.conf.js",
"test:watch": "karma start --auto-watch --browsers ChromeHeadless --reporters=progress karma.conf.js",
"test:build": "karma start --single-run --browsers ChromeHeadless --reporters=junit,progress karma.conf.js",
"test:debug": "karma start --auto-watch --browsers ChromeDebugging --reporters=progress karma.conf.js"
},
"license": "UNLICENSED",
"devDependencies": {
"@angular-devkit/build-angular": "^0.800.0",
"@angular-devkit/build-webpack": "^0.800.0",
"@angular/cli": "^8.0.0",
"@angular/compiler-cli": "^8.0.0",
"@angular/language-service": "^8.0.0",
"@types/jasmine": "^2.8.16",
"@types/node": "^12.6.4",
"angular-ui-tree": "^2.22.6",
"awesome-typescript-loader": "^5.1.1",
"clean-webpack-plugin": "^2.0.2",
"codelyzer": "^5.1.0",
"css-loader": "^0.28.11",
"enzyme": "^2.9.1",
"expose-loader": "^0.7.5",
"file-loader": "^2.0.0",
"html-replace-webpack-plugin": "^2.5.5",
"html-webpack-harddisk-plugin": "^1.0.1",
"html-webpack-plugin": "^3.2.0",
"jasmine": "^2.99.0",
"jasmine-core": "^2.99.1",
"jasmine-enzyme": "^3.8.3",
"jasmine-spec-reporter": "^4.2.1",
"karma": "^4.2.0",
"karma-chrome-launcher": "^3.0.0",
"karma-cli": "^2.0.0",
"karma-coverage-istanbul-reporter": "~2.0.1",
"karma-jasmine": "^1.1.2",
"karma-jasmine-html-reporter": "^0.2.2",
"karma-junit-reporter": "^1.2.0",
"karma-sourcemap-loader": "^0.3.7",
"karma-webpack": "^2.0.13",
"ng-text-truncate-2": "^1.0.1",
"protractor": "^5.4.2",
"react": "^15.6.2",
"react-addons-test-utils": "^15.6.2",
"react-dom": "^15.6.2",
"react-test-renderer": "^15.6.2",
"rimraf": "^2.6.3",
"rxjs-tslint": "^0.1.7",
"source-map-loader": "^0.2.4",
"terser-webpack-plugin": "^1.3.0",
"ts-node": "~7.0.0",
"tslint": "^5.18.0",
"tslint-loader": "3.6.0",
"typescript": "3.4.5",
"webpack": "^4.35.3",
"webpack-bundle-analyzer": "^3.3.2",
"webpack-cli": "^3.3.5",
"webpack-dev-server": "^3.7.2",
"webpack-notifier": "^1.8.0"
},
"dependencies": {
"@angular/animations": "^8.0.0",
"@angular/common": "^8.0.0",
"@angular/compiler": "^8.0.0",
"@angular/core": "^8.0.0",
"@angular/forms": "^8.0.0",
"@angular/platform-browser": "^8.0.0",
"@angular/platform-browser-dynamic": "^8.0.0",
"@angular/router": "^8.0.0",
"@angular/upgrade": "^8.0.0",
"@types/angular": "1.5.12",
"@types/angular-mocks": "1.5.10",
"@types/chroma-js": "^1.4.1",
"@types/core-js": "^2.5.2",
"@types/jquery": "^2.0.53",
"@types/prop-types": "^15.7.1",
"@types/react": "^15.0.23",
"@types/react-dom": "^15.5.0",
"@types/ui-grid": "0.0.38",
"@uirouter/angular-hybrid": "~8.0.0",
"@uirouter/angularjs": "^1.0.20",
"@uirouter/visualizer": "^7.0.0",
"angular": "1.6.10",
"angular-animate": "1.6.10",
"angular-file-saver": "1.1.3",
"angular-local-storage": "^0.7.1",
"angular-mocks": "1.5.7",
"angular-svg-round-progressbar": "^0.4.8",
"angular-ui-tree": "2.22.6",
"canvg-browser": "^1.0.0",
"chroma-js": "^1.4.1",
"classlist.js": "^1.1.20150312",
"core-js": "^3.1.3",
"fileapi": "^2.1.1",
"humanize-duration": "^3.18.0",
"jquery": "^2.1.1",
"mini-css-extract-plugin": "^0.7.0",
"moment": "2.10.6",
"ng-text-truncate-2": "^1.0.1",
"prop-types": "^15.7.2",
"rxjs": "^6.5.0",
"ts-loader": "^6.0.4",
"tslib": "^1.9.0",
"ui-router-visualizer": "^4.0.0",
"webpack-filter-warnings-plugin": "^1.2.1",
"xlsx": "^0.11.19",
"xlsx-style": "https://registry.npmjs.org/xlsx-style/-/xlsx-style-0.8.13.tgz",
"zone.js": "^0.9.1"
},
"-vs-binding": {
"AfterBuild": [
"build"
],
"ProjectOpened": [
"watch"
]
}
}
在控制台中出现以下错误,我同时在本地和服务器中获取
<--- Last few GCs --->
[237840:0000029FB4CC4C40] 281470 ms: Mark-sweep 1331.3 (1453.8) -> 1321.9 (1457.3) MB, 3742.7 / 0.0 ms (average mu = 0.097, current mu = 0.048) allocation failure scavenge might not succeed
[237840:0000029FB4CC4C40] 284506 ms: Mark-sweep 1335.2 (1457.3) -> 1326.1 (1457.3) MB, 2885.5 / 0.0 ms (average mu = 0.074, current mu = 0.049) allocation failure scavenge might not succeed
<--- JS stacktrace --->
==== JS stack trace =========================================
0: ExitFrame [pc: 000000D5138DC5C1]
Security context: 0x01af6e61e6e9 <JSObject>
1: _(aka _) [0000033529102201] [C:\git-angular\ICC\Server\AuraLiteOnline\PwC.Aura.Online\node_modules\terser-webpack-plugin\node_modules\terser\dist\bundle.min.js:~1] [pc=000000D515B25DD6](this=0x02b3515826f1 <undefined>,n=0x013bb58a2bb9 <String[4]: punc>,i=0x02b351586629 <String[1]: .>,o=0x02b3515826f1 <undefined>)
2: arguments adaptor frame: 2->3...
FATAL ERROR: Ineffective mark-compacts near heap limit Allocation failed - JavaScript heap out of memory
1: 00007FF7E490C6AA v8::internal::GCIdleTimeHandler::GCIdleTimeHandler+4506
2: 00007FF7E48E7416 node::MakeCallback+4534
3: 00007FF7E48E7D90 node_module_register+2032
4: 00007FF7E4C0189E v8::internal::FatalProcessOutOfMemory+846
5: 00007FF7E4C017CF v8::internal::FatalProcessOutOfMemory+639
6: 00007FF7E4DE7F94 v8::internal::Heap::MaxHeapGrowingFactor+9620
7: 00007FF7E4DDEF76 v8::internal::ScavengeJob::operator=+24550
8: 00007FF7E4DDD5CC v8::internal::ScavengeJob::operator=+17980
9: 00007FF7E4DE6317 v8::internal::Heap::MaxHeapGrowingFactor+2327
10: 00007FF7E4DE6396 v8::internal::Heap::MaxHeapGrowingFactor+2454
11: 00007FF7E4F10637 v8::internal::Factory::NewFillerObject+55
12: 00007FF7E4F8DCD9 v8::internal::operator<<+74697
13: 000000D5138DC5C`enter code here`1
npm ERR! code ELIFECYCLE
npm ERR! errno 134
请提出任何解决此问题的解决方案
答案 0 :(得分:1)
我在服务器中发现了上述问题的修复程序,内存问题在那里,因此导致了上面的错误,使其正常工作,我在“ npm install”之后添加了以下任务 下一步->“ npm install增加内存限制”,然后->必须运行此任务“ increase-memory-limit”。
更改后,生产版本将成功。