Диагностика производительности в Managed Service for MySQL®
В Managed Service for MySQL® встроен инструмент для сбора статистики по сессиям и запросам. Эти метрики могут быть полезны при анализе производительности и оптимизации настроек кластера.
Активировать сбор статистики
При создании кластера или изменении его настроек:
- Включите опцию Сбор статистики (по умолчанию отключена).
- Настройте Интервал сбора сессий и Интервал сбора запросов. Диапазон значений — от
1до86400секунд.
Если у вас еще нет интерфейса командной строки Yandex Cloud (CLI), установите и инициализируйте его.
По умолчанию используется каталог, указанный при создании профиля CLI. Чтобы изменить каталог по умолчанию, используйте команду yc config set folder-id <идентификатор_каталога>. Также для любой команды вы можете указать другой каталог с помощью параметров --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 с планом инфраструктуры.
О том, как создать такой файл, см. в разделе Создание кластера.
-
Чтобы включить и настроить сбор статистики, добавьте блок
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 минут
}
}
-
Получите IAM-токен для аутентификации в API и поместите токен в переменную среды окружения:
export IAM_TOKEN="<IAM-токен>" -
Чтобы включить сбор статистики при создании кластера:
-
Воспользуйтесь методом Cluster.create и добавьте параметр
configSpec.performanceDiagnosticsв команду cURL по созданию кластера:curl \ --request POST \ --header "Authorization: Bearer $IAM_TOKEN" \ --header "Content-Type: application/json" \ --url 'https://mdb.api.yandexcloud.kz/managed-mysql/v1/clusters' \ --data '{ "configSpec": { "performanceDiagnostics": { "enabled": <активировать_сбор_статистики>, "sessionsSamplingInterval": "<интервал_сбора_сессий>", "statementsSamplingInterval": "<интервала_сбора_запросов>" }, ... }, ... }'Где
configSpec.performanceDiagnostics— настройки сбора статистики:enabled— активация сбора статистики:trueилиfalse;sessionsSamplingInterval— интервал сбора сессий: от1до86400секунд;statementsSamplingInterval— интервал сбора запросов: от60до86400секунд.
-
Убедитесь, что запрос был выполнен успешно, изучив ответ сервера.
-
-
Чтобы включить сбор статистики при изменении существующего кластера:
-
Воспользуйтесь методом Cluster.update и выполните запрос, например, с помощью cURL
:Важно
Метод API переопределит все параметры изменяемого объекта, которые не были явно переданы в запросе, на значения по умолчанию. Чтобы избежать этого, перечислите настройки, которые вы хотите изменить, в параметре
updateMask(одной строкой через запятую).curl \ --request PATCH \ --header "Authorization: Bearer $IAM_TOKEN" \ --header "Content-Type: application/json" \ --url 'https://mdb.api.yandexcloud.kz/managed-mysql/v1/clusters/<идентификатор_кластера>' \ --data '{ "updateMask": "configSpec.performanceDiagnostics", "configSpec": { "performanceDiagnostics": { "enabled": <активировать_сбор_статистики>, "sessionsSamplingInterval": "<интервал_сбора_сессий>", "statementsSamplingInterval": "<интервала_сбора_запросов>" } } }'Где
configSpec.performanceDiagnostics— настройки сбора статистики:enabled— активация сбора статистики:trueилиfalse;sessionsSamplingInterval— интервал сбора сессий: от1до86400секунд;statementsSamplingInterval— интервал сбора запросов: от60до86400секунд.
-
Убедитесь, что запрос был выполнен успешно, изучив ответ сервера.
-
-
Получите IAM-токен для аутентификации в API и поместите токен в переменную среды окружения:
export IAM_TOKEN="<IAM-токен>" -
Клонируйте репозиторий cloudapi
:cd ~/ && git clone --depth=1 https://github.com/yandex-cloud/cloudapiДалее предполагается, что содержимое репозитория находится в директории
~/cloudapi/. -
Чтобы включить сбор статистики при создании кластера:
-
Воспользуйтесь методом ClusterService/Create и добавьте параметр
config_spec.performance_diagnosticsв команду gRPCurl по созданию кластера:grpcurl \ -format json \ -import-path ~/cloudapi/ \ -import-path ~/cloudapi/third_party/googleapis/ \ -proto ~/cloudapi/yandex/cloud/mdb/mysql/v1/cluster_service.proto \ -rpc-header "Authorization: Bearer $IAM_TOKEN" \ -d '{ "config_spec": { "performance_diagnostics": { "enabled": <активировать_сбор_статистики>, "sessions_sampling_interval": "<интервал_сбора_сессий>", "statements_sampling_interval": "<интервала_сбора_запросов>" }, ... }, ... }' \ mdb.api.yandexcloud.kz:443 \ yandex.cloud.mdb.mysql.v1.ClusterService.CreateГде
config_spec.performance_diagnostics— настройки сбора статистики:enabled— активация сбора статистики:trueилиfalse;sessions_sampling_interval— интервал сбора сессий: от1до86400секунд;statements_sampling_interval— интервал сбора запросов: от60до86400секунд.
-
Убедитесь, что запрос был выполнен успешно, изучив ответ сервера.
-
-
Чтобы включить сбор статистики при изменении существующего кластера:
-
Воспользуйтесь вызовом ClusterService/Update и выполните запрос, например, с помощью gRPCurl
:Важно
Метод API переопределит все параметры изменяемого объекта, которые не были явно переданы в запросе, на значения по умолчанию. Чтобы избежать этого, перечислите настройки, которые вы хотите изменить, в параметре
update_mask(в виде массива строкpaths[]).Формат перечисления настроек
"update_mask": { "paths": [ "<настройка_1>", "<настройка_2>", ... "<настройка_N>" ] }grpcurl \ -format json \ -import-path ~/cloudapi/ \ -import-path ~/cloudapi/third_party/googleapis/ \ -proto ~/cloudapi/yandex/cloud/mdb/mysql/v1/cluster_service.proto \ -rpc-header "Authorization: Bearer $IAM_TOKEN" \ -d '{ "cluster_id": "<идентификатор_кластера>", "update_mask": { "paths": [ "config_spec.performance_diagnostics" ] }, "config_spec": { "performance_diagnostics": { "enabled": <активировать_сбор_статистики>, "sessions_sampling_interval": "<интервал_сбора_сессий>", "statements_sampling_interval": "<интервала_сбора_запросов>" } } }' \ mdb.api.yandexcloud.kz:443 \ yandex.cloud.mdb.mysql.v1.ClusterService.UpdateГде
config_spec.performance_diagnostics— настройки сбора статистики:enabled— активация сбора статистики:trueилиfalse;sessions_sampling_interval— интервал сбора сессий: от1до86400секунд;statements_sampling_interval— интервал сбора запросов: от60до86400секунд.
-
Убедитесь, что запрос был выполнен успешно, изучив ответ сервера.
-
Получить статистику по сессиям
-
Перейдите в сервис Managed Service for MySQL.
-
Нажмите на имя нужного кластера и выберите вкладку Диагностика производительности → Сессии.
Для просмотра статистики по сессиям или истории запросов в рамках сессии выберите соответствующую вкладку.
СтатистикаИсторияДля просмотра статистики по сессиям:
- Задайте интересующий временной интервал.
- (Опционально) Настройте фильтры.
- Выберите нужный срез данных
.
Чтобы показать или скрыть отдельные категории, нажмите на имя категории в легенде графика.
Для просмотра истории запросов в рамках сессии:
- Задайте интересующий временной интервал.
- (Опционально) Настройте фильтры.
Получить статистику по запросам
-
Перейдите в сервис Managed Service for MySQL.
-
Нажмите на имя нужного кластера и выберите вкладку Диагностика производительности → Запросы.
Для просмотра статистики по запросам или сравнения их статистических данных на двух временных интервалах выберите соответствующую вкладку.
Интервал2 интервалаДля просмотра статистики запросов:
- Выберите интересующий временной интервал.
- (Опционально) Настройте фильтры.
Чтобы получить сведения об относительном изменении статистических характеристик запросов:
- В поле Интервал 1 выберите временной интервал, статистика за который будет основой для расчетов.
- В поле Интервал 2 выберите временной интервал, статистика за который будет сравниваться со статистикой первого интервала.
- (Опционально) Настройте фильтры.
Например, пусть в первом интервале было выполнено 10 запросов
SELECT * FROM cities, а во втором — 20. Тогда при сравнении статистических данных разница по метрикеколичество запросов
(столбецCallsв таблице) будет равняться+100%.
Доступные метрики
В этом разделе перечислены метрики, по которым собирается статистика запросов, и соответствующие им метрики сервиса Managed Service for MySQL® в Monitoring.
| Метрика статистики | Метрика Monitoring | Описание |
|---|---|---|
| Total query latency | - | Время выполнения запроса, суммарно. |
| Total lock latency | - | Время ожидания блокировок, суммарно. |
| Avg query latency | mysql_latency_query_avgDGAUGE, миллисекунды |
Среднее время выполнения запроса. |
| Avg lock latency | - | Среднее время ожидания блокировок. |
| Rows examined | - | Количество прочитанных строк. |
| Calls | - | Количество обращений к базе данных. |
| Rows sent | - | Количество возвращенных строк в ответе. |
| Rows affected | - | Количество измененных, удаленных, добавленных или возвращенных в ответе строк. |
| Tmp tables | mysql_Created_tmp_tables_rateDGAUGE, таблиц/с |
Количество временных таблиц, созданных при обработке запроса. |
| Tmp disk tables | mysql_Created_tmp_disk_tables_rateDGAUGE, таблиц/с |
Количество временных таблиц, созданных на диске при обработке запроса. |
| Select full join | mysql_Select_full_join_rateDGAUGE, запросы/с |
Количество джоинов, которые используют скан таблицы вместо индекса. |
| Select full range join | mysql_Select_full_range_join_rateDGAUGE, запросы/с |
Количество джоинов, которые используют поиск по интервалу в референсной таблице. |
| Select range | - | Количество выборок по интервалам. |
| Select scan | - | Количество выборок с использованием скана таблицы. |
| Sort merge passes | - | Количество сортировок по слияниям таблиц. |
| Sort range | mysql_Sort_range_rateDGAUGE, запросы/с |
Количество сортировок по интервалам в единицу времени. |
| Sort rows | mysql_Sort_rows_rateDGAUGE, запросы/с |
Количество отсортированных строк в единицу времени. |
| Sort scan | mysql_Sort_scan_rateDGAUGE, запросы/с |
Количество сортировок с использованием скана таблицы в единицу времени. |
| No index used | - | 1, если при сканировании таблицы не использовался индекс, 0 в ином случае. |
| No good index used | - | 1, если для выполнения запроса не найден подходящий индекс, 0 в ином случае. |
| Errors | - | Количество ошибок при выполнении запроса. |
| Warnings | - | Количество предупреждений при выполнении запроса. |
Подробнее про отображаемые сведения см. в документации MySQL®