{"id":14284,"url":"\/distributions\/14284\/click?bit=1&hash=82a231c769d1e10ea56c30ae286f090fbb4a445600cfa9e05037db7a74b1dda9","title":"\u041f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u0444\u0438\u043d\u0430\u043d\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u043d\u0430 \u0442\u0430\u043d\u0446\u044b \u0441 \u0441\u043e\u0431\u0430\u043a\u0430\u043c\u0438","buttonText":"","imageUuid":""}

Я задолбался пропускать падения моих сервисов и написал HealthCheck-бота

Пишешь боту имя своего домена и бот проверяет его раз в минуту.

К идее создания бота я пришёл при запуске другого продукта для проверки резюме на английском -

В день запуска всё пошло не так😎

Ошибка #1

Большинство сервисов работали на одном сервере, а это

Запускал я довольно требовательный сервис к ресурсам - используется OCR (распознавание символов на pdf файле), алгоритм категоризации, нейронная сеть для определения насколько резюме соответствует профессии найденной по ключевым словам. В общем жирный сервис, который ест много ресурсов процессора и при превышении лимитов - он зависает намертво вместе с сервером.

Не кладите яйца в одну корзину

Ошибка #2

После запуска я не особо следил за сервисом, занимался своими делами.

В итоге проблему с виртуальной машиной, где крутятся все мои сервисы я заметил только по комментариям от пользователей на ProductHunt.

А завис не только сервис, а вообще всё!

Приходилось перезагружать сервер и поднимать все сервисы, чтобы они ожили. Спасибо боту @IsBotDownBot - я понимал когда падали мои боты😂

Кот из дома - мыши в пляс!

Ошибка #3

В сервисе не было ограничений на количество загрузок резюме - в итоге кто-то отчаянно пытался получить высокий балл от https://checkcv.info/ и загружал резюме около сотни раз, это нагружало сервер и тоже приводило к падению сервера.

Берегись козла спереди, лошади сзади, а лихого человека со всех сторон.

Решение

После 5 падений сервиса (довольно позорно, но что поделать) я начал искать быстрое решение для мониторинга, желательно бесплатное.

Небольшой ресерч не дал простого и быстрого решения, чтобы проверять свои сервисы по доменному имени, поэтому я написал своё решение - https://t.me/YourDomainHealthCheckBot

Просто отправляешь боту свой домен - например checkcv.info - бот сам определяет доступен ли сервис по HTTPS или HTTP и начинает его пинговать раз в минуту.

В случае ошибки или недоступности сайта - бот отправит сообщение об ошибке.

Как только сервис вернется к жизни - бот сообщит и об этом.

Вот в общем-то и все, так же можно редактировать свой список сайтов.

Ещё можно пингануть сайт один раз.

Кто-то подсказал, что этим ботом можно поднимать свои Heroku-сервисы к жизни.

С тех пор как запустил бота сервис пока не падал, но если упадёт узнаю об этом в течение минуты (если не упадёт сервер с ботом😏).

Буду рад услышать фидбек или предложения по улучшению -

0
190 комментариев
Написать комментарий...
Alex Chernyshev

Автор, тема мониторинга работоспособности обширна и огромна, то что вы сделали это метрика из серии 'средней температуры по больнице'.

Если делать по-серьезному - нужно учитывать редиректы, зеркала, анти-DDOS системы вроде Cloudflare, нужно делать проверки из разных ЦОДв на разных континентах: из одной точки сайт может работать а из другой - нет.

Нужно сам контент проверяемой страницы уметь обрабатывать на предмет ошибок, тк очень во многих случаях ваша пинговалка будет получать 200 ОК а сам сайт работать не будет.

Ответить
Развернуть ветку
Alex Fedorov
Автор

вы всё это ожидаете в бесплатном боте в телеге?)

Ответить
Развернуть ветку
Alex Chernyshev

Это тоже ошибка - выдвигать 'бесплатность' в качестве фичи еще и с подходом 'жри что дают - бесплатно же'.
Люди, которые являются вашей ЦА вообщем-то не тупые и технически образованные, вполне понимают и суть сервиса и его нужность и могут и готовы за него заплатить.
Сделайте хорошо, берите за сервис деньги и отвечайте за качество - и все у вас будет хорошо.

Ответить
Развернуть ветку
Alex Fedorov
Автор

проверка ddos и из разных цодов точно требует несопоставимых с текущими затратами на поддержку бота, вы же сами говорите, что в платной версии это ожидаете. Все что вы описали можно сделать и возможно будет добавлено как раз как платные опции

Ответить
Развернуть ветку
187 комментариев
Раскрывать всегда