Добавить настройки масштабирования функции
Вы можете задать:
zone_instances_limit— количество экземпляров функции в зоне доступности;zone_requests_limit— количество одновременно выполняемых вызовов функции в зоне доступности;provisioned_instances_count— количество подготовленных экземпляров;
Время простоя подготовленных экземпляров и выполнения в них функции тарифицируется отдельно.
Для разных версий функции можно задать свои настройки масштабирования, используя теги. Настройки масштабирования будут действовать для той версии функции, которой присвоен указанный тег. Версии функции масштабируются независимо друг от друга.
Настройки масштабирования не могут превышать квоты.
Примечание
Настройки масштабирования применяются в течение 5 минут после их задания.
- В консоли управления
перейдите в каталог, в котором находится функция. - Перейдите в сервис Cloud Functions.
- Выберите функцию.
- В блоке История версий наведите курсор на тег версии функции (например,
$latest), для которой хотите добавить настройки масштабирования. - Во всплывающем окне нажмите кнопку Добавить.
- В открывшемся окне укажите:
- zone_instances_limit — количество экземпляров функции в зоне доступности.
- zone_requests_limit — количество одновременно выполняемых вызовов функции в зоне доступности.
- provisioned_instances_count — количество подготовленных экземпляров.
- Нажмите кнопку Сохранить.
Чтобы задать настройки масштабирования, выполните команду:
yc serverless function set-scaling-policy \
--id=<идентификатор_функции> \
--tag=\$latest \
--zone-instances-limit=1 \
--zone-requests-limit=2 \
--provisioned-instances-count=3
Где:
--id— идентификатор функции. Чтобы узнать его, получите список функций.--tag— тег версии функции.--zone-instances-limit— количество экземпляров функции.--zone-requests-limit— количество выполняемых вызовов.--provisioned-instances-count— количество подготовленных экземпляров.
Результат:
function_id: d4eokpuol55h********
tag: $latest
zone_instances_limit: "1"
zone_requests_limit: "2"
provisioned_instances_count: "3"
Terraform
Terraform распространяется под лицензией Business Source License
Подробную информацию о ресурсах провайдера смотрите в документации на сайте Terraform
Если у вас еще нет Terraform, установите его и настройте провайдер Yandex Cloud.
Чтобы добавить настройки масштабирования:
-
Опишите в конфигурационном файле параметры ресурсов, которые необходимо создать:
yandex_function— описание создаваемой функции и ее исходный код.name— имя функции.user_hash— произвольная строка, определяющая версию функции. При изменениях функции необходимо менять и эту строку. Функция обновится при изменении этой строки.runtime— среда выполнения функции.entrypoint— точка входа, указывается в формате<имя_файла_без_расширения>.<имя_обработчика>.memory— объем памяти в мегабайтах, отведенный для выполнения функции.execution_timeout— максимальное время выполнения функции до таймаута.service_account_id— идентификатор сервисного аккаунта, от имени которого будет запускаться функция.content— исходный код функции.content.0.zip_filename— имя ZIP-архива, содержащего исходный код функции.
yandex_function_scaling_policy— описание настроек масштабирования функции.function_id— идентификатор функции.policy— настройки масштабирования:policy.0.tag— тег версии функции.policy.0.zone_instances_limit— количество экземпляров функции.policy.0.zone_requests_limit— количество выполняемых вызовов.
Пример структуры конфигурационного файла:
provider "yandex" { token = "<OAuth-токен_или_статический_ключ_сервисного_аккаунта>" folder_id = "<идентификатор_каталога>" zone = "ru-central1-a" } resource "yandex_function" "test-function" { name = "<имя_функции>" user_hash = "<хеш>" runtime = "<среда_выполнения>" entrypoint = "<точка_входа>" memory = "128" execution_timeout = "10" service_account_id = "<идентификатор_сервисного_аккаунта>" content { zip_filename = "<путь_к_ZIP-архиву>" } } resource "yandex_function_scaling_policy" "my_scaling_policy" { function_id = "<идентификатор_функции>" policy { tag = "$latest" zone_instances_limit = 2 zone_requests_limit = 1 } }Подробнее о параметрах ресурсов см. yandex_function_scaling_policy.
-
Проверьте конфигурацию командой:
terraform validateЕсли конфигурация является корректной, появится сообщение:
Success! The configuration is valid. -
Выполните команду:
terraform planВ терминале будет выведен список ресурсов с параметрами. На этом этапе изменения не будут внесены. Если в конфигурации есть ошибки, Terraform на них укажет.
-
Примените изменения конфигурации:
terraform apply -
Подтвердите изменения: введите в терминал слово
yesи нажмите Enter.
Проверить добавление настроек масштабирования можно в консоли управления
yc serverless function list-scaling-policies <имя_или_идентификатор_функции>
Чтобы задать настройки масштабирования, воспользуйтесь методом REST API setScalingPolicy для ресурса Function или вызовом gRPC API FunctionService/SetScalingPolicy.