为什么我的firebase连接会超时?

时间:2014-08-04 19:51:39

标签: firebase nest-api

我正在尝试使用我的Node.js网络应用程序连接到firebase,但从上周五开始,我开始遇到一些问题,间歇性地导致我的应用程序不接收来自firebase的任何数据并超时。我认为这是firebase的一个问题,但为了安全起见,我恢复了一个运行良好的旧版/更简单版本。但是,我的旧版本也没有用。

为了进行调试,我一直专注于"测试"场景。在我的app.js文件中,我有路由app.get('/listener/test', listener.test);,在我的监听路由中我有:

DeviceListener.prototype.test = function() {
    var url = 'wss://developer-api.nest.com/';
    var dataRef =new Firebase(url);
    console.log("Testing. Attempting to authenticate firebase.");
    dataRef.auth(this.token, function (error, result) {
        if (error) console.log("Firebase Authentication Error: " + error);
        else {
            console.log("Firebase authentication success");
            dataRef.on("child_changed", function(snapshot){
                var device_data = snapshot.val();
                console.log(JSON.stringify(device_data));
                console.log("Device Changed");
            });
        }
    });
}

但是,当我转到/listener/test时,我只有控制台输出:

at=info method=GET path="/listener/test" host=ooma2.herokuapp.com request_id=f1de66a2-2086-4aa1-b4a9-5a399110850a fwd="38.112.2.94" dyno=web.1 connect=3ms service=30ms status=302 bytes=707 
heroku/router:  at=info method=GET path="/" host=ooma2.herokuapp.com request_id=f8c42a92-8e0d-489c-ba37-fc10a7286d4d fwd="38.112.2.94" dyno=web.1 connect=2ms service=13ms status=302 bytes=698 
heroku/router:  at=info method=GET path="/login" host=ooma2.herokuapp.com request_id=3826633b-3159-4495-82a4-966739066b8a fwd="38.112.2.94" dyno=web.1 connect=2ms service=26ms status=304 bytes=738 
app/web.1:  Testing. Attempting to authenticate firebase. 
heroku/router:  at=info method=GET path="/stylesheet/login.css" host=ooma2.herokuapp.com request_id=057aa990-57ee-4aac-91f2-e1543d2a9c02 fwd="38.112.2.94" dyno=web.1 connect=2ms service=7ms status=404 bytes=679 
heroku/router:  at=info method=GET path="/stylesheet/ooma.css" host=ooma2.herokuapp.com request_id=2f483b7b-a8f5-467a-bdf4-4c594ca0c2e0 fwd="38.112.2.94" dyno=web.1 connect=2ms service=5ms status=404 bytes=678 
heroku/router:  at=error code=H12 desc="Request timeout" method=GET path="/bower_components/firebase/firebase.js" host=ooma2.herokuapp.com request_id=533d2333-bb0e-4fcf-b81f-fc0dd5bd1808 fwd="38.112.2.94" dyno=web.1 connect=3ms service=30001ms status=503 bytes=681 
heroku/router:  at=error code=H12 desc="Request timeout" method=GET path="/js/login.js" host=ooma2.herokuapp.com request_id=971d1823-a9fd-4f85-b488-2d77f209acec fwd="38.112.2.94" dyno=web.1 connect=1ms service=30001ms status=503 bytes=655 
heroku/router:  at=error code=H12 desc="Request timeout" method=GET path="/bower_components/jquery-cookie/jquery.cookie.js" host=ooma2.herokuapp.com request_id=bcde664a-e580-4854-bd12-47df563464f0 fwd="38.112.2.94" dyno=web.1 connect=1ms service=30001ms status=503 bytes=691 
heroku/router:  at=error code=H12 desc="Request timeout" method=GET path="/bower_components/jquery/dist/jquery.js" host=ooma2.herokuapp.com request_id=969c6fd0-9801-4f78-af59-10e63ad52fa9 fwd="38.112.2.94" dyno=web.1 connect=33ms service=30033ms status=503 bytes=684 

由于既未记录消息Firebase Authentication Error: ...也未记录Firebase Authentication Success,我猜这意味着身份验证永远不会完成。

这听起来合乎逻辑吗?因为如果是这样,我不确定如何着手解决它。我非常感谢有关这方面的任何想法和想法,或任何其他解释。还有,还有其他人经历过类似的事吗?特别是在2014年8月1日左右开始?

1 个答案:

答案 0 :(得分:2)

过去几天我一直有同样的问题。今晚我将我的节点版本降级到v0.10.20,问题似乎已得到解决,但我只会知道更多的时间。您可以尝试将其放在package.json中:

  "engines": {
         "node": "0.10.20",
         "npm": ">=1.3"
     }

(之前我发布了一个关于编写'心跳'功能的答案,该功能每隔30秒就会对Firebase进行一次ping操作以防止超时。这似乎有效,但问题稍后会再次出现。)