Диагностика производительности в Managed Service for MySQL
В Managed Service for MySQL встроен инструмент для сбора статистики по сессиям и запросам. Эти метрики могут быть полезны при анализе производительности и оптимизации настроек кластера.
Активировать сбор статистики
При создании кластера или изменении его настроек:
- Включите опцию Сбор статистики (по умолчанию отключена).
- Настройте Интервал сбора сессий и Интервал сбора запросов. Диапазон значений — от
1
до86400
секунд.
Если у вас еще нет интерфейса командной строки Yandex Cloud, установите и инициализируйте его.
По умолчанию используется каталог, указанный в профиле CLI. Вы можете указать другой каталог с помощью параметра --folder-name
или --folder-id
.
Чтобы включить и настроить сбор статистики, передайте параметр --performance-diagnostics
в команде изменения кластера:
yc managed-mysql cluster update <имя_или_идентификатор_кластера> \
...
--performance-diagnostics enabled=true,`
`sessions-sampling-interval=<интервал_сбора_сессий>,`
`statements-sampling-interval=<интервал_сбора_запросов> \
...
Допустимые значения параметров sessions-sampling-interval
и statements-sampling-interval
— от 1
до 86400
секунд.
-
Откройте актуальный конфигурационный файл Terraform с планом инфраструктуры.
О том, как создать такой файл, см. в разделе Создание MySQL-кластера.
-
Чтобы включить и настроить сбор статистики, добавьте блок
performance_diagnostics
в конфигурацию кластера:resource "yandex_mdb_mysql_cluster" "<название_кластера>" { ... performance_diagnostics { enabled = true sessions_sampling_interval = <интервал_сбора_сессий> statements_sampling_interval = <интервал_сбора_запросов> } ... }
Допустимые значения параметров
sessions_sampling_interval
иstatements_sampling_interval
— от1
до86400
секунд. -
Проверьте корректность настроек.
-
В командной строке перейдите в каталог, в котором расположены актуальные конфигурационные файлы Terraform с планом инфраструктуры.
-
Выполните команду:
terraform validate
Если в файлах конфигурации есть ошибки, Terraform на них укажет.
-
-
Подтвердите изменение ресурсов.
-
Выполните команду для просмотра планируемых изменений:
terraform plan
Если конфигурации ресурсов описаны верно, в терминале отобразится список изменяемых ресурсов и их параметров. Это проверочный этап: ресурсы не будут изменены.
-
Если вас устраивают планируемые изменения, внесите их:
-
Выполните команду:
terraform apply
-
Подтвердите изменение ресурсов.
-
Дождитесь завершения операции.
-
-
Ограничения по времени
Провайдер Terraform ограничивает время на выполнение операций с кластером Managed Service for MySQL:
- создание кластера, в том числе путем восстановления из резервной копии, — 15 минут;
- изменение кластера, в том числе обновление версии MySQL, — 60 минут;
- удаление кластера — 15 минут.
Операции, длящиеся дольше указанного времени, прерываются.
Добавьте к описанию кластера блок timeouts
, например:
resource "yandex_mdb_mysql_cluster" "<имя_кластера>" {
...
timeouts {
create = "1h30m" # Полтора часа
update = "2h" # 2 часа
delete = "30m" # 30 минут
}
}
Чтобы включить сбор статистики, воспользуйтесь методом REST API create или update для ресурса Cluster или вызовом gRPC API ClusterService/Create или ClusterService/Update и передайте в запросе:
- Идентификатор кластера в параметре
clusterId
. Идентификатор можно получить со списком кластеров в каталоге. - Значение
true
в параметреconfigSpec.performanceDiagnostics.enabled
. - Интервал сбора сессий в параметре
configSpec.performanceDiagnostics.sessionsSamplingInterval
. Допустимые значения — от1
до86400
секунд. - Интервал сбора запросов в параметре
configSpec.performanceDiagnostics.statementsSamplingInterval
. Допустимые значения — от1
до86400
секунд. - Список полей, подлежащих изменению, в параметре
updateMask
.
Важно
Этот метод API сбросит все настройки кластера, которые не были явно переданы в запросе, на значения по умолчанию. Чтобы избежать этого, обязательно передайте название полей, подлежащих изменению, в параметре updateMask
.
Получить статистику по сессиям
-
В консоли управления
перейдите на страницу каталога и выберите сервис Managed Service for MySQL. -
Нажмите на имя нужного кластера и выберите вкладку Диагностика производительности → Сессии.
Для просмотра статистики по сессиям или истории запросов в рамках сессии выберите соответствующую вкладку.
СтатистикаИсторияДля просмотра статистики по сессиям:
- Задайте интересующий временной интервал.
- (Опционально) Настройте фильтры.
- Выберите нужный срез данных
.
Чтобы показать или скрыть отдельные категории, нажмите на имя категории в легенде графика.
Для просмотра истории запросов в рамках сессии:
- Задайте интересующий временной интервал.
- (Опционально) Настройте фильтры.
Получить статистику по запросам
-
В консоли управления
перейдите на страницу каталога и выберите сервис Managed Service for MySQL. -
Нажмите на имя нужного кластера и выберите вкладку Диагностика производительности → Запросы.
Для просмотра статистики по запросам или сравнения их статистических данных на двух временных интервалах выберите соответствующую вкладку.
Интервал2 интервалаДля просмотра статистики запросов:
- Выберите интересующий временной интервал.
- (Опционально) Настройте фильтры.
Чтобы получить сведения об относительном изменении статистических характеристик запросов:
- В поле Интервал 1 выберите временной интервал, статистика за который будет основой для расчетов.
- В поле Интервал 2 выберите временной интервал, статистика за который будет сравниваться со статистикой первого интервала.
- (Опционально) Настройте фильтры.
Например, пусть в первом интервале было выполнено 10 запросов
SELECT * FROM cities
, а во втором — 20. Тогда при сравнении статистических данных разница по метрикеколичество запросов
(столбецCalls
в таблице) будет равняться+100%
.
Подробнее про отображаемые сведения см. в документации MySQL