bin | ||
cmd | ||
docs | ||
internal | ||
vendor | ||
.env_empty | ||
.gitignore | ||
go.mod | ||
go.sum | ||
Makefile | ||
README.md | ||
readme.rus |
Applications for sending logs with errors from the LOKI(GRAFANA) logger to the Telegram messenger
The LOKI logger has an inconvenient interface for searching errors in application logs, and no one will look there every 5 minutes - Therefore, it is necessary to automate the process of searching for errors in logs and notifying developers.
The application does:
- Log in to grafana
- Takes a list of services from the services.txt file
- For each service, searches for LOKI logs with the text: error:,panic:,ERROR:,PANIC:
- Found logs with errors are sent to the Telegram messenger
- Repeats the search every 10 minutes
Installation procedure:
-
Compile this repository make build the telegram_loki file will appear in the bin folder
-
make a .env file with filled parameters: TELEGRAM_APP_ID= TELEGRAM_APP_HASH= TELEGRAM_PHONE_FROM= TELEGRAM_PHONE_SEND_TEST= LOKI_URL= LOKI_SEARCH_TEXT="\\[ERROR\\]|\\[PANIC\\]|level=error|level=panic"
GRAFANA_LOGIN= GRAFANA_PASSWORD= TELEGRAM_CHAT_NAME= TELEGRAM_MESSAGES_COUNT=
-
Fill in the settings/services.txt file In json format write the service name in LOKI and the name (login) of the programmer (optional) sample: { "test-service1": "@DeveloperTelegramName" }
-
Run the telegram_loki file
Source code in Golang language. Tested on Linux Ubuntu Readme from 10/13/2023
License: Save information about the author and the site.
Made by Alexander Nikitin https://github.com/ManyakRus/telegram_loki