Автор: Надежда Дудник (главный инженер по тестированию в Сбере, ментор по тестированию), https://t.me/protestinginfo
Для начинающих специалистов по тестированию
Введение
Kibana (wiki) используется для мониторинга и анализа ИТ-инфраструктуры в составе Elastic Stack, в который помимо нее входят Elasticsearch и Logstash. Logstash отвечает за логирование и поставляет входящий поток данных в Elasticsearch для хранения, классификации и поиска. Kibana, в свою очередь, получает доступ к данным Elasticsearch для их визуализации в различных визуальных форматах.
У Kibana имеется свой язык запросов KQL (Kibana Query Language) - официальный источник.
С помощью этого языка можно составлять запросы, которые помогают отфильтровывать и найти необходимую информацию.
Выбрать значение в Change index pattern, где необходимо проверить логи. Сперва для разбора я выберу 'logstash', а затем для разбора рассмотрим 'forum', так как логи идут от форума клана по игре Властелин колец онлайн - http://forum.free-peoples.ru/, за который отвечает также Евгений Сычёв (предупреждение: требование наличия сертификата -> довериться).
Основные блоки для работы с логами
Блок для ввода поиска логов с использованием KQL-запроса и без;
Блок с выбором временного промежутка (Today, This week, Last 15 minutes (по умолчанию), Last 30 minutes, Last 1 hour, Last 24 hours, Last 7 days, Last 30 days, Last 90 days, Last 1 year);
Блок с выбранными фильтрами для вывода логов ("Selected fields");
Блок с доступными фильтрами ("Available fields");
Блок результатов поиска логов под выбранные фильтры или без них;
Блок фильтров по типу данных "Filter by type";
Кнопки "Refresh / Update".
Использование KQL
Указать курсор в строку для составления KQL запросов.
Отображаются возможные ключевые атрибуты для поиска логов.
Указать, например, атрибут "message" (Filter results that contain message).
Скриншоты из документации про описание основных параметров.
Разберем примеры, поле "host" имеет тип данных "string", при которых отображаются следующие параметрыдля поля строки:
Поле "geoip.ip" имеет тип данных "number", в котором отображаются следующие параметры для числового поля:
Составление простого KQL-запроса
host: jekil1.fvds.ru and severity :WARN
( : ) - оператор, который отвечает за поиск совпадений.
Результаты совпадений:
Следующийзапрос:host: jekil1.fvds.ru and severity : WARN and message:*auth.log*
*auth.log*, где (*) обозначает подстановочный знак.
*auth.log* - находит любые значения, которые имеют "oauth.log" в любой позиции
exc* - находит любые значения, которые начинаются с "exc".
Можно использовать оператор подстановочного знака после фразы.
*exc - находит любые значения, которые заканчиваются на "exc".
Хочу отметить, что двойные кавычки очень нужны при поиске логов.
KQL c фильтром "Filter by type"
Добавить поле "_type" в фильтр через "Filter by type":
Результаты совпадений отображаются в виде Table или JSON:
1. Ввести "host: jekil1.fvds.ru and severity : WARN and message: exc*" в блоке для запросов;
2. Выбрать "Today" в блоке временного интервала;
3. Выбрать только "_type" в блоке используемых фильтров;
4. Нажать на кнопку "Refresh/Update"
Результаты поиска:
Результаты поиска по фильтру selected fields, выбрав "_type" и "path":
KQL c фильтром "Filter for value"
Дополнительно, поле "host" можно добавить в "Filter for value":
Обратите внимание на скриншоте примера 3 имеется ссылка "Edit as Query DSL" (где DSL - Domain Specific Language), при нажатии на нее открывется окно ввода, которое позволяет вставить JSON запрос в формате Elastic и даёт возможность, например, осуществлять фильтрацию по regexp.
Дать название фильтру как "Severity" и нажать на кнопку "Save". Результат совпадений будет следующим:
Значение "WARN" подсвечивается желтым цветом, так как указано в фильтре по значениям в правом верхнем углу.
Поиск логов без использования KQL
1. Ввести, например, значение поля "source" = "filewatch.tailmode.handlers.create" в блок для запросов;
2. Выбрать "Today" в блоке с временным интервалом ;
3. Нажать на кнопку "Refresh";
4. Удалить выбранные фильтры из "Filter for value" и "Filter by type".
Результаты поиска совпадений:
Практика
Перейти по ссылке форума клана по игре Властелин колец онлайн - https://forum.free-peoples.ru/. (зайти на свой страх и риск -> 'Advanced');
Ввести невалидные "Имя пользователя:" = "test" и "Пароль:" = "test" на странице форума;
Из документации: "Можно объединять разные части запросов по ключевым словам с помощью открывающей скобки " ( " и закрывающей скобки " ) ". Каждой открывающей скобке " ( " должна соответствовать закрывающая скобка " ) ". Пробел до или после скобки не влияет на запрос."
Также можно добавить фильтры из блока со всеми фильтрами в область с используемыми (выбранными) фильтрами.
Обычно я ищу логи в Kibana по уровню логирования ERROR, а также указывая необходимые данные по системе. Дополнительно можно искать логи по sessionId, Id, UUID, сообщениям от ответа сервера, данным запроса.
Данной инструкцией, опираясь на полезные источники, хотела донести знакомство как составлять KQL-запросы, научить читать логи и применить эти знания в своей работе.