我遇到一个问题,经过gulp watch触发几次重启后,我收到一条警告,说明我可能有内存泄漏。我认为这是因为我每次重启都会启动一个新的gulp手表实例,一遍又一遍地触发新服务器和另一个新手表。我不确定是不是这样,如果确实如此,我也不确定如何修复它。
这是我的gulpfile.js。
const gulp = require('gulp');
const exec = require('child_process').exec;
const gutil = require('gulp-util');
const eslint = require('gulp-eslint');
gulp.task('dev', (() => {
gulp.start('test');
gulp.start('lint');
gulp.start('server');
gulp.start('watch');
return gutil.log('Gulp is running!');
}));
gulp.task('server', (cb) => {
exec('npm start', (err, stdout, stderr) => {
gutil.log(stdout);
gutil.log(stderr);
cb(err);
});
});
gulp.task('test', (cb) => {
exec('npm test', (err, stdout, stderr) => {
gutil.log(stdout);
gutil.log(stderr);
cb(err);
});
});
gulp.task('watch', () => {
gulp.watch(['./app.js', './views/*', './routes/*'], ['dev']);
});
gulp.task('lint', () => {
return gulp.src(['**/*.js', '!node_modules/**'])
.pipe(eslint())
.pipe(eslint.format());
});
我的错误是:
(node:808) Warning: Possible EventEmitter memory leak detected. 11 change listeners added. Use emitter.setMaxListeners() to increase limit
答案 0 :(得分:4)
您的gulp.watch
调用任务dev
,后者又会创建另一个gulp.watch
。我的钱就在那。
答案 1 :(得分:1)
正如另一位用户所说,你在b = P(class(x) = 1)
中调用gulp dev
基本上会创建一个无效循环,这会导致这种情况。
要添加,我建议使用默认任务:
gulp watch