Gulp-Connect-Php + browserSync + Gulp-Connect адрес в использовании проблема

Мне нужна возможность использовать browserSync с поддержкой php и переписывать некоторые конкретные URL-адреса. Я придумал browserSync с пакетами Gulp-Connect-Php плюс Gulp-Connect + modrewrite. Вот мой конфиг:

var  
browserSync  = require('browser-sync'),  
phpconnect   = require('gulp-connect-php'),
connect      = require('gulp-connect'),
modrewrite   = require('connect-modrewrite'),

phpconnect.server({base:'dist/',port: 8010}, function (){
  connect.server({
    port: 8001,
    middleware: function() {
        return [
            modrewrite([
                '^/admin/(.*) - [L]',
                '^([^.]*|.*?\.php)$ http://localhost:8010$1 [P,NC]'
            ])
        ];
    }
 })

 browserSync({
   injectChanges: true,
   proxy: '127.0.0.1:8010'
 });

})

Это работает отлично и именно так, как мне нужно. Время от времени возникает следующая проблема:

[error] You tried to start Browsersync twice! To create multiple instances, use browserSync.create().init()
events.js:141
      throw er; // Unhandled 'error' event
      ^

Error: listen EADDRINUSE :::8001

Другими словами, browserSync запускается ДО gulp-connect и использует порт 8010, который должен использоваться gulp-connect, и gulp-connect не запускается.

Я установил нпм sleep пакет и добавил следующую строку перед запуском browserSync:

sleep.sleep(15)

другими словами, я добавил 15-секундную задержку перед запуском browserSync. Это работает, но я уверен, что есть более элегантное решение.

Пожалуйста, порекомендуйте.

1 ответ

gulp-connect внутренне соединяет соединение, которое запускает узел http сервер.

Он генерирует событие, когда сервер начинает называться listening, https://nodejs.org/api/net.html

    var  
    browserSync  = require('browser-sync'),  
    phpconnect   = require('gulp-connect-php'),
    connect      = require('gulp-connect'),
    modrewrite   = require('connect-modrewrite'),

    phpconnect.server({base:'dist/',port: 8010}, function (){
      var app = connect.server({
        port: 8001,
        middleware: function() {
            return [
                modrewrite([
                    '^/admin/(.*) - [L]',
                    '^([^.]*|.*?\.php)$ http://localhost:8010$1 [P,NC]'
                ])
            ];
        }
     })
     app.server.on('listening', function () {
       browserSync({
         injectChanges: true,
         proxy: '127.0.0.1:8010'
       });
     });
Другие вопросы по тегам