我试图在不同的gulp任务中启动和停止gulp-webserver,如下所示:

gulp.task('webserver', ['build'], function () {
    gulp.src([config.build, config.base])
    .pipe(webserver({
    livereload: false,
    directoryListing: false,
    open: true
  }));
});

gulp.task('webserver-stop', function () {
    var stream = gulp.src([config.build, config.base])
      .pipe(webserver());
    stream.emit('kill');
});


我能够成功启动服务器,但是当我尝试停止使用gulp webserver-stop时,出现以下错误。

[19:36:30] Finished 'webserver-stop' after 27 ms
events.js:160
  throw er; // Unhandled 'error' event
  ^

Error: listen EADDRINUSE 127.0.0.1:8000
at Object.exports._errnoException (util.js:1008:11)
at exports._exceptionWithHostPort (util.js:1031:20)
at Server._listen2 (net.js:1253:14)
at listen (net.js:1289:10)
at net.js:1399:9
at GetAddrInfoReqWrap.asyncCallback [as callback] (dns.js:65:16)
at GetAddrInfoReqWrap.onlookup [as oncomplete] (dns.js:84:10)


我之前对gulp和javascript没有丰富的经验,
请提供任何解决此问题的帮助。

最佳答案

当您先运行gulp webserver然后gulp webserver-stop时,您有两个过程。这两个过程彼此一无所知。

因此,当您在webserver()中调用webserver-stop时,它将仅启动另一个Web服务器实例。它不会连接到已经运行的实例或类似的实例。并且由于端口8000上已经运行了一个Web服务器,因此会出现EADDRINUSE错误。

相反,您的webserver-stop任务需要向正在运行的Web服务器发送一条消息,导致其关闭。

由于您已经在运行Web服务器,因此不妨通过HTTP发送该消息。您可以使用middlewaregulp-webserver option实现此目的:

var gulp = require('gulp');
var webserver = require('gulp-webserver');
var http = require('http');

gulp.task('webserver', function () {
  var stream = gulp.src(['.'])
    .pipe(webserver({
      livereload: false,
      directoryListing: false,
      open: true,
      middleware: function(req, res, next) {
        if (/_kill_\/?/.test(req.url)) {
          res.end();
          stream.emit('kill');
        }
        next();
      }
    }));
});

gulp.task('webserver-stop', function (cb) {
  http.request('http://localhost:8000/_kill_').on('close', cb).end();
});


现在,您可以在另一个终端窗口中调用gulp webserver-stop,或者只是在浏览器中打开http://localhost:8000/_kill_来关闭正在运行的Web服务器实例。

关于javascript - 启动和停止gulp-webserver,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/38977393/

10-12 13:27