Application Load Balancer API, gRPC: LoadBalancerService.Create
- gRPC request
- CreateLoadBalancerRequest
- ListenerSpec
- EndpointSpec
- AddressSpec
- ExternalIpv4AddressSpec
- InternalIpv4AddressSpec
- ExternalIpv6AddressSpec
- HttpListener
- HttpHandler
- Http2Options
- Redirects
- TlsListener
- TlsHandler
- StreamHandler
- SniMatch
- StreamListener
- AllocationPolicy
- Location
- AutoScalePolicy
- LogOptions
- LogDiscardRule
- operation.Operation
- CreateLoadBalancerMetadata
- LoadBalancer
- Listener
- Endpoint
- Address
- ExternalIpv4Address
- InternalIpv4Address
- ExternalIpv6Address
- HttpListener
- HttpHandler
- Http2Options
- Redirects
- TlsListener
- TlsHandler
- StreamHandler
- SniMatch
- StreamListener
- AllocationPolicy
- Location
- AutoScalePolicy
- LogOptions
- LogDiscardRule
Creates an application load balancer in the specified folder.
gRPC request
rpc Create (CreateLoadBalancerRequest) returns (operation.Operation)
CreateLoadBalancerRequest
{
"folder_id": "string",
"name": "string",
"description": "string",
"labels": "map<string, string>",
"region_id": "string",
"network_id": "string",
"listener_specs": [
{
"name": "string",
"endpoint_specs": [
{
"address_specs": [
{
// Includes only one of the fields `external_ipv4_address_spec`, `internal_ipv4_address_spec`, `external_ipv6_address_spec`
"external_ipv4_address_spec": {
"address": "string"
},
"internal_ipv4_address_spec": {
"address": "string",
"subnet_id": "string"
},
"external_ipv6_address_spec": {
"address": "string"
}
// end of the list of possible fields
}
],
"ports": [
"int64"
]
}
],
// Includes only one of the fields `http`, `tls`, `stream`
"http": {
"handler": {
"http_router_id": "string",
// Includes only one of the fields `http2_options`, `allow_http10`
"http2_options": {
"max_concurrent_streams": "int64"
},
"allow_http10": "bool",
// end of the list of possible fields
"rewrite_request_id": "bool"
},
"redirects": {
"http_to_https": "bool"
}
},
"tls": {
"default_handler": {
// Includes only one of the fields `http_handler`, `stream_handler`
"http_handler": {
"http_router_id": "string",
// Includes only one of the fields `http2_options`, `allow_http10`
"http2_options": {
"max_concurrent_streams": "int64"
},
"allow_http10": "bool",
// end of the list of possible fields
"rewrite_request_id": "bool"
},
"stream_handler": {
"backend_group_id": "string",
"idle_timeout": "google.protobuf.Duration"
},
// end of the list of possible fields
"certificate_ids": [
"string"
]
},
"sni_handlers": [
{
"name": "string",
"server_names": [
"string"
],
"handler": {
// Includes only one of the fields `http_handler`, `stream_handler`
"http_handler": {
"http_router_id": "string",
// Includes only one of the fields `http2_options`, `allow_http10`
"http2_options": {
"max_concurrent_streams": "int64"
},
"allow_http10": "bool",
// end of the list of possible fields
"rewrite_request_id": "bool"
},
"stream_handler": {
"backend_group_id": "string",
"idle_timeout": "google.protobuf.Duration"
},
// end of the list of possible fields
"certificate_ids": [
"string"
]
}
}
]
},
"stream": {
"handler": {
"backend_group_id": "string",
"idle_timeout": "google.protobuf.Duration"
}
}
// end of the list of possible fields
}
],
"allocation_policy": {
"locations": [
{
"zone_id": "string",
"subnet_id": "string",
"disable_traffic": "bool"
}
]
},
"security_group_ids": [
"string"
],
"auto_scale_policy": {
"min_zone_size": "int64",
"max_size": "int64"
},
"log_options": {
"log_group_id": "string",
"discard_rules": [
{
"http_codes": [
"int64"
],
"http_code_intervals": [
"HttpCodeInterval"
],
"grpc_codes": [
"google.rpc.Code"
],
"discard_percent": "google.protobuf.Int64Value"
}
],
"disable": "bool"
}
}
Field |
Description |
folder_id |
string Required field. ID of the folder to create an application load balancer in. To get the folder ID, make a yandex.cloud.resourcemanager.v1.FolderService.List request. |
name |
string Name of the application load balancer. |
description |
string Description of the application load balancer. |
labels |
object (map<string, string>) Application load balancer labels as |
region_id |
string Required field. ID of the region that the application load balancer is located at. The only supported value is |
network_id |
string Required field. ID of the network that the application load balancer belongs to. |
listener_specs[] |
Listeners that belong to the application load balancer. For details about the concept, |
allocation_policy |
Locality settings of the application load balancer. For details about the concept, |
security_group_ids[] |
string ID's of the security groups attributed to the application load balancer. For details about the concept, |
auto_scale_policy |
Scaling settings of the application load balancer. The scaling settings relate to a special internal instance group which facilitates the balancer's work. For details about the concept, |
log_options |
Cloud logging settings of the application load balancer. |
ListenerSpec
Field |
Description |
name |
string Required field. Name of the listener. The name is unique within the application load balancer. |
endpoint_specs[] |
Endpoints of the listener. Endpoints are defined by their IP addresses and ports. |
http |
Unencrypted HTTP listener settings. Includes only one of the fields Listener type and settings. |
tls |
TLS-encrypted HTTP or TCP stream listener settings. All handlers within a listener (TlsListener.default_handler and TlsListener.sni_handlers) must be of one Includes only one of the fields Listener type and settings. |
stream |
Unencrypted stream (TCP) listener settings. Includes only one of the fields Listener type and settings. |
EndpointSpec
Field |
Description |
address_specs[] |
Endpoint public (external) and internal addresses. |
ports[] |
int64 Endpoint ports. |
AddressSpec
Field |
Description |
external_ipv4_address_spec |
Public IPv4 endpoint address. Includes only one of the fields Endpoint address of one of the types: public (external) IPv4 address, internal IPv4 address, public IPv6 address. |
internal_ipv4_address_spec |
Internal IPv4 endpoint address. To enable the use of listeners with internal addresses, contact support. Includes only one of the fields Endpoint address of one of the types: public (external) IPv4 address, internal IPv4 address, public IPv6 address. |
external_ipv6_address_spec |
Public IPv6 endpoint address. Includes only one of the fields Endpoint address of one of the types: public (external) IPv4 address, internal IPv4 address, public IPv6 address. |
ExternalIpv4AddressSpec
Field |
Description |
address |
string IPv4 address. |
InternalIpv4AddressSpec
Field |
Description |
address |
string IPv4 address. |
subnet_id |
string ID of the subnet that the address belongs to. |
ExternalIpv6AddressSpec
Field |
Description |
address |
string IPv6 address. |
HttpListener
An HTTP listener resource.
Field |
Description |
handler |
Settings for handling HTTP requests. Only one of |
redirects |
Redirects settings. Only one of |
HttpHandler
An HTTP handler resource.
Field |
Description |
http_router_id |
string ID of the HTTP router processing requests. For details about the concept, see To get the list of all available HTTP routers, make a HttpRouterService.List request. |
http2_options |
HTTP/2 settings. If specified, incoming HTTP/2 requests are supported by the listener. Includes only one of the fields Protocol settings. For HTTPS (HTTP over TLS) connections, settings are applied to the protocol |
allow_http10 |
bool Enables support for incoming HTTP/1.0 and HTTP/1.1 requests and disables it for HTTP/2 requests. Includes only one of the fields Protocol settings. For HTTPS (HTTP over TLS) connections, settings are applied to the protocol |
rewrite_request_id |
bool When unset, will preserve the incoming x-request-id header, otherwise would rewrite it with a new value. |
Http2Options
An HTTP/2 options resource.
Field |
Description |
max_concurrent_streams |
int64 Maximum number of concurrent HTTP/2 streams in a connection. |
Redirects
A listener redirects resource.
Field |
Description |
http_to_https |
bool Redirects all unencrypted HTTP requests to the same URI with scheme changed to The setting has the same effect as a single, catch-all HttpRoute |
TlsListener
TLS-encrypted (HTTP or TCP stream) listener resource.
Field |
Description |
default_handler |
Required field. Settings for handling requests by default, with Server Name |
sni_handlers[] |
Settings for handling requests with Server Name Indication (SNI) |
TlsHandler
A TLS-encrypted (HTTP or TCP stream) handler resource.
Field |
Description |
http_handler |
HTTP handler. Includes only one of the fields Settings for handling requests. |
stream_handler |
Stream (TCP) handler. Includes only one of the fields Settings for handling requests. |
certificate_ids[] |
string ID's of the TLS server certificates from Certificate Manager. RSA and ECDSA certificates are supported, and only the first certificate of each type is used. |
StreamHandler
A stream (TCP) handler resource.
Field |
Description |
backend_group_id |
string Required field. ID of the backend group processing requests. For details about the concept, see The backend group type, specified via BackendGroup.backend, must be To get the list of all available backend groups, make a BackendGroupService.List request. |
idle_timeout |
The idle timeout is duration during which no data is transmitted or received on either the upstream or downstream connection. |
SniMatch
A SNI handler resource.
Field |
Description |
name |
string Required field. Name of the SNI handler. |
server_names[] |
string Server names that are matched by the SNI handler. |
handler |
Required field. Settings for handling requests with Server Name Indication (SNI) matching one of |
StreamListener
A stream (TCP) listener resource.
Field |
Description |
handler |
Required field. Settings for handling stream (TCP) requests. |
AllocationPolicy
A locality settings (allocation policy) resource.
Field |
Description |
locations[] |
Availability zones and subnets that the application load balancer resides. |
Location
An application load balancer location resource.
For details about the concept, see documentation.
Field |
Description |
zone_id |
string Required field. ID of the availability zone where the application load balancer resides. Each availability zone can only be specified once. |
subnet_id |
string ID of the subnet that the application load balancer belongs to. |
disable_traffic |
bool Disables the load balancer node in the specified availability zone. Backends in the availability zone are not directly affected by this setting. |
AutoScalePolicy
A resource for scaling settings of an application load balancer.
Field |
Description |
min_zone_size |
int64 Lower limit for the number of resource units in each availability zone. If not specified previously (using other instruments such as management console), the default value is 2. The minimum value is 2. |
max_size |
int64 Upper limit for the total number of resource units across all availability zones. If a positive value is specified, it must be at least If the value is 0, there is no upper limit. |
LogOptions
Field |
Description |
log_group_id |
string Cloud Logging log group ID to store access logs. |
discard_rules[] |
ordered list of rules, first matching rule applies |
disable |
bool Do not send logs to Cloud Logging log group. |
LogDiscardRule
LogDiscardRule discards a fraction of logs with certain codes.
If neither codes or intervals are provided, rule applies to all logs.
Field |
Description |
http_codes[] |
int64 HTTP codes that should be discarded. |
http_code_intervals[] |
enum HttpCodeInterval Groups of HTTP codes like 4xx that should be discarded.
|
grpc_codes[] |
GRPC codes that should be discarded |
discard_percent |
Percent of logs to be discarded: 0 - keep all, 100 or unset - discard all |
operation.Operation
{
"id": "string",
"description": "string",
"created_at": "google.protobuf.Timestamp",
"created_by": "string",
"modified_at": "google.protobuf.Timestamp",
"done": "bool",
"metadata": {
"load_balancer_id": "string"
},
// Includes only one of the fields `error`, `response`
"error": "google.rpc.Status",
"response": {
"id": "string",
"name": "string",
"description": "string",
"folder_id": "string",
"labels": "map<string, string>",
"status": "Status",
"region_id": "string",
"network_id": "string",
"listeners": [
{
"name": "string",
"endpoints": [
{
"addresses": [
{
// Includes only one of the fields `external_ipv4_address`, `internal_ipv4_address`, `external_ipv6_address`
"external_ipv4_address": {
"address": "string"
},
"internal_ipv4_address": {
"address": "string",
"subnet_id": "string"
},
"external_ipv6_address": {
"address": "string"
}
// end of the list of possible fields
}
],
"ports": [
"int64"
]
}
],
// Includes only one of the fields `http`, `tls`, `stream`
"http": {
"handler": {
"http_router_id": "string",
// Includes only one of the fields `http2_options`, `allow_http10`
"http2_options": {
"max_concurrent_streams": "int64"
},
"allow_http10": "bool",
// end of the list of possible fields
"rewrite_request_id": "bool"
},
"redirects": {
"http_to_https": "bool"
}
},
"tls": {
"default_handler": {
// Includes only one of the fields `http_handler`, `stream_handler`
"http_handler": {
"http_router_id": "string",
// Includes only one of the fields `http2_options`, `allow_http10`
"http2_options": {
"max_concurrent_streams": "int64"
},
"allow_http10": "bool",
// end of the list of possible fields
"rewrite_request_id": "bool"
},
"stream_handler": {
"backend_group_id": "string",
"idle_timeout": "google.protobuf.Duration"
},
// end of the list of possible fields
"certificate_ids": [
"string"
]
},
"sni_handlers": [
{
"name": "string",
"server_names": [
"string"
],
"handler": {
// Includes only one of the fields `http_handler`, `stream_handler`
"http_handler": {
"http_router_id": "string",
// Includes only one of the fields `http2_options`, `allow_http10`
"http2_options": {
"max_concurrent_streams": "int64"
},
"allow_http10": "bool",
// end of the list of possible fields
"rewrite_request_id": "bool"
},
"stream_handler": {
"backend_group_id": "string",
"idle_timeout": "google.protobuf.Duration"
},
// end of the list of possible fields
"certificate_ids": [
"string"
]
}
}
]
},
"stream": {
"handler": {
"backend_group_id": "string",
"idle_timeout": "google.protobuf.Duration"
}
}
// end of the list of possible fields
}
],
"allocation_policy": {
"locations": [
{
"zone_id": "string",
"subnet_id": "string",
"disable_traffic": "bool"
}
]
},
"log_group_id": "string",
"security_group_ids": [
"string"
],
"created_at": "google.protobuf.Timestamp",
"auto_scale_policy": {
"min_zone_size": "int64",
"max_size": "int64"
},
"log_options": {
"log_group_id": "string",
"discard_rules": [
{
"http_codes": [
"int64"
],
"http_code_intervals": [
"HttpCodeInterval"
],
"grpc_codes": [
"google.rpc.Code"
],
"discard_percent": "google.protobuf.Int64Value"
}
],
"disable": "bool"
}
}
// end of the list of possible fields
}
An Operation resource. For more information, see Operation.
Field |
Description |
id |
string ID of the operation. |
description |
string Description of the operation. 0-256 characters long. |
created_at |
Creation timestamp. |
created_by |
string ID of the user or service account who initiated the operation. |
modified_at |
The time when the Operation resource was last modified. |
done |
bool If the value is |
metadata |
Service-specific metadata associated with the operation. |
error |
The error result of the operation in case of failure or cancellation. Includes only one of the fields The operation result. |
response |
The normal response of the operation in case of success. Includes only one of the fields The operation result. |
CreateLoadBalancerMetadata
Field |
Description |
load_balancer_id |
string ID of the application load balancer that is being created. |
LoadBalancer
An application load balancer resource.
For details about the concept, see documentation.
Field |
Description |
id |
string ID of the application load balancer. Generated at creation time. |
name |
string Name of the application load balancer. The name is unique within the folder. |
description |
string Description of the application load balancer. |
folder_id |
string ID of the folder that the application load balancer belongs to. |
labels |
object (map<string, string>) Application load balancer labels as |
status |
enum Status Status of the application load balancer.
|
region_id |
string ID of the region that the application load balancer is located at. |
network_id |
string ID of the network that the application load balancer belongs to. |
listeners[] |
Listeners that belong to the application load balancer. For details about the concept, see documentation. |
allocation_policy |
Locality settings of the application load balancer. For details about the concept, see documentation. |
log_group_id |
string ID of the log group that stores access logs of the application load balancer. The logs can be accessed using a Cloud Functions trigger for Cloud Logs. |
security_group_ids[] |
string ID's of the security groups attributed to the application load balancer. For details about the concept, |
created_at |
Creation timestamp. |
auto_scale_policy |
Scaling settings of the application load balancer. The scaling settings relate to a special internal instance group which facilitates the balancer's work. For details about the concept, |
log_options |
Cloud logging settings of the application load balancer. |
Listener
A listener resource.
For details about the concept, see documentation.
Field |
Description |
name |
string Required field. Name of the listener. The name is unique within the application load balancer. |
endpoints[] |
Endpoints of the listener. Endpoints are defined by their IP addresses and ports. |
http |
Unencrypted HTTP listener settings. Includes only one of the fields Listener type and settings. |
tls |
TLS-encrypted HTTP or TCP stream listener settings. All handlers within a listener (TlsListener.default_handler and TlsListener.sni_handlers) must be of one Includes only one of the fields Listener type and settings. |
stream |
Unencrypted stream (TCP) listener settings. Includes only one of the fields Listener type and settings. |
Endpoint
An endpoint resource.
Field |
Description |
addresses[] |
Endpoint public (external) and internal addresses. |
ports[] |
int64 Endpoint ports. |
Address
An endpoint address resource.
Field |
Description |
external_ipv4_address |
Public IPv4 endpoint address. Includes only one of the fields Endpoint address of one of the types: public (external) IPv4 address, internal IPv4 address, public IPv6 address. |
internal_ipv4_address |
Internal IPv4 endpoint address. To enable the use of listeners with internal addresses, contact support. Includes only one of the fields Endpoint address of one of the types: public (external) IPv4 address, internal IPv4 address, public IPv6 address. |
external_ipv6_address |
Public IPv6 endpoint address. Includes only one of the fields Endpoint address of one of the types: public (external) IPv4 address, internal IPv4 address, public IPv6 address. |
ExternalIpv4Address
A public (external) IPv4 endpoint address resource.
Field |
Description |
address |
string IPv4 address. |
InternalIpv4Address
An internal IPv4 endpoint address resource.
Field |
Description |
address |
string IPv4 address. |
subnet_id |
string ID of the subnet that the address belongs to. |
ExternalIpv6Address
A public (external) IPv4 endpoint address resource.
Field |
Description |
address |
string IPv6 address. |
HttpListener
An HTTP listener resource.
Field |
Description |
handler |
Settings for handling HTTP requests. Only one of |
redirects |
Redirects settings. Only one of |
HttpHandler
An HTTP handler resource.
Field |
Description |
http_router_id |
string ID of the HTTP router processing requests. For details about the concept, see To get the list of all available HTTP routers, make a HttpRouterService.List request. |
http2_options |
HTTP/2 settings. If specified, incoming HTTP/2 requests are supported by the listener. Includes only one of the fields Protocol settings. For HTTPS (HTTP over TLS) connections, settings are applied to the protocol |
allow_http10 |
bool Enables support for incoming HTTP/1.0 and HTTP/1.1 requests and disables it for HTTP/2 requests. Includes only one of the fields Protocol settings. For HTTPS (HTTP over TLS) connections, settings are applied to the protocol |
rewrite_request_id |
bool When unset, will preserve the incoming x-request-id header, otherwise would rewrite it with a new value. |
Http2Options
An HTTP/2 options resource.
Field |
Description |
max_concurrent_streams |
int64 Maximum number of concurrent HTTP/2 streams in a connection. |
Redirects
A listener redirects resource.
Field |
Description |
http_to_https |
bool Redirects all unencrypted HTTP requests to the same URI with scheme changed to The setting has the same effect as a single, catch-all HttpRoute |
TlsListener
TLS-encrypted (HTTP or TCP stream) listener resource.
Field |
Description |
default_handler |
Required field. Settings for handling requests by default, with Server Name |
sni_handlers[] |
Settings for handling requests with Server Name Indication (SNI) |
TlsHandler
A TLS-encrypted (HTTP or TCP stream) handler resource.
Field |
Description |
http_handler |
HTTP handler. Includes only one of the fields Settings for handling requests. |
stream_handler |
Stream (TCP) handler. Includes only one of the fields Settings for handling requests. |
certificate_ids[] |
string ID's of the TLS server certificates from Certificate Manager. RSA and ECDSA certificates are supported, and only the first certificate of each type is used. |
StreamHandler
A stream (TCP) handler resource.
Field |
Description |
backend_group_id |
string Required field. ID of the backend group processing requests. For details about the concept, see The backend group type, specified via BackendGroup.backend, must be To get the list of all available backend groups, make a BackendGroupService.List request. |
idle_timeout |
The idle timeout is duration during which no data is transmitted or received on either the upstream or downstream connection. |
SniMatch
A SNI handler resource.
Field |
Description |
name |
string Required field. Name of the SNI handler. |
server_names[] |
string Server names that are matched by the SNI handler. |
handler |
Required field. Settings for handling requests with Server Name Indication (SNI) matching one of |
StreamListener
A stream (TCP) listener resource.
Field |
Description |
handler |
Required field. Settings for handling stream (TCP) requests. |
AllocationPolicy
A locality settings (allocation policy) resource.
Field |
Description |
locations[] |
Availability zones and subnets that the application load balancer resides. |
Location
An application load balancer location resource.
For details about the concept, see documentation.
Field |
Description |
zone_id |
string Required field. ID of the availability zone where the application load balancer resides. Each availability zone can only be specified once. |
subnet_id |
string ID of the subnet that the application load balancer belongs to. |
disable_traffic |
bool Disables the load balancer node in the specified availability zone. Backends in the availability zone are not directly affected by this setting. |
AutoScalePolicy
A resource for scaling settings of an application load balancer.
Field |
Description |
min_zone_size |
int64 Lower limit for the number of resource units in each availability zone. If not specified previously (using other instruments such as management console), the default value is 2. The minimum value is 2. |
max_size |
int64 Upper limit for the total number of resource units across all availability zones. If a positive value is specified, it must be at least If the value is 0, there is no upper limit. |
LogOptions
Field |
Description |
log_group_id |
string Cloud Logging log group ID to store access logs. |
discard_rules[] |
ordered list of rules, first matching rule applies |
disable |
bool Do not send logs to Cloud Logging log group. |
LogDiscardRule
LogDiscardRule discards a fraction of logs with certain codes.
If neither codes or intervals are provided, rule applies to all logs.
Field |
Description |
http_codes[] |
int64 HTTP codes that should be discarded. |
http_code_intervals[] |
enum HttpCodeInterval Groups of HTTP codes like 4xx that should be discarded.
|
grpc_codes[] |
GRPC codes that should be discarded |
discard_percent |
Percent of logs to be discarded: 0 - keep all, 100 or unset - discard all |