node.js - notification - browsersync laravel
BrowserSync extremadamente lento (3)
Me encantaría usar BrowserSync para el desarrollo. Sin embargo, la carga de la página (no solo la recarga después de los cambios) es extremadamente lenta.
Yo uso el modo proxy
. Navegar por la página sin BrowserSync es tan rápido como debería ser.
Una razón puede ser el siguiente error cuando instalo BrowserSync:
> ws@0.4.31 install /usr/local/lib/node_modules/browser-sync/node_modules/socket.io/node_modules/engine.io/node_modules/ws
> (node-gyp rebuild 2> builderror.log) || (exit 0)
CXX(target) Release/obj.target/bufferutil/src/bufferutil.o
SOLINK_MODULE(target) Release/bufferutil.node
SOLINK_MODULE(target) Release/bufferutil.node: Finished
CXX(target) Release/obj.target/validation/src/validation.o
SOLINK_MODULE(target) Release/validation.node
SOLINK_MODULE(target) Release/validation.node: Finished
Instalé el nodo desde cero (utilizando brew
y el instalador de paquetes), pero no pude deshacerme del error.
Además, no hace una diferencia si BrowserSync se ejecuta utilizando Gulp o sobre la línea de comandos.
¿Alguna idea?
En mi caso estaba usando ventanas. Después de analizar la pestaña de red en firebug noté que faltaban algunas imágenes. Tan pronto como arreglé las imágenes funcionó rápido!
Es muy probable que tengas este problema en macOS!
De lo que he recopilado de mi investigación, esto es el resultado de las búsquedas de Bonjour IPv6 que se emiten para ciertas búsquedas de DNS en dominios .local. Estas búsquedas de IPv6 crean un retraso de tiempo de espera hasta que se emite la búsqueda de DNS IPv4 original.
La solución de @RicoLeuthold funciona, porque los dominios .dev no activan las búsquedas de Bonjour en macOS. Pero puede ser terrible cambiar todos tus vHosts si ya tienes muchos de ellos ejecutándose en dominios .local con proyectos configurados para usar estos dominios .local también.
SOLUCIÓN ALTERNATIVA
Una alternativa es agregar una entrada de host local de IPv6 adicional en su archivo de hosts (generalmente / private / etc / hosts) para cada entrada .local de IPv4.
Cambiar este contenido de hosts ...
127.0.0.1 phpmyadmin.local
127.0.0.1 project1.local
127.0.0.1 project2.local
... a que aloja contenido ...
::1 phpmyadmin.local
127.0.0.1 phpmyadmin.local
::1 project1.local
127.0.0.1 project1.local
::1 project2.local
127.0.0.1 project2.local
CONSEJO: UTILIZAR UN EDITOR REGEXP
Si está utilizando un editor como Atom o Sublime Text capaz de regexp buscar / reemplazar, aquí hay un patrón para actualizar su archivo hosts:
Search:
(127.0.0.1)(.*)$
Replace:
::1$2/n$1$2
Este patrón también agregará entradas de IPv6 a la entrada general de local de IPv4 en la parte superior del archivo de hosts. Después de realizar la búsqueda / reemplazo, debe revisar la parte superior de su archivo para ver una entrada duplicada de ...
::1 localhost
... y eliminar uno de los duplicados.
La solución es bastante simple, pero imógica. Tuve mi instancia local ejecutándose bajo http://project.local
. Cambiarlo a http://project.dev
solucionó el problema. Estoy ejecutando OS X.