【问题标题】:Yeoman Angular.js grunt serve-d app has very long latency from livereload.js?snipver=1Yeoman Angular.js grunt serve-d 应用程序从 livereload.js?snipver=1 延迟很长
【发布时间】:2014-03-20 18:44:31
【问题描述】:

我跟随Yeoman's guide 设置了一个Angular.js 应用程序。 我没有更改任何内容,除了将主机名从“localhost”更改为“0.0.0.0”。

当我做grunt serve 时,没有错误。最终,我确实看到了“'Allo,'Allo”首页,但只是在 livereload.js?snipver=1 延迟超过 30 秒之后,它未能 GET。如右图所示,服务器没有输出任何异常。

我的整个项目is on github

我对 livereload 进行了 grep-ped,发现了一些嫌疑人:

  • /node_modules/grunt-contrib-connect/node_modules/connect-livereload/index.js 有下面这两个函数,包含 livereload url。第一个链接到“http://my.ip.addr.ess:9000/livereload.js”,它有一个“Cannot GET”。

    function getSnippet() {
        /*jshint quotmark:false */
        var snippet = [ 
            "<!-- livereload script -->",
            "<script type=\"text/javascript\">document.write('<script src=\"http://'",
            " + (location.host || 'localhost').split(':')[0]",
            " + ':" + port + "/livereload.js?snipver=1\" type=\"text/javascript\"><\\/  script>')",
            "</script>",
            ""  
        ].join('\n');
        return snippet;
      };    
    
      function snippetExists(body) {
        if (!body) return true;
        return (~body.lastIndexOf("/livereload.js?snipver=1"));
      }
    
  • 我的 Gruntfile.js 将 livereload 设置为 true,我想保留它。

有人知道吗?


更新:

我又试了一次全新的机器,from scratch。我仍然遇到同样的问题!这次 livereload 的状态显示“net::ERR_CONNECTION_TIMED_OUT”。

更多信息:我在 AWS EC2 上运行,只打开了 8000 和 9000 端口。


【问题讨论】:

  • 将其作为问题发布到 yeoman 的 github 上。或者在那里查找。

标签: node.js angularjs gruntjs yeoman yeoman-generator


【解决方案1】:

经过仔细考虑,我确定这不可能是 Yeoman 或我的任何 Ubuntu 服务器的问题,因为在我将机器擦干净并重新开始之后没有任何变化。它也不是浏览器上被阻止的 IP,因为 Chrome 和 Firefox 都有同样的问题。这不是我的客户端计算机上的阻止 IP,因为问题在另一台计算机上仍然存在。

当我真正查看 livereload 请求的确切 URL 时,灯泡熄灭了。它在端口 35729 上请求,这是我尚未在我的 AWS EC2 帐户上打开的端口!

我打开那个端口后,它工作得完美无缺!

【讨论】:

    猜你喜欢
    • 2016-07-28
    • 2015-07-28
    • 1970-01-01
    • 2016-01-23
    • 2015-04-13
    • 1970-01-01
    • 1970-01-01
    • 2014-05-11
    • 2012-06-23
    相关资源
    最近更新 更多