Просмотр логов кластера Sharded PostgreSQL
Managed Service for Sharded PostgreSQL позволяет получить фрагмент логов кластера за выбранный период и просматривать логи в реальном времени.
Примечание
Логи кластера хранятся 30 дней.
Получить лог кластера
- Перейдите в сервис Yandex Managed Service for Sharded PostgreSQL.
- Нажмите на имя нужного кластера и выберите вкладку
Логи. - Укажите период времени, за который нужно отобразить логи: введите его вручную или выберите в календаре, нажав на поле ввода дат.
- (Опционально) В строке с полем ввода дат добавьте фильтры логов:
- Выберите тип сервиса —
INFRA,ROUTERилиCOORDINATOR. - Укажите хосты.
- Выберите уровень логирования.
- Выберите тип сервиса —
Будет отображен список записей в логе за выбранный период времени. Чтобы посмотреть подробную информацию о событии, нажмите на интересующую запись в списке.
Если записей слишком много и отображается только часть из них, нажмите на кнопку Загрузить еще в конце списка.
Если у вас еще нет интерфейса командной строки Yandex Cloud (CLI), установите и инициализируйте его.
По умолчанию используется каталог, указанный при создании профиля CLI. Чтобы изменить каталог по умолчанию, используйте команду yc config set folder-id <идентификатор_каталога>. Также для любой команды вы можете указать другой каталог с помощью параметров --folder-name или --folder-id.
-
Просмотрите описание команды CLI для просмотра логов кластера:
yc managed-sharded-postgresql cluster list-logs --help -
Запустите команду получения логов кластера (в примере приведены не все доступные параметры):
yc managed-sharded-postgresql cluster list-logs <имя_или_идентификатор_кластера> \ --limit <ограничение_количества_записей> \ --service-type <тип_сервиса> \ --columns <список_колонок_для_вывода_информации> \ --filter <настройки_фильтрации_записей> \ --since <левая_граница_временного_диапазона> \ --until <правая_граница_временного_диапазона>Где:
-
--limit— ограничение на количество выводимых записей. -
--service-type— тип сервиса, логи которого нужно получить (infra,routerилиcoordinator). -
--columns— список колонок для вывода информации:hostname— имя хоста.severity— уровень логирования, напримерinfo.message— сообщение, которое выводит компонент.contextual_data— дополнительная информация.
-
--filter— настройки фильтрации записей, напримерmessage.hostname='node1.mdb.yandexcloud.kz'. -
--since— левая граница временного диапазона в формате RFC-3339 ,HH:MM:SSили временного промежутка относительно текущего времени. Примеры:2006-01-02T15:04:05Z,15:04:05,2h,3h30m ago. -
--until— правая граница временного диапазона, формат аналогичен--since.
-
-
Получите IAM-токен для аутентификации в API и поместите токен в переменную среды окружения:
export IAM_TOKEN="<IAM-токен>" -
Воспользуйтесь методом Cluster.ListLogs и выполните запрос, например с помощью cURL
:curl \ --request GET \ --header "Authorization: Bearer $IAM_TOKEN" \ --url 'https://mdb.api.yandexcloud.kz/managed-spqr/v1/clusters/<идентификатор_кластера>:logs' \ --url-query serviceType=<тип_сервиса> \ --url-query columnFilter=<колонка_1> \ --url-query columnFilter=<колонка_2> \ ... \ --url-query columnFilter=<колонка_N> \ --url-query fromTime=<левая_граница_временного_диапазона> \ --url-query toTime=<правая_граница_временного_диапазона>Где:
-
serviceType— тип сервиса, логи которого нужно получить:INFRA— операции хостовINFRA, объединяющие роли роутера и координатора;ROUTER— операции роутера;COORDINATOR— операции координатора.
-
columnFilter— название колонки для вывода информации:hostname— имя хоста.severity— уровень логирования, напримерinfo.message— сообщение, которое выводит компонент.contextual_data— дополнительная информация.
В одном параметре
columnFilterможно указать только одну колонку. Если необходимо отфильтровать логи по нескольким колонкам, передайте перечень нужных колонок в нескольких параметрах. -
fromTime— левая граница временного диапазона в формате RFC-3339 . Пример:2024-09-18T15:04:05Z. -
toTime— правая граница временного диапазона, формат аналогиченfromTime.
-
-
Убедитесь, что запрос был выполнен успешно, изучив ответ сервера.
-
Получите IAM-токен для аутентификации в API и поместите токен в переменную среды окружения:
export IAM_TOKEN="<IAM-токен>" -
Клонируйте репозиторий cloudapi
:cd ~/ && git clone --depth=1 https://github.com/yandex-cloud/cloudapiДалее предполагается, что содержимое репозитория находится в директории
~/cloudapi/. -
Воспользуйтесь вызовом ClusterService.ListLogs и выполните запрос, например с помощью gRPCurl
:grpcurl \ -format json \ -import-path ~/cloudapi/ \ -import-path ~/cloudapi/third_party/googleapis/ \ -proto ~/cloudapi/yandex/cloud/mdb/spqr/v1/cluster_service.proto \ -rpc-header "Authorization: Bearer $IAM_TOKEN" \ -d '{ "cluster_id": "<идентификатор_кластера>", "service_type": "<тип_сервиса>", "column_filter": [ "<колонка_1>", "<колонка_2>", ..., "<колонка_N>" ], "from_time": "<левая_граница_временного_диапазона>", "to_time": "<правая_граница_временного_диапазона>" }' \ mdb.api.yandexcloud.kz:443 \ yandex.cloud.mdb.spqr.v1.ClusterService.ListLogsГде:
-
service_type— тип сервиса, логи которого нужно получить:INFRA— операции хостовINFRA, объединяющие роли роутера и координатора;ROUTER— операции роутера;COORDINATOR— операции координатора.
-
column_filter— список колонок для вывода информации:hostname— имя хоста.severity— уровень логирования, напримерinfo.message— сообщение, которое выводит компонент.contextual_data— дополнительная информация.
В параметре
column_filterможно указать несколько колонок, если нужно отфильтровать логи по нескольким колонкам. -
from_time— левая граница временного диапазона в формате RFC-3339 . Пример:2024-09-18T15:04:05Z. -
to_time— правая граница временного диапазона, формат аналогиченfrom_time.
-
-
Убедитесь, что запрос был выполнен успешно, изучив ответ сервера.
Получить поток логов кластера
Этот способ позволяет получать логи кластера в реальном времени.
Если у вас еще нет интерфейса командной строки Yandex Cloud (CLI), установите и инициализируйте его.
По умолчанию используется каталог, указанный при создании профиля CLI. Чтобы изменить каталог по умолчанию, используйте команду yc config set folder-id <идентификатор_каталога>. Также для любой команды вы можете указать другой каталог с помощью параметров --folder-name или --folder-id.
Для просмотра логов кластера по мере их поступления выполните команду:
yc managed-sharded-postgresql cluster list-logs <имя_или_идентификатор_кластера> \
--service-type <тип_сервиса> \
--follow
Где --service-type — тип сервиса, логи которого нужно получить (infra, router или coordinator).
-
Получите IAM-токен для аутентификации в API и поместите токен в переменную среды окружения:
export IAM_TOKEN="<IAM-токен>" -
Воспользуйтесь методом Cluster.StreamLogs и выполните запрос, например с помощью cURL
:curl \ --request GET \ --header "Authorization: Bearer $IAM_TOKEN" \ --url 'https://mdb.api.yandexcloud.kz/managed-spqr/v1/clusters/<идентификатор_кластера>:stream_logs' \ --url-query serviceType=<тип_сервиса> \ --url-query columnFilter=<колонка_1> \ --url-query columnFilter=<колонка_2> \ ... \ --url-query columnFilter=<колонка_N> \Где:
-
serviceType— тип сервиса, логи которого нужно получить:INFRA— операции хостовINFRA, объединяющие роли роутера и координатора;ROUTER— операции роутера;COORDINATOR— операции координатора.
-
columnFilter— название колонки для вывода информации:hostname— имя хоста.severity— уровень логирования, напримерinfo.message— сообщение, которое выводит компонент.contextual_data— дополнительная информация.
В одном параметре
columnFilterможно указать только одну колонку. Если необходимо отфильтровать логи по нескольким колонкам, передайте перечень нужных колонок в нескольких параметрах.
-
-
Убедитесь, что запрос был выполнен успешно, изучив ответ сервера.
Команда не завершается после отправки. Новые логи отображаются в выводе команды в режиме реального времени.
-
Получите IAM-токен для аутентификации в API и поместите токен в переменную среды окружения:
export IAM_TOKEN="<IAM-токен>" -
Клонируйте репозиторий cloudapi
:cd ~/ && git clone --depth=1 https://github.com/yandex-cloud/cloudapiДалее предполагается, что содержимое репозитория находится в директории
~/cloudapi/. -
Воспользуйтесь вызовом ClusterService.StreamLogs и выполните запрос, например с помощью gRPCurl
:grpcurl \ -format json \ -import-path ~/cloudapi/ \ -import-path ~/cloudapi/third_party/googleapis/ \ -proto ~/cloudapi/yandex/cloud/mdb/spqr/v1/cluster_service.proto \ -rpc-header "Authorization: Bearer $IAM_TOKEN" \ -d '{ "cluster_id": "<идентификатор_кластера>", "service_type": "<тип_сервиса>", "column_filter": [ "<колонка_1>", "<колонка_2>", ..., "<колонка_N>" ] }' \ mdb.api.yandexcloud.kz:443 \ yandex.cloud.mdb.spqr.v1.ClusterService.StreamLogsГде:
-
service_type— тип сервиса, логи которого нужно получить:INFRA— операции хостовINFRA, объединяющие роли роутера и координатора;ROUTER— операции роутера;COORDINATOR— операции координатора.
-
column_filter— список колонок для вывода информации:hostname— имя хоста.severity— уровень логирования, напримерinfo.message— сообщение, которое выводит компонент.contextual_data— дополнительная информация.
В параметре
column_filterможно указать несколько колонок, если нужно отфильтровать логи по нескольким колонкам.
-
-
Убедитесь, что запрос был выполнен успешно, изучив ответ сервера.
Команда не завершается после отправки. Новые логи отображаются в выводе команды в режиме реального времени.