2016-10-07 19 views
0

herokuにnode.jsサーバーをアップロードしました。その目的は、ユーザーに通知を送信することです。 firebaseデータベースを聞いて通知を送信しています。問題は、1時間ほど働いた後に通知を送信しなくなり、herokuでアプリを開くと再び動作することです。それは本当に奇妙です。何か案は?私のコードはHeroku dev centerから、この1Herokuアプリがしばらくしてから動作を停止し、再度開く必要があります

var firebase = require('firebase'); 
var request = require('request'); 
var express = require('express'); 

var app = express(); 

app.set('port', (process.env.PORT || 5000)); 

var API_KEY = "..."; // Your Firebase Cloud Server API key 

firebase.initializeApp({ 
    serviceAccount: ".json", 
    databaseURL: "https://.firebaseio.com/" 
}); 
ref = firebase.database().ref(); 

function listenForNotificationRequests() { 
    var requests = ref.child('notificationRequests'); 
    ref.on('child_added', function(requestSnapshot) { 
    var request = requestSnapshot.val(); 
    sendNotificationToUser(
     request.username, 
     request.message, 
     function() { 
     request.ref().remove(); 
     } 
    ); 
    }, function(error) { 
    console.error(error); 
    }); 
}; 

function sendNotificationToUser(username, message, onSuccess) { 
    request({ 
    url: 'https://fcm.googleapis.com/fcm/send', 
    method: 'POST', 
    headers: { 
     'Content-Type' :' application/json', 
     'Authorization': 'key='+API_KEY 
    }, 
    body: JSON.stringify({ 
     notification: { 
     title: message 
     }, 
     to : '/topics/user_'+username 
    }) 
    }, function(error, response, body) { 
    if (error) { console.error(error); } 
    else if (response.statusCode >= 400) { 
     console.error('HTTP Error: '+response.statusCode+' - '+response.statusMessage); 
    } 
    else { 
     onSuccess(); 
    } 
    }); 
} 

app.listen(app.get('port'), function() { 
    listenForNotificationRequests(); 
}); 

答えて

3

に似ている:彼らは非アクティブの30分後にスリープ状態に入るため

無料dynosはユニークです。

無料のティアを使用していますか?

+0

これはおそらく答えですが、あなたの質問を改言するのがよいので、回答とコメントのように聞こえます;) – brandonscript

+0

はい、もう少し詳しく教えてください。だから、私はこれが起こらないように支払う必要がありますか? – Nikola

+0

私はherokuアプリサイトをhttp://www.herokuping.com/に追加しました。今は大丈夫です。 – Nikola

関連する問題