【问题标题】:Heroku app stops working after some time and needs reopeningHeroku 应用程序在一段时间后停止工作,需要重新打开
【发布时间】:2017-02-17 00:16:03
【问题描述】:

我已将 node.js 服务器上传到 heroku。它的目的是向我的用户发送通知。它正在监听 firebase 数据库并发送通知。问题是,一个小时左右的工作后,它停止发送通知,当我在 heroku 上打开应用程序时,它又开始工作了。这真的很奇怪。有任何想法吗?我的代码和这个类似

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();
});

【问题讨论】:

    标签: node.js heroku firebase firebase-cloud-messaging


    【解决方案1】:

    来自Heroku dev center

    免费测功机是独一无二的,因为它们会在 30 分钟不活动后进入睡眠状态。

    您使用的是免费套餐吗?

    【讨论】:

    • 这很可能是答案,但你最好重新措辞你的问题,让它听起来像一个答案而不是评论;)
    • 是的,您能多说一点。所以我必须为此付出代价?
    • 好的。我在这里添加了我的 heroku 应用程序站点 herokuping.com 。现在应该没事了。
    猜你喜欢
    • 2019-08-08
    • 1970-01-01
    • 1970-01-01
    • 2021-02-06
    • 1970-01-01
    • 2022-11-15
    • 2010-11-30
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多