@Getmanele
Junior frontend developer

Телеграмм бот зависает (hiroku hosting)?

Есть бот ( тестовый - учебный)
Бот на js
Сам бот залит на heroku.com
Запускается-работает и зависает
Вот лог:
2020-05-28T08:43:50.357758+00:00 app[web.1]: 
2020-05-28T08:43:50.357767+00:00 app[web.1]: > covid19@1.0.0 start /app
2020-05-28T08:43:50.357767+00:00 app[web.1]: > node bot.js
2020-05-28T08:43:50.357768+00:00 app[web.1]: 
2020-05-28T08:43:50.855446+00:00 app[web.1]: Бот запущен
2020-05-28T08:43:51.418671+00:00 heroku[web.1]: State changed from starting to up
2020-05-28T09:15:25.299481+00:00 heroku[web.1]: Idling
2020-05-28T09:15:25.302593+00:00 heroku[web.1]: State changed from up to down
2020-05-28T09:15:26.699556+00:00 heroku[web.1]: Stopping all processes with SIGTERM
2020-05-28T09:15:26.895990+00:00 heroku[web.1]: Process exited with status 143
2020-05-28T09:18:17.833275+00:00 heroku[web.1]: State changed from down to starting
2020-05-28T09:18:21.545626+00:00 heroku[web.1]: Starting process with command `npm start`
2020-05-28T09:18:23.710890+00:00 app[web.1]: 
2020-05-28T09:18:23.710905+00:00 app[web.1]: > covid19@1.0.0 start /app
2020-05-28T09:18:23.710905+00:00 app[web.1]: > node bot.js
2020-05-28T09:18:23.710905+00:00 app[web.1]: 
2020-05-28T09:18:24.501667+00:00 heroku[web.1]: State changed from starting to up
2020-05-28T09:18:24.335618+00:00 app[web.1]: Бот запущен

Вот сам код бота:
require('dotenv').config();
const { Telegraf } = require('telegraf');
const api = require('covid19-api');
const markup = require('telegraf/markup');
const COUNTRIES_LIST = require(`./constants`);
const bot = new Telegraf(process.env.BOT_TOKEN);

require('https')
  .createServer()
  .listen(process.env.PORT || 5000)
  .on('request', function (req, res) {
    res.end('');
  });

bot.start((ctx) =>
  ctx.reply(
    `
Привет ${ctx.message.from.first_name}!
Узнай статистику по Коронавирусу.
Введи на англ. название страны и получи статистику.
Посмотреть название всех стран: /help.
`,
    markup
      .keyboard([
        [`Ukraine`, `Russia`],
        [`US`, `Italy`],
        [`Canada`, `Portugal`],
      ])
      .resize()
      .extra()
  )
);
bot.help((ctx) => ctx.reply(COUNTRIES_LIST));

// bot.start((ctx) => console.log(ctx));

bot.on('text', async (ctx) => {
  let data = {};

  try {
    data = await api.getReportsByCountries(ctx.message.text);

    const formatData = `
Страна : ${data[0][0].country}
Заболевшие : ${data[0][0].cases}
Смертей : ${data[0][0].deaths}
Вылечились : ${data[0][0].recovered}
  `;
    ctx.reply(formatData);
  } catch {
    ctx.reply(`ошибка: такой страны нет. Смотри /help`);
  }
});

bot.launch();
console.log(`Бот запущен`);


еще во вкладке Resources не появился worker
5ecf84b645716359944212.png
хотя файл procfile создан и в нем есть строка worker: npm start
5ecf850a1b84b516292338.png
Вот лог остановки бота
5ecf8576c36ba978653561.png
Прошу помощи - как добавить worker и почему бот крашится ?
Спасибо!
  • Вопрос задан
  • 1264 просмотра
Пригласить эксперта
Ответы на вопрос 1
MZOK
@MZOK
а
Если вы используете бесплатный тариф, тогда если на приложение нет запросов 30 минут то он сам выключается. Для того чтобы он не засыпал используйте - wakemydyno.com.

Чтобы добавить worker введите команду - heroku ps:scale worker=1
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы