Filters
Node Balancers v4.83.1
NodeBalancers List
Returns a paginated list of NodeBalancers you have access to.
Authorizations
| personalAccessToken | |
| oauth | nodebalancers:read_only | 
Query Parameters
| page | 
 The page of a collection to return. | 
| page_size | 
 The number of items to return per page. | 
Request Samples
curl -H "Authorization: Bearer $TOKEN" \
    https://api.linode.com/v4/nodebalancers
linode-cli nodebalancers list
Response Samples
{
  "data": [
    {
      "client_conn_throttle": 0,
      "created": "2018-01-01T00:01:01",
      "hostname": "nb-207-192-68-16.newark.nodebalancer.linode.com",
      "id": 12345,
      "ipv4": "12.34.56.78",
      "ipv6": null,
      "label": "balancer12345",
      "region": "us-east",
      "tags": [
        "example tag",
        "another example"
      ],
      "transfer": {
        "in": 28.91200828552246,
        "out": 3.5487728118896484,
        "total": 32.46078109741211
      },
      "updated": "2018-03-01T00:01:01"
    }
  ],
  "page": 1,
  "pages": 1,
  "results": 1
}{
  "errors": [
    {
      "field": "fieldname",
      "reason": "fieldname must be a valid value"
    }
  ]
}Responses
| data | array of objects
 | ||||||||||||||||||||||||||||
| page | integer | ||||||||||||||||||||||||||||
| pages | integer | ||||||||||||||||||||||||||||
| results | integer | 
| errors | array of objects
 | 
NodeBalancer Create
Creates a NodeBalancer in the requested Region. This NodeBalancer will not start serving requests until it is configured.
Authorizations
| personalAccessToken | |
| oauth | nodebalancers:read_write | 
Request Body Schema
| client_conn_throttle | integer0..20Throttle connections per second. Set to 0 (zero) to disable throttling. | 
| configs | arrayThe ports to configure this NodeBalancer with on creation. Each config must have a unique port and at least one Node. | 
| label Filterable | string3..32
charactersThis NodeBalancer’s label. These must be unique on your Account. | 
| region Required | stringThe ID of the Region to create this NodeBalancer in. | 
Request Samples
curl -H "Content-Type: application/json" \
    -H "Authorization: Bearer $TOKEN" \
    -X POST -d '{
      "region": "us-east",
      "label": "balancer12345",
      "client_conn_throttle": 0
    }' \
    https://api.linode.com/v4/nodebalancers
linode-cli nodebalancers create \
  --region us-east \
  --label balancer12345 \
  --client_conn_throttle 0
Response Samples
{
  "client_conn_throttle": 0,
  "created": "2018-01-01T00:01:01",
  "hostname": "nb-207-192-68-16.newark.nodebalancer.linode.com",
  "id": 12345,
  "ipv4": "12.34.56.78",
  "ipv6": null,
  "label": "balancer12345",
  "region": "us-east",
  "tags": [
    "example tag",
    "another example"
  ],
  "transfer": {
    "in": 28.91200828552246,
    "out": 3.5487728118896484,
    "total": 32.46078109741211
  },
  "updated": "2018-03-01T00:01:01"
}{
  "errors": [
    {
      "field": "fieldname",
      "reason": "fieldname must be a valid value"
    }
  ]
}Responses
| client_conn_throttle | integer0..20Throttle connections per second. Set to 0 (zero) to disable throttling. | ||||||
| created | string <date-time>When this NodeBalancer was created. | ||||||
| hostname | stringThis NodeBalancer’s hostname, ending with .nodebalancer.linode.com | ||||||
| id | integerThis NodeBalancer’s unique ID. | ||||||
| ipv4 | string <ip>This NodeBalancer’s public IPv4 address. | ||||||
| ipv6 Nullable | string <ip>This NodeBalancer’s public IPv6 address. | ||||||
| label Filterable | string3..32
charactersThis NodeBalancer’s label. These must be unique on your Account. | ||||||
| region Filterable | stringThe Region where this NodeBalancer is located. NodeBalancers only support backends in the same Region. | ||||||
| tags Filterable | array of stringsAn array of Tags applied to this object. Tags are for organizational purposes only. | ||||||
| transfer | objectInformation about the amount of transfer this NodeBalancer has had so far this month. 
 | ||||||
| updated | string <date-time>When this NodeBalancer was last updated. | 
| errors | array of objects
 | 
NodeBalancer Delete
Deletes a NodeBalancer.
This is a destructive action and cannot be undone.
Deleting a NodeBalancer will also delete all associated Configs and Nodes, although the backend servers represented by the Nodes will not be changed or removed. Deleting a NodeBalancer will cause you to lose access to the IP Addresses assigned to this NodeBalancer.
Authorizations
| personalAccessToken | |
| oauth | nodebalancers:read_write | 
Path Parameters
| nodeBalancerId | integerRequiredThe ID of the NodeBalancer to access. | 
Request Samples
curl -H "Authorization: Bearer $TOKEN" \
    -X DELETE \
    https://api.linode.com/v4/nodebalancers/12345
linode-cli nodebalancers delete 12345
Response Samples
{
  "errors": [
    {
      "field": "fieldname",
      "reason": "fieldname must be a valid value"
    }
  ]
}Responses
| errors | array of objects
 | 
NodeBalancer View
Returns a single NodeBalancer you can access.
Authorizations
| personalAccessToken | |
| oauth | nodebalancers:read_only | 
Path Parameters
| nodeBalancerId | integerRequiredThe ID of the NodeBalancer to access. | 
Request Samples
curl -H "Authorization: Bearer $TOKEN" \
    https://api.linode.com/v4/nodebalancers/12345
linode-cli nodebalancers view 12345
Response Samples
{
  "client_conn_throttle": 0,
  "created": "2018-01-01T00:01:01",
  "hostname": "nb-207-192-68-16.newark.nodebalancer.linode.com",
  "id": 12345,
  "ipv4": "12.34.56.78",
  "ipv6": null,
  "label": "balancer12345",
  "region": "us-east",
  "tags": [
    "example tag",
    "another example"
  ],
  "transfer": {
    "in": 28.91200828552246,
    "out": 3.5487728118896484,
    "total": 32.46078109741211
  },
  "updated": "2018-03-01T00:01:01"
}{
  "errors": [
    {
      "field": "fieldname",
      "reason": "fieldname must be a valid value"
    }
  ]
}Responses
| client_conn_throttle | integer0..20Throttle connections per second. Set to 0 (zero) to disable throttling. | ||||||
| created | string <date-time>When this NodeBalancer was created. | ||||||
| hostname | stringThis NodeBalancer’s hostname, ending with .nodebalancer.linode.com | ||||||
| id | integerThis NodeBalancer’s unique ID. | ||||||
| ipv4 | string <ip>This NodeBalancer’s public IPv4 address. | ||||||
| ipv6 Nullable | string <ip>This NodeBalancer’s public IPv6 address. | ||||||
| label Filterable | string3..32
charactersThis NodeBalancer’s label. These must be unique on your Account. | ||||||
| region Filterable | stringThe Region where this NodeBalancer is located. NodeBalancers only support backends in the same Region. | ||||||
| tags Filterable | array of stringsAn array of Tags applied to this object. Tags are for organizational purposes only. | ||||||
| transfer | objectInformation about the amount of transfer this NodeBalancer has had so far this month. 
 | ||||||
| updated | string <date-time>When this NodeBalancer was last updated. | 
| errors | array of objects
 | 
NodeBalancer Update
Updates information about a NodeBalancer you can access.
Authorizations
| personalAccessToken | |
| oauth | nodebalancers:read_write | 
Path Parameters
| nodeBalancerId | integerRequiredThe ID of the NodeBalancer to access. | 
Request Body Schema
| client_conn_throttle | integer0..20Throttle connections per second. Set to 0 (zero) to disable throttling. | 
| label Filterable | string3..32
charactersThis NodeBalancer’s label. These must be unique on your Account. | 
| tags Filterable | array of stringsAn array of Tags applied to this object. Tags are for organizational purposes only. | 
| transfer | objectInformation about the amount of transfer this NodeBalancer has had so far this month. | 
Request Samples
curl -H "Content-Type: application/json" \
    -H "Authorization: Bearer $TOKEN" \
    -X PUT -d '{
      "label": "balancer12345",
      "client_conn_throttle": 0
    }' \
    https://api.linode.com/v4/nodebalancers/12345
linode-cli nodebalancers update 12345 \
  --label balancer12345 \
  --client_conn_throttle 0
Response Samples
{
  "client_conn_throttle": 0,
  "created": "2018-01-01T00:01:01",
  "hostname": "nb-207-192-68-16.newark.nodebalancer.linode.com",
  "id": 12345,
  "ipv4": "12.34.56.78",
  "ipv6": null,
  "label": "balancer12345",
  "region": "us-east",
  "tags": [
    "example tag",
    "another example"
  ],
  "transfer": {
    "in": 28.91200828552246,
    "out": 3.5487728118896484,
    "total": 32.46078109741211
  },
  "updated": "2018-03-01T00:01:01"
}{
  "errors": [
    {
      "field": "fieldname",
      "reason": "fieldname must be a valid value"
    }
  ]
}Responses
| client_conn_throttle | integer0..20Throttle connections per second. Set to 0 (zero) to disable throttling. | ||||||
| created | string <date-time>When this NodeBalancer was created. | ||||||
| hostname | stringThis NodeBalancer’s hostname, ending with .nodebalancer.linode.com | ||||||
| id | integerThis NodeBalancer’s unique ID. | ||||||
| ipv4 | string <ip>This NodeBalancer’s public IPv4 address. | ||||||
| ipv6 Nullable | string <ip>This NodeBalancer’s public IPv6 address. | ||||||
| label Filterable | string3..32
charactersThis NodeBalancer’s label. These must be unique on your Account. | ||||||
| region Filterable | stringThe Region where this NodeBalancer is located. NodeBalancers only support backends in the same Region. | ||||||
| tags Filterable | array of stringsAn array of Tags applied to this object. Tags are for organizational purposes only. | ||||||
| transfer | objectInformation about the amount of transfer this NodeBalancer has had so far this month. 
 | ||||||
| updated | string <date-time>When this NodeBalancer was last updated. | 
| errors | array of objects
 | 
Configs List
Returns a paginated list of NodeBalancer Configs associated with this NodeBalancer. NodeBalancer Configs represent individual ports that this NodeBalancer will accept traffic on, one Config per port.
For example, if you wanted to accept standard HTTP traffic, you would need a Config listening on port 80.
Authorizations
| personalAccessToken | |
| oauth | nodebalancers:read_only | 
Path Parameters
| nodeBalancerId | integerRequiredThe ID of the NodeBalancer to access. | 
Query Parameters
| page | 
 The page of a collection to return. | 
| page_size | 
 The number of items to return per page. | 
Request Samples
curl -H "Authorization: Bearer $TOKEN" \
    https://api.linode.com/v4/nodebalancers/12345/configs
linode-cli nodebalancers configs-list 12345
Response Samples
{
  "data": [
    {
      "algorithm": "roundrobin",
      "check": "http_body",
      "check_attempts": 3,
      "check_body": "it works",
      "check_interval": 90,
      "check_passive": true,
      "check_path": "/test",
      "check_timeout": 10,
      "cipher_suite": "recommended",
      "id": 4567,
      "nodebalancer_id": 12345,
      "nodes_status": {
        "down": 0,
        "up": 4
      },
      "port": 80,
      "protocol": "http",
      "proxy_protocol": "none",
      "ssl_cert": null,
      "ssl_commonname": null,
      "ssl_fingerprint": null,
      "ssl_key": null,
      "stickiness": "http_cookie"
    }
  ],
  "page": 1,
  "pages": 1,
  "results": 1
}{
  "errors": [
    {
      "field": "fieldname",
      "reason": "fieldname must be a valid value"
    }
  ]
}Responses
| data | array of objects
 | ||||||||||||||||||||||||||||||||||||||||||||
| page | integer | ||||||||||||||||||||||||||||||||||||||||||||
| pages | integer | ||||||||||||||||||||||||||||||||||||||||||||
| results | integer | 
| errors | array of objects
 | 
Config Create
Creates a NodeBalancer Config, which allows the NodeBalancer to accept traffic on a new port. You will need to add NodeBalancer Nodes to the new Config before it can actually serve requests.
Authorizations
| personalAccessToken | |
| oauth | nodebalancers:read_write | 
Path Parameters
| nodeBalancerId | integerRequiredThe ID of the NodeBalancer to access. | 
Request Body Schema
| algorithm | stringEnum:
 roundrobinleastconnsourceWhat algorithm this NodeBalancer should use for routing traffic to backends. | 
| check | stringEnum:
 noneconnectionhttphttp_bodyThe type of check to perform against backends to ensure they are serving requests. This is used to determine if backends are up or down. 
 | 
| check_attempts | integer1..30How many times to attempt a check before considering a backend to be down. | 
| check_body | stringThis value must be present in the response body of the check in order for it to pass. If this value is not present in the response body of a check request, the backend is considered to be down. | 
| check_interval | integerHow often, in seconds, to check that backends are up and serving requests. | 
| check_passive | booleanIf true, any response from this backend with a  | 
| check_path | stringThe URL path to check on each backend. If the backend does not respond to this request it is considered to be down. | 
| check_timeout | integer1..30How long, in seconds, to wait for a check attempt before considering it failed. | 
| cipher_suite | stringEnum:
 recommendedlegacyWhat ciphers to use for SSL connections served by this NodeBalancer. 
 | 
| port | integer1..65535The port this Config is for. These values must be unique across configs on a single NodeBalancer (you can’t have two configs for port 80, for example). While some ports imply some protocols, no enforcement is done and you may configure your NodeBalancer however is useful to you. For example, while port 443 is generally used for HTTPS, you do not need SSL configured to have a NodeBalancer listening on port 443. | 
| protocol | stringEnum:
 httphttpstcpThe protocol this port is configured to serve. 
 | 
| proxy_protocol | stringEnum:
 nonev1v2Default:noneProxyProtocol is a TCP extension that sends initial TCP connection information such as source/destination IPs and ports to backend devices. This information would be lost otherwise. Backend devices must be configured to work with ProxyProtocol if enabled. 
 | 
| ssl_cert Nullable | string <ssl-cert>The PEM-formatted public SSL certificate (or the combined PEM-formatted SSL certificate and Certificate Authority chain) that should be served on this NodeBalancerConfig’s port. The contents of this field will not be shown in any responses that display
the NodeBalancerConfig. Instead,  The read-only  | 
| ssl_key Nullable | string <ssl-key>The PEM-formatted private key for the SSL certificate set in the  The contents of this field will not be shown in any responses that display
the NodeBalancerConfig. Instead,  The read-only  | 
| stickiness | stringEnum:
 nonetablehttp_cookieControls how session stickiness is handled on this port. 
 | 
Request Samples
curl -H "Content-Type: application/json" \
    -H "Authorization: Bearer $TOKEN" \
    -X POST -d '{
      "port": 80,
      "protocol": "http",
      "algorithm": "roundrobin",
      "stickiness": "http_cookie",
      "check": "http_body",
      "check_interval": 90,
      "check_timeout": 10,
      "check_attempts": 3,
      "check_path": "/test",
      "check_body": "it works",
      "check_passive": true,
      "proxy_protocol": "v1",
      "cipher_suite": "recommended"
    }' \
    https://api.linode.com/v4/nodebalancers/12345/configs
linode-cli nodebalancers config-create 12345 \
  --port 80 \
  --protocol http \
  --algorithm roundrobin \
  --stickiness http_cookie \
  --check http_body \
  --check_interval 90 \
  --check_timeout 10 \
  --check_attempts 3 \
  --check_path "/test" \
  --check_body "it works" \
  --check_passive true \
  --proxy_protocol "v1" \
  --cipher_suite recommended
Response Samples
{
  "algorithm": "roundrobin",
  "check": "http_body",
  "check_attempts": 3,
  "check_body": "it works",
  "check_interval": 90,
  "check_passive": true,
  "check_path": "/test",
  "check_timeout": 10,
  "cipher_suite": "recommended",
  "id": 4567,
  "nodebalancer_id": 12345,
  "nodes_status": {
    "down": 0,
    "up": 4
  },
  "port": 80,
  "protocol": "http",
  "proxy_protocol": "none",
  "ssl_cert": null,
  "ssl_commonname": null,
  "ssl_fingerprint": null,
  "ssl_key": null,
  "stickiness": "http_cookie"
}{
  "errors": [
    {
      "field": "fieldname",
      "reason": "fieldname must be a valid value"
    }
  ]
}Responses
| algorithm | stringEnum:
 roundrobinleastconnsourceWhat algorithm this NodeBalancer should use for routing traffic to backends. | ||||
| check | stringEnum:
 noneconnectionhttphttp_bodyThe type of check to perform against backends to ensure they are serving requests. This is used to determine if backends are up or down. 
 | ||||
| check_attempts | integer1..30How many times to attempt a check before considering a backend to be down. | ||||
| check_body | stringThis value must be present in the response body of the check in order for it to pass. If this value is not present in the response body of a check request, the backend is considered to be down. | ||||
| check_interval | integerHow often, in seconds, to check that backends are up and serving requests. | ||||
| check_passive | booleanIf true, any response from this backend with a  | ||||
| check_path | stringThe URL path to check on each backend. If the backend does not respond to this request it is considered to be down. | ||||
| check_timeout | integer1..30How long, in seconds, to wait for a check attempt before considering it failed. | ||||
| cipher_suite | stringEnum:
 recommendedlegacyWhat ciphers to use for SSL connections served by this NodeBalancer. 
 | ||||
| id | integerThis config’s unique ID | ||||
| nodebalancer_id | integerThe ID for the NodeBalancer this config belongs to. | ||||
| nodes_status | objectA structure containing information about the health of the backends for this port. This information is updated periodically as checks are performed against backends. 
 | ||||
| port | integer1..65535The port this Config is for. These values must be unique across configs on a single NodeBalancer (you can’t have two configs for port 80, for example). While some ports imply some protocols, no enforcement is done and you may configure your NodeBalancer however is useful to you. For example, while port 443 is generally used for HTTPS, you do not need SSL configured to have a NodeBalancer listening on port 443. | ||||
| protocol | stringEnum:
 httphttpstcpThe protocol this port is configured to serve. 
 | ||||
| proxy_protocol | stringEnum:
 nonev1v2Default:noneProxyProtocol is a TCP extension that sends initial TCP connection information such as source/destination IPs and ports to backend devices. This information would be lost otherwise. Backend devices must be configured to work with ProxyProtocol if enabled. 
 | ||||
| ssl_cert Nullable | string <ssl-cert>The PEM-formatted public SSL certificate (or the combined PEM-formatted SSL certificate and Certificate Authority chain) that should be served on this NodeBalancerConfig’s port. The contents of this field will not be shown in any responses that display
the NodeBalancerConfig. Instead,  The read-only  | ||||
| ssl_commonname | stringThe read-only common name automatically derived from the SSL certificate assigned to this NodeBalancerConfig. Please refer to this field to verify that the appropriate certificate is assigned to your NodeBalancerConfig. | ||||
| ssl_fingerprint | stringThe read-only fingerprint automatically derived from the SSL certificate assigned to this NodeBalancerConfig. Please refer to this field to verify that the appropriate certificate is assigned to your NodeBalancerConfig. | ||||
| ssl_key Nullable | string <ssl-key>The PEM-formatted private key for the SSL certificate set in the  The contents of this field will not be shown in any responses that display
the NodeBalancerConfig. Instead,  The read-only  | ||||
| stickiness | stringEnum:
 nonetablehttp_cookieControls how session stickiness is handled on this port. 
 | 
| errors | array of objects
 | 
Config Delete
Deletes the Config for a port of this NodeBalancer.
This cannot be undone.
Once completed, this NodeBalancer will no longer respond to requests on the given port. This also deletes all associated NodeBalancerNodes, but the Linodes they were routing traffic to will be unchanged and will not be removed.
Authorizations
| personalAccessToken | |
| oauth | nodebalancers:read_write | 
Path Parameters
| nodeBalancerId | integerRequiredThe ID of the NodeBalancer to access. | 
| configId | integerRequiredThe ID of the config to access. | 
Request Samples
curl -H "Authorization: Bearer $TOKEN" \
    -X DELETE \
    https://api.linode.com/v4/nodebalancers/12345/configs/4567
linode-cli nodebalancers config-delete \
  12345 4567
Response Samples
{
  "errors": [
    {
      "field": "fieldname",
      "reason": "fieldname must be a valid value"
    }
  ]
}Responses
| errors | array of objects
 | 
Config View
Returns configuration information for a single port of this NodeBalancer.
Authorizations
| personalAccessToken | |
| oauth | nodebalancers:read_only | 
Path Parameters
| nodeBalancerId | integerRequiredThe ID of the NodeBalancer to access. | 
| configId | integerRequiredThe ID of the config to access. | 
Request Samples
curl -H "Authorization: Bearer $TOKEN" \
    https://api.linode.com/v4/nodebalancers/12345/configs/4567
linode-cli nodebalancers config-view \
  12345 4567
Response Samples
{
  "algorithm": "roundrobin",
  "check": "http_body",
  "check_attempts": 3,
  "check_body": "it works",
  "check_interval": 90,
  "check_passive": true,
  "check_path": "/test",
  "check_timeout": 10,
  "cipher_suite": "recommended",
  "id": 4567,
  "nodebalancer_id": 12345,
  "nodes_status": {
    "down": 0,
    "up": 4
  },
  "port": 80,
  "protocol": "http",
  "proxy_protocol": "none",
  "ssl_cert": null,
  "ssl_commonname": null,
  "ssl_fingerprint": null,
  "ssl_key": null,
  "stickiness": "http_cookie"
}{
  "errors": [
    {
      "field": "fieldname",
      "reason": "fieldname must be a valid value"
    }
  ]
}Responses
| algorithm | stringEnum:
 roundrobinleastconnsourceWhat algorithm this NodeBalancer should use for routing traffic to backends. | ||||
| check | stringEnum:
 noneconnectionhttphttp_bodyThe type of check to perform against backends to ensure they are serving requests. This is used to determine if backends are up or down. 
 | ||||
| check_attempts | integer1..30How many times to attempt a check before considering a backend to be down. | ||||
| check_body | stringThis value must be present in the response body of the check in order for it to pass. If this value is not present in the response body of a check request, the backend is considered to be down. | ||||
| check_interval | integerHow often, in seconds, to check that backends are up and serving requests. | ||||
| check_passive | booleanIf true, any response from this backend with a  | ||||
| check_path | stringThe URL path to check on each backend. If the backend does not respond to this request it is considered to be down. | ||||
| check_timeout | integer1..30How long, in seconds, to wait for a check attempt before considering it failed. | ||||
| cipher_suite | stringEnum:
 recommendedlegacyWhat ciphers to use for SSL connections served by this NodeBalancer. 
 | ||||
| id | integerThis config’s unique ID | ||||
| nodebalancer_id | integerThe ID for the NodeBalancer this config belongs to. | ||||
| nodes_status | objectA structure containing information about the health of the backends for this port. This information is updated periodically as checks are performed against backends. 
 | ||||
| port | integer1..65535The port this Config is for. These values must be unique across configs on a single NodeBalancer (you can’t have two configs for port 80, for example). While some ports imply some protocols, no enforcement is done and you may configure your NodeBalancer however is useful to you. For example, while port 443 is generally used for HTTPS, you do not need SSL configured to have a NodeBalancer listening on port 443. | ||||
| protocol | stringEnum:
 httphttpstcpThe protocol this port is configured to serve. 
 | ||||
| proxy_protocol | stringEnum:
 nonev1v2Default:noneProxyProtocol is a TCP extension that sends initial TCP connection information such as source/destination IPs and ports to backend devices. This information would be lost otherwise. Backend devices must be configured to work with ProxyProtocol if enabled. 
 | ||||
| ssl_cert Nullable | string <ssl-cert>The PEM-formatted public SSL certificate (or the combined PEM-formatted SSL certificate and Certificate Authority chain) that should be served on this NodeBalancerConfig’s port. The contents of this field will not be shown in any responses that display
the NodeBalancerConfig. Instead,  The read-only  | ||||
| ssl_commonname | stringThe read-only common name automatically derived from the SSL certificate assigned to this NodeBalancerConfig. Please refer to this field to verify that the appropriate certificate is assigned to your NodeBalancerConfig. | ||||
| ssl_fingerprint | stringThe read-only fingerprint automatically derived from the SSL certificate assigned to this NodeBalancerConfig. Please refer to this field to verify that the appropriate certificate is assigned to your NodeBalancerConfig. | ||||
| ssl_key Nullable | string <ssl-key>The PEM-formatted private key for the SSL certificate set in the  The contents of this field will not be shown in any responses that display
the NodeBalancerConfig. Instead,  The read-only  | ||||
| stickiness | stringEnum:
 nonetablehttp_cookieControls how session stickiness is handled on this port. 
 | 
| errors | array of objects
 | 
Config Update
Updates the configuration for a single port on a NodeBalancer.
Authorizations
| personalAccessToken | |
| oauth | nodebalancers:read_write | 
Path Parameters
| nodeBalancerId | integerRequiredThe ID of the NodeBalancer to access. | 
| configId | integerRequiredThe ID of the config to access. | 
Request Body Schema
| algorithm | stringEnum:
 roundrobinleastconnsourceWhat algorithm this NodeBalancer should use for routing traffic to backends. | 
| check | stringEnum:
 noneconnectionhttphttp_bodyThe type of check to perform against backends to ensure they are serving requests. This is used to determine if backends are up or down. 
 | 
| check_attempts | integer1..30How many times to attempt a check before considering a backend to be down. | 
| check_body | stringThis value must be present in the response body of the check in order for it to pass. If this value is not present in the response body of a check request, the backend is considered to be down. | 
| check_interval | integerHow often, in seconds, to check that backends are up and serving requests. | 
| check_passive | booleanIf true, any response from this backend with a  | 
| check_path | stringThe URL path to check on each backend. If the backend does not respond to this request it is considered to be down. | 
| check_timeout | integer1..30How long, in seconds, to wait for a check attempt before considering it failed. | 
| cipher_suite | stringEnum:
 recommendedlegacyWhat ciphers to use for SSL connections served by this NodeBalancer. 
 | 
| port | integer1..65535The port this Config is for. These values must be unique across configs on a single NodeBalancer (you can’t have two configs for port 80, for example). While some ports imply some protocols, no enforcement is done and you may configure your NodeBalancer however is useful to you. For example, while port 443 is generally used for HTTPS, you do not need SSL configured to have a NodeBalancer listening on port 443. | 
| protocol | stringEnum:
 httphttpstcpThe protocol this port is configured to serve. 
 | 
| proxy_protocol | stringEnum:
 nonev1v2Default:noneProxyProtocol is a TCP extension that sends initial TCP connection information such as source/destination IPs and ports to backend devices. This information would be lost otherwise. Backend devices must be configured to work with ProxyProtocol if enabled. 
 | 
| ssl_cert Nullable | string <ssl-cert>The PEM-formatted public SSL certificate (or the combined PEM-formatted SSL certificate and Certificate Authority chain) that should be served on this NodeBalancerConfig’s port. The contents of this field will not be shown in any responses that display
the NodeBalancerConfig. Instead,  The read-only  | 
| ssl_key Nullable | string <ssl-key>The PEM-formatted private key for the SSL certificate set in the  The contents of this field will not be shown in any responses that display
the NodeBalancerConfig. Instead,  The read-only  | 
| stickiness | stringEnum:
 nonetablehttp_cookieControls how session stickiness is handled on this port. 
 | 
Request Samples
curl -H "Content-Type: application/json" \
    -H "Authorization: Bearer $TOKEN" \
    -X PUT -d '{
      "port": 80,
      "protocol": "http",
      "algorithm": "roundrobin",
      "stickiness": "http_cookie",
      "check": "http_body",
      "check_interval": 90,
      "check_timeout": 10,
      "check_attempts": 3,
      "check_path": "/test",
      "check_body": "it works",
      "check_passive": true,
      "proxy_protocol": "v1",
      "cipher_suite": "recommended"
    }' \
    https://api.linode.com/v4/nodebalancers/12345/configs/4567
linode-cli nodebalancers config-update \
  12345 4567 \
  --port 80 \
  --protocol http \
  --algorithm roundrobin \
  --stickiness http_cookie \
  --check http_body \
  --check_interval 90 \
  --check_timeout 10 \
  --check_attempts 3 \
  --check_path "/test" \
  --check_body "it works" \
  --check_passive true \
  --proxy_protocol "v1" \
  --cipher_suite recommended
Response Samples
{
  "algorithm": "roundrobin",
  "check": "http_body",
  "check_attempts": 3,
  "check_body": "it works",
  "check_interval": 90,
  "check_passive": true,
  "check_path": "/test",
  "check_timeout": 10,
  "cipher_suite": "recommended",
  "id": 4567,
  "nodebalancer_id": 12345,
  "nodes_status": {
    "down": 0,
    "up": 4
  },
  "port": 80,
  "protocol": "http",
  "proxy_protocol": "none",
  "ssl_cert": null,
  "ssl_commonname": null,
  "ssl_fingerprint": null,
  "ssl_key": null,
  "stickiness": "http_cookie"
}{
  "errors": [
    {
      "field": "fieldname",
      "reason": "fieldname must be a valid value"
    }
  ]
}Responses
| algorithm | stringEnum:
 roundrobinleastconnsourceWhat algorithm this NodeBalancer should use for routing traffic to backends. | ||||
| check | stringEnum:
 noneconnectionhttphttp_bodyThe type of check to perform against backends to ensure they are serving requests. This is used to determine if backends are up or down. 
 | ||||
| check_attempts | integer1..30How many times to attempt a check before considering a backend to be down. | ||||
| check_body | stringThis value must be present in the response body of the check in order for it to pass. If this value is not present in the response body of a check request, the backend is considered to be down. | ||||
| check_interval | integerHow often, in seconds, to check that backends are up and serving requests. | ||||
| check_passive | booleanIf true, any response from this backend with a  | ||||
| check_path | stringThe URL path to check on each backend. If the backend does not respond to this request it is considered to be down. | ||||
| check_timeout | integer1..30How long, in seconds, to wait for a check attempt before considering it failed. | ||||
| cipher_suite | stringEnum:
 recommendedlegacyWhat ciphers to use for SSL connections served by this NodeBalancer. 
 | ||||
| id | integerThis config’s unique ID | ||||
| nodebalancer_id | integerThe ID for the NodeBalancer this config belongs to. | ||||
| nodes_status | objectA structure containing information about the health of the backends for this port. This information is updated periodically as checks are performed against backends. 
 | ||||
| port | integer1..65535The port this Config is for. These values must be unique across configs on a single NodeBalancer (you can’t have two configs for port 80, for example). While some ports imply some protocols, no enforcement is done and you may configure your NodeBalancer however is useful to you. For example, while port 443 is generally used for HTTPS, you do not need SSL configured to have a NodeBalancer listening on port 443. | ||||
| protocol | stringEnum:
 httphttpstcpThe protocol this port is configured to serve. 
 | ||||
| proxy_protocol | stringEnum:
 nonev1v2Default:noneProxyProtocol is a TCP extension that sends initial TCP connection information such as source/destination IPs and ports to backend devices. This information would be lost otherwise. Backend devices must be configured to work with ProxyProtocol if enabled. 
 | ||||
| ssl_cert Nullable | string <ssl-cert>The PEM-formatted public SSL certificate (or the combined PEM-formatted SSL certificate and Certificate Authority chain) that should be served on this NodeBalancerConfig’s port. The contents of this field will not be shown in any responses that display
the NodeBalancerConfig. Instead,  The read-only  | ||||
| ssl_commonname | stringThe read-only common name automatically derived from the SSL certificate assigned to this NodeBalancerConfig. Please refer to this field to verify that the appropriate certificate is assigned to your NodeBalancerConfig. | ||||
| ssl_fingerprint | stringThe read-only fingerprint automatically derived from the SSL certificate assigned to this NodeBalancerConfig. Please refer to this field to verify that the appropriate certificate is assigned to your NodeBalancerConfig. | ||||
| ssl_key Nullable | string <ssl-key>The PEM-formatted private key for the SSL certificate set in the  The contents of this field will not be shown in any responses that display
the NodeBalancerConfig. Instead,  The read-only  | ||||
| stickiness | stringEnum:
 nonetablehttp_cookieControls how session stickiness is handled on this port. 
 | 
| errors | array of objects
 | 
Nodes List
Returns a paginated list of NodeBalancer nodes associated with this Config. These are the backends that will be sent traffic for this port.
Authorizations
| personalAccessToken | |
| oauth | nodebalancers:read_only | 
Path Parameters
| nodeBalancerId | integerRequiredThe ID of the NodeBalancer to access. | 
| configId | integerRequiredThe ID of the NodeBalancer config to access. | 
Query Parameters
| page | 
 The page of a collection to return. | 
| page_size | 
 The number of items to return per page. | 
Request Samples
curl -H "Authorization: Bearer $TOKEN" \
    https://api.linode.com/v4/nodebalancers/12345/configs/4567/nodes
linode-cli nodebalancers nodes-list 12345 4567
Response Samples
{
  "data": [
    {
      "address": "192.168.210.120:80",
      "config_id": 4567,
      "id": 54321,
      "label": "node54321",
      "mode": "accept",
      "nodebalancer_id": 12345,
      "status": "UP",
      "weight": 50
    }
  ],
  "page": 1,
  "pages": 1,
  "results": 1
}{
  "errors": [
    {
      "field": "fieldname",
      "reason": "fieldname must be a valid value"
    }
  ]
}Responses
| data | array of objects
 | ||||||||||||||||
| page | integer | ||||||||||||||||
| pages | integer | ||||||||||||||||
| results | integer | 
| errors | array of objects
 | 
Node Create
Creates a NodeBalancer Node, a backend that can accept traffic for this NodeBalancer Config. Nodes are routed requests on the configured port based on their status.
Authorizations
| personalAccessToken | |
| oauth | nodebalancers:read_write | 
Path Parameters
| nodeBalancerId | integerRequiredThe ID of the NodeBalancer to access. | 
| configId | integerRequiredThe ID of the NodeBalancer config to access. | 
Request Body Schema
| address Required | string <ip>The private IP Address where this backend can be reached. This must be a private IP address. | 
| label Required | string3..32
charactersThe label for this node. This is for display purposes only. | 
| mode | stringEnum:
 acceptrejectdrainbackupThe mode this NodeBalancer should use when sending traffic to this backend. 
 | 
| weight | integer1..255Used when picking a backend to serve a request and is not pinned to a single backend yet. Nodes with a higher weight will receive more traffic. | 
Request Samples
curl -H "Content-Type: application/json" \
    -H "Authorization: Bearer $TOKEN" \
    -X POST -d '{
      "address": "192.168.210.120:80",
      "label": "node54321",
      "weight": 50,
      "mode": "accept"
    }' \
    https://api.linode.com/v4/nodebalancers/12345/configs/4567/nodes
linode-cli nodebalancers node-create \
  12345 4567 \
  --address 192.168.210.120:80 \
  --label node54321 \
  --weight 50 \
  --mode accept
Response Samples
{
  "address": "192.168.210.120:80",
  "config_id": 4567,
  "id": 54321,
  "label": "node54321",
  "mode": "accept",
  "nodebalancer_id": 12345,
  "status": "UP",
  "weight": 50
}{
  "errors": [
    {
      "field": "fieldname",
      "reason": "fieldname must be a valid value"
    }
  ]
}Responses
| address | string <ip>The private IP Address where this backend can be reached. This must be a private IP address. | 
| config_id | integerThe NodeBalancer Config ID that this Node belongs to. | 
| id | integerThis node’s unique ID. | 
| label | string3..32
charactersThe label for this node. This is for display purposes only. | 
| mode | stringEnum:
 acceptrejectdrainbackupThe mode this NodeBalancer should use when sending traffic to this backend. 
 | 
| nodebalancer_id | integerThe NodeBalancer ID that this Node belongs to. | 
| status | stringEnum:
 unknownUPDOWNThe current status of this node, based on the configured checks of its NodeBalancer Config. | 
| weight | integer1..255Used when picking a backend to serve a request and is not pinned to a single backend yet. Nodes with a higher weight will receive more traffic. | 
| errors | array of objects
 | 
Node Delete
Deletes a Node from this Config. This backend will no longer receive traffic for the configured port of this NodeBalancer.
This does not change or remove the Linode whose address was used in the creation of this Node.
Authorizations
| personalAccessToken | |
| oauth | nodebalancers:read_write | 
Path Parameters
| nodeBalancerId | integerRequiredThe ID of the NodeBalancer to access. | 
| configId | integerRequiredThe ID of the Config to access | 
| nodeId | integerRequiredThe ID of the Node to access | 
Request Samples
curl -H "Authorization: Bearer $TOKEN" \
    -X DELETE \
    https://api.linode.com/v4/nodebalancers/12345/configs/4567/nodes/54321
linode-cli nodebalancers node-delete \
  12345 4567 54321
Response Samples
{
  "errors": [
    {
      "field": "fieldname",
      "reason": "fieldname must be a valid value"
    }
  ]
}Responses
| errors | array of objects
 | 
Node View
Returns information about a single Node, a backend for this NodeBalancer’s configured port.
Authorizations
| personalAccessToken | |
| oauth | nodebalancers:read_write | 
Path Parameters
| nodeBalancerId | integerRequiredThe ID of the NodeBalancer to access. | 
| configId | integerRequiredThe ID of the Config to access | 
| nodeId | integerRequiredThe ID of the Node to access | 
Request Samples
curl -H "Authorization: Bearer $TOKEN" \
    https://api.linode.com/v4/nodebalancers/12345/configs/4567/nodes/54321
linode-cli nodebalancers node-view 12345 4567 54321
Response Samples
{
  "address": "192.168.210.120:80",
  "config_id": 4567,
  "id": 54321,
  "label": "node54321",
  "mode": "accept",
  "nodebalancer_id": 12345,
  "status": "UP",
  "weight": 50
}{
  "errors": [
    {
      "field": "fieldname",
      "reason": "fieldname must be a valid value"
    }
  ]
}Responses
| address | string <ip>The private IP Address where this backend can be reached. This must be a private IP address. | 
| config_id | integerThe NodeBalancer Config ID that this Node belongs to. | 
| id | integerThis node’s unique ID. | 
| label | string3..32
charactersThe label for this node. This is for display purposes only. | 
| mode | stringEnum:
 acceptrejectdrainbackupThe mode this NodeBalancer should use when sending traffic to this backend. 
 | 
| nodebalancer_id | integerThe NodeBalancer ID that this Node belongs to. | 
| status | stringEnum:
 unknownUPDOWNThe current status of this node, based on the configured checks of its NodeBalancer Config. | 
| weight | integer1..255Used when picking a backend to serve a request and is not pinned to a single backend yet. Nodes with a higher weight will receive more traffic. | 
| errors | array of objects
 | 
Node Update
Updates information about a Node, a backend for this NodeBalancer’s configured port.
Authorizations
| personalAccessToken | |
| oauth | nodebalancers:read_write | 
Path Parameters
| nodeBalancerId | integerRequiredThe ID of the NodeBalancer to access. | 
| configId | integerRequiredThe ID of the Config to access | 
| nodeId | integerRequiredThe ID of the Node to access | 
Request Body Schema
| address | string <ip>The private IP Address where this backend can be reached. This must be a private IP address. | 
| label | string3..32
charactersThe label for this node. This is for display purposes only. | 
| mode | stringEnum:
 acceptrejectdrainbackupThe mode this NodeBalancer should use when sending traffic to this backend. 
 | 
| weight | integer1..255Used when picking a backend to serve a request and is not pinned to a single backend yet. Nodes with a higher weight will receive more traffic. | 
Request Samples
curl -H "Content-Type: application/json" \
    -H "Authorization: Bearer $TOKEN" \
    -X PUT -d '{
      "address": "192.168.210.120:80",
      "label": "node54321",
      "weight": 50,
      "mode": "accept"
    }' \
    https://api.linode.com/v4/nodebalancers/12345/configs/4567/nodes/54321
linode-cli nodebalancers node-create \
  12345 4567 54321 \
  --address 192.168.210.120:80 \
  --label node54321 \
  --weight 50 \
  --mode accept
Response Samples
{
  "address": "192.168.210.120:80",
  "config_id": 4567,
  "id": 54321,
  "label": "node54321",
  "mode": "accept",
  "nodebalancer_id": 12345,
  "status": "UP",
  "weight": 50
}{
  "errors": [
    {
      "field": "fieldname",
      "reason": "fieldname must be a valid value"
    }
  ]
}Responses
| address | string <ip>The private IP Address where this backend can be reached. This must be a private IP address. | 
| config_id | integerThe NodeBalancer Config ID that this Node belongs to. | 
| id | integerThis node’s unique ID. | 
| label | string3..32
charactersThe label for this node. This is for display purposes only. | 
| mode | stringEnum:
 acceptrejectdrainbackupThe mode this NodeBalancer should use when sending traffic to this backend. 
 | 
| nodebalancer_id | integerThe NodeBalancer ID that this Node belongs to. | 
| status | stringEnum:
 unknownUPDOWNThe current status of this node, based on the configured checks of its NodeBalancer Config. | 
| weight | integer1..255Used when picking a backend to serve a request and is not pinned to a single backend yet. Nodes with a higher weight will receive more traffic. | 
| errors | array of objects
 | 
Config Rebuild
Rebuilds a NodeBalancer Config and its Nodes that you have permission to modify.
Authorizations
| personalAccessToken | |
| oauth | nodebalancers:read_write | 
Path Parameters
| nodeBalancerId | integerRequiredThe ID of the NodeBalancer to access. | 
| configId | integerRequiredThe ID of the Config to access. | 
Request Body Schema
| configs | arrayEach config must have a unique port and at least one Node. Additionally: 
 | 
Request Samples
curl -H "Content-Type: application/json" \
    -H "Authorization: Bearer $TOKEN" \
    -X POST -d '{
      "port": 80,
      "protocol": "http",
      "algorithm": "roundrobin",
      "stickiness": "http_cookie",
      "check": "http_body",
      "check_interval": 90,
      "check_timeout": 10,
      "check_attempts": 3,
      "check_path": "/test",
      "check_body": "it works",
      "check_passive": true,
      "proxy_protocol": "v1",
      "cipher_suite": "recommended",
      "nodes": [
        {
          "id": 543231,
          "address": "192.168.210.120:80",
          "label": "node54321",
          "weight": 50,
          "mode": "accept"
        },
        {
          "address": "192.168.210.122:81",
          "label": "thenewnode",
          "weight": 50,
          "mode": "accept"
        },
      ]
    }' \
    https://api.linode.com/v4/nodebalancers/12345/configs/4567/rebuild
linode-cli nodebalancers config-rebuild \
  12345 4567 \
  --port 80 \
  --protocol http \
  --algorithm roundrobin \
  --stickiness http_cookie \
  --check http_body \
  --check_interval 90 \
  --check_timeout 10 \
  --check_attempts 3 \
  --check_path "/test" \
  --check_body "it works" \
  --check_passive true \
  --proxy_protocol "v1" \
  --cipher_suite recommended
Response Samples
{
  "client_conn_throttle": 0,
  "created": "2018-01-01T00:01:01",
  "hostname": "nb-207-192-68-16.newark.nodebalancer.linode.com",
  "id": 12345,
  "ipv4": "12.34.56.78",
  "ipv6": null,
  "label": "balancer12345",
  "region": "us-east",
  "tags": [
    "example tag",
    "another example"
  ],
  "transfer": {
    "in": 28.91200828552246,
    "out": 3.5487728118896484,
    "total": 32.46078109741211
  },
  "updated": "2018-03-01T00:01:01"
}{
  "errors": [
    {
      "field": "fieldname",
      "reason": "fieldname must be a valid value"
    }
  ]
}Responses
| client_conn_throttle | integer0..20Throttle connections per second. Set to 0 (zero) to disable throttling. | ||||||
| created | string <date-time>When this NodeBalancer was created. | ||||||
| hostname | stringThis NodeBalancer’s hostname, ending with .nodebalancer.linode.com | ||||||
| id | integerThis NodeBalancer’s unique ID. | ||||||
| ipv4 | string <ip>This NodeBalancer’s public IPv4 address. | ||||||
| ipv6 Nullable | string <ip>This NodeBalancer’s public IPv6 address. | ||||||
| label Filterable | string3..32
charactersThis NodeBalancer’s label. These must be unique on your Account. | ||||||
| region Filterable | stringThe Region where this NodeBalancer is located. NodeBalancers only support backends in the same Region. | ||||||
| tags Filterable | array of stringsAn array of Tags applied to this object. Tags are for organizational purposes only. | ||||||
| transfer | objectInformation about the amount of transfer this NodeBalancer has had so far this month. 
 | ||||||
| updated | string <date-time>When this NodeBalancer was last updated. | 
| errors | array of objects
 | 
NodeBalancer Statistics View
Returns detailed statistics about the requested NodeBalancer.
Authorizations
| personalAccessToken | |
| oauth | nodebalancers:read_only | 
Path Parameters
| nodeBalancerId | integerRequiredThe ID of the NodeBalancer to access. | 
Response Samples
{
  "data": {
    "connections": [
      null
    ],
    "traffic": {
      "in": [
        null
      ],
      "out": [
        null
      ]
    }
  },
  "title": "linode.com - balancer12345 (12345) - day (5 min avg)"
}{
  "errors": [
    {
      "field": "fieldname",
      "reason": "fieldname must be a valid value"
    }
  ]
}Responses
| data | objectThe data returned about this NodeBalancers. 
 | ||||||||
| title | stringThe title for the statistics generated in this response. | 
| errors | array of objects
 | 



