Зависание сокетов в Node, Express и MongoDB - PullRequest
0 голосов
/ 09 сентября 2018

Я разрабатываю стековое приложение MEAN.Я запрашиваю APAP дляapsap.io для получения данных монет с использованием cronjobs и библиотеки запросов в Node и Express, и после извлечения данных я помещаю данные в мой экземпляр MLAB MongoDb с интервалом в 5 минут.

IЯ получаю следующие ошибки в консоли.

{ Error: connect ETIMEDOUT 104.17.39.95:80
    at Object._errnoException (util.js:999:13)
    at _exceptionWithHostPort (util.js:1020:20)
    at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1207:14)
  errno: 'ETIMEDOUT',
  code: 'ETIMEDOUT',
  syscall: 'connect',
  address: '104.17.39.95',
  port: 80 }

{ Error: socket hang up
    at createHangUpError (_http_client.js:330:15)
    at Socket.socketOnEnd (_http_client.js:423:23)
    at Socket.emit (events.js:164:20)
    at endReadableNT (_stream_readable.js:1062:12)
    at process._tickCallback (internal/process/next_tick.js:152:19) code: 'ECONNRESET' }

Ниже приведена конфигурация mongoose в файле server.js.

const options = {
    reconnectTries: 10, // Never stop trying to reconnect
    reconnectInterval: 500, // Reconnect every 500msi.e 0.5 sec
    poolSize: 15, // Maintain up to 15 socket connections
    socketTimeoutMS: 0, // Close sockets after 5 minute of inactivity
    connectTimeoutMS: 0,
    family: 4, // Use IPv4, skip trying IPv6
    keepAlive: true
};

// Connect to database via mongoose
mongoose.connect(config.database, options)
  .then(() => console.log(`MongoDB Connected ${config.database}`))
  .catch(err => console.log(err));

И сервер настроен на отсутствие тайм-аута, используя приведенный ниже код в качестве,

app.listen(port, () => console.log(`Server started on port ${port}`));
app.listen().setTimeout(0); 

Ниже приведена функция получения данных, предоставленных URL.

var historyGraphTask = cron.schedule('*/15 * * * *', function () {
    CoinGraph.count(function (err, count) {
        if (err) {
            console.log(err);
        } else {
            CoinGraph.find({}, (err, coinData) => {
                if (err) {
                    console.log(err);
                } else {
                    for (var i = 0; i < coinData.length; i++) {
                        let symbol = coinData[i].symbol;
                        const historyUrl = 'http://coincap.io/history/' + symbol;
                        DataReq(historyUrl).then((data) => {
                            if (data === null || data === undefined) {
                                console.log('Data Error in cron job of graph');
                            } else {
                                const newData = data.Data;
                                HistoryData.findOneAndUpdate({symbol: symbol} , { data : newData  }, { safe: true, upsert: true }  ,(err, historyData) => {
                                    if (err) {
                                        console.log(err);
                                    } else {
                                        CoinGraph.findOneAndUpdate({ symbol: symbol }, { historyData: historyData._id }, { safe: true, upsert: true } , function (err, updatedData) {
                                            if (err) {
                                                console.log(err);
                                            } else {
                                                console.log(updatedData);
                                            }
                                        });
                                    }
                                }); 

                            }
                        }).catch((error) => {
                            console.log(error);
                        });

                    }
                }
            });
        }

    });
});

function DataReq(Url) {
    return new Promise((resolve, reject) => {
        request(Url, {timeout: 0}, function (error, response, body) {
            if (body === undefined || body === null || error) {
                console.log(error);
                return;
            } else {
                const Data = JSON.parse(body);
                if (Data) {
                    resolve({ Data });
                } else {
                    reject();
                }
            }
        });
    });
}

Что я делаю не так?Я испробовал все возможные решения и все же застрял на этом долгое время.

1 Ответ

0 голосов
/ 10 сентября 2018

Судя по вашему коду, похоже, что он не заканчивается. Под завершением я подразумеваю выполнение любых обратных вызовов для завершения функции.

Первоначально я обнаружил, что вам нужно как-то сделать обратный вызов.

Я бы посоветовал вам проверить документацию для правильной обработки запроса либо в используемой вами библиотеке CRON, либо в документации на coingraph.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...