2023-10-13 15:40:52 +02:00
|
|
|
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:
|
2024-11-01 14:46:58 +02:00
|
|
|
Search for errors in the LOKI logger
|
2023-10-13 15:40:52 +02:00
|
|
|
1. Log in to grafana
|
2024-11-07 13:06:19 +02:00
|
|
|
2. Takes a list of services from the services.txt file,
|
|
|
|
including the name of the service and the name of the person responsible
|
2024-11-01 14:46:58 +02:00
|
|
|
3. For each service, searches for LOKI logs with the text: error:, panic:, ERROR:, PANIC:
|
|
|
|
4. Sends the found logs with errors to the Telegram messenger
|
2023-10-13 15:40:52 +02:00
|
|
|
5. Repeats the search every 10 minutes
|
|
|
|
|
2024-11-01 14:46:58 +02:00
|
|
|
Search for errors in the database:
|
|
|
|
1. Log in to the PostgreSQL database
|
|
|
|
2. Finds .sql files in the sql folder, and executes a script in the database,
|
|
|
|
if the script returns a value, a message about this will come to the Telegram messenger,
|
|
|
|
if the script does not return lines, then everything is fine.
|
|
|
|
3. Repeats requests every 60 minutes
|
2024-11-07 13:06:19 +02:00
|
|
|
4. If you fill in the scripts.txt file (scripts_add.txt),
|
|
|
|
including the .sql file name and the name of the person responsible,
|
|
|
|
then the name of the person responsible will also be added.
|
2023-10-13 15:40:52 +02:00
|
|
|
|
|
|
|
Installation procedure:
|
|
|
|
1. Compile this repository
|
2024-11-01 14:46:58 +02:00
|
|
|
>make build
|
2023-10-13 15:40:52 +02:00
|
|
|
the telegram_loki file will appear in the bin folder
|
|
|
|
|
2024-11-01 14:02:44 +02:00
|
|
|
2. fill parametes in settings.txt file (or .env file)
|
|
|
|
with Grafana LOKI URL, login, password, etc.
|
2023-10-13 15:40:52 +02:00
|
|
|
|
|
|
|
3. 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"
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
3. 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
|