Update
Update a Load Balancer
To update a load balancer's settings, send a PUT request to
/v2/load_balancers/$LOAD_BALANCER_ID
. The request should contain a full
representation of the load balancer including existing attributes. It may
contain one of the droplets_ids
or tag
attributes as they are mutually
exclusive. Note that any attribute that is not provided will be reset to its
default value.
Parameters
An array of objects specifying the forwarding rules for a load balancer.
This field has been deprecated. You can no longer specify an algorithm for load balancers.
A boolean value indicating whether to disable automatic DNS record creation for Let's Encrypt certificates that are added to the load balancer.
An array of objects specifying the domain configurations for a Global load balancer.
An array containing the IDs of the Droplets assigned to the load balancer.
A boolean value indicating whether HTTP keepalive connections are maintained to target Droplets.
A boolean value indicating whether PROXY Protocol is in use.
An object specifying allow and deny rules to control traffic to the load balancer.
An object specifying forwarding configurations for a Global load balancer.
An object specifying health check settings for the load balancer.
An integer value which configures the idle timeout for HTTP requests to the target droplets.
A human-readable name for a load balancer instance.
A string indicating whether the load balancer should be external or internal. Internal load balancers have no public IPs and are only accessible to resources on the same VPC network. This property cannot be updated after creating the load balancer.
A string indicating whether the load balancer will support IPv4 or both IPv4 and IPv6 networking. This property cannot be updated after creating the load balancer.
The ID of the project that the load balancer is associated with. If no ID is provided at creation, the load balancer associates with the user's default project. If an invalid project ID is provided, the load balancer will not be created.
A boolean value indicating whether HTTP requests to the load balancer on port 80 will be redirected to HTTPS on port 443.
The slug identifier for the region where the resource will initially be available.
This field has been replaced by the size_unit
field for all regions except in AMS2, NYC2, and SFO1. Each available load balancer size now equates to the load balancer having a set number of nodes.
lb-small
= 1 nodelb-medium
= 3 nodeslb-large
= 6 nodes
You can resize load balancers after creation up to once per hour. You cannot resize a load balancer within the first hour of its creation.
How many nodes the load balancer contains. Each additional node increases the load balancer's ability to manage more connections. Load balancers can be scaled up or down, and you can change the number of nodes after creation up to once per hour. This field is currently not available in the AMS2, NYC2, or SFO1 regions. Use the size
field to scale load balancers that reside in these regions.
An object specifying sticky sessions settings for the load balancer.
An array containing the UUIDs of the Regional load balancers to be used as target backends for a Global load balancer.
A string indicating the policy for the TLS cipher suites used by the load balancer. The possible values are DEFAULT
or STRONG
. The default value is DEFAULT
.
A string indicating whether the load balancer should be a standard regional HTTP load balancer, a regional network load balancer that routes traffic at the TCP/UDP transport layer, or a global load balancer.
A string specifying the UUID of the VPC to which the load balancer is assigned.
Returns
from do_gradientai import GradientAI
client = GradientAI()
load_balancer = client.gpu_droplets.load_balancers.update(
lb_id="4de7ac8b-495b-4884-9a69-1050c6793cd6",
forwarding_rules=[{
"entry_protocol": "http",
"entry_port": 80,
"target_protocol": "http",
"target_port": 80,
"certificate_id": "",
"tls_passthrough": False,
}, {
"entry_protocol": "https",
"entry_port": 443,
"target_protocol": "https",
"target_port": 443,
"certificate_id": "",
"tls_passthrough": True,
}],
algorithm="round_robin",
droplet_ids=[3164444, 3164445],
enable_backend_keepalive=True,
enable_proxy_protocol=True,
firewall={
"deny": ["cidr:1.2.0.0/16", "ip:2.3.4.5"],
"allow": ["ip:1.2.3.4", "cidr:2.3.4.0/24"],
},
health_check={
"protocol": "http",
"port": 80,
"path": "/",
"check_interval_seconds": 10,
"response_timeout_seconds": 5,
"healthy_threshold": 5,
"unhealthy_threshold": 3,
},
http_idle_timeout_seconds=60,
name="updated-example-lb-01",
project_id="9cc10173-e9ea-4176-9dbc-a4cee4c4ff30",
redirect_http_to_https=False,
region="nyc3",
sticky_sessions={
"type": "none"
},
vpc_uuid="c33931f2-a26a-4e61-b85c-4e95a2ec431b",
)
print(load_balancer.load_balancer)
{
"load_balancer": {
"id": "4de7ac8b-495b-4884-9a69-1050c6793cd6",
"name": "updated-example-lb-01",
"ip": "104.131.186.241",
"size": "lb-small",
"algorithm": "round_robin",
"status": "new",
"created_at": "2017-02-01T22:22:58Z",
"forwarding_rules": [
{
"entry_protocol": "http",
"entry_port": 80,
"target_protocol": "http",
"target_port": 80,
"certificate_id": "",
"tls_passthrough": false
},
{
"entry_protocol": "https",
"entry_port": 443,
"target_protocol": "https",
"target_port": 443,
"certificate_id": "",
"tls_passthrough": true
}
],
"health_check": {
"protocol": "http",
"port": 80,
"path": "/",
"check_interval_seconds": 10,
"response_timeout_seconds": 5,
"healthy_threshold": 5,
"unhealthy_threshold": 3
},
"sticky_sessions": {
"type": "none"
},
"region": {
"name": "New York 3",
"slug": "nyc3",
"sizes": [
"s-1vcpu-1gb",
"s-1vcpu-2gb",
"s-1vcpu-3gb",
"s-2vcpu-2gb",
"s-3vcpu-1gb",
"s-2vcpu-4gb",
"s-4vcpu-8gb",
"s-6vcpu-16gb",
"s-8vcpu-32gb",
"s-12vcpu-48gb",
"s-16vcpu-64gb",
"s-20vcpu-96gb",
"s-24vcpu-128gb",
"s-32vcpu-192gb"
],
"features": [
"private_networking",
"backups",
"ipv6",
"metadata",
"install_agent"
],
"available": true
},
"tag": "",
"droplet_ids": [
3164444,
3164445
],
"redirect_http_to_https": false,
"enable_proxy_protocol": true,
"enable_backend_keepalive": true,
"vpc_uuid": "c33931f2-a26a-4e61-b85c-4e95a2ec431b",
"disable_lets_encrypt_dns_records": false,
"project_id": "9cc10173-e9ea-4176-9dbc-a4cee4c4ff30",
"http_idle_timeout_seconds": 60,
"firewall": {
"deny": [
"cidr:1.2.0.0/16",
"ip:2.3.4.5"
],
"allow": [
"ip:1.2.3.4",
"cidr:2.3.4.0/24"
]
}
}
}