Cloudflare Docs
Load Balancing
Load Balancing
Edit this page on GitHub
Set theme to dark (⇧+D)

Load shedding

Use load shedding to prevent an at-risk origin from becoming unhealthy and starting the failover process.

Once you configure load shedding on a pool, that pool will begin diverting traffic to other pools according to your load shedding settings and the load balancer’s steering policy.

​​ Step 1 — Identify at-risk origins

Using your internal metrics, identify origins at risk of reaching their failure threshold.

  • If your origin is seeing increased traffic but is not yet at risk of failure, start with Step 2.
  • If your origin is about to fail, start with Step 4.

​​ Step 2 — Shed default traffic from a pool

Once you have identified an at-risk origin, shed a small amount of Default traffic from that origin’s pool. This traffic is not affiliated with existing Session affinity sessions.

Configure load shedding via the dashboard or the API.

​​ Configure via dashboard

To enable load shedding for a specific pool via the dashboard:

  1. Go to Traffic > Load Balancing.
  2. Click Manage Pools.
  3. On a pool, click Edit.
  4. Click the Configure Load Shedding dropdown.
  5. For Default traffic, select a Policy and a Shed %:
Policy options

When shedding Default traffic, you have two Policy options:

  • Random: Randomly sheds the percentage of requests specified in the Shed %. Distributes traffic more accurately, but may cause requests from the same IP to hit different origins.
  • IP hash: Sheds the percentage of IP address hash space specified in the Shed %. Ensures requests from the same IP will hit the same origin, but may shed a significantly higher or lower percentage of requests.

For more guidance on choosing a policy, refer to Shedding policies.

Shed %
When choosing a Shed %, start with a small percentage and increase gradually. Particularly if you choose the IP hash shedding policy, you might shed more traffic than expected.

​​ Configure via API

To enable load shedding for a specific pool via the API, update the values for the pool’s load_shedding object.

Example request
Request
curl -X PATCH "https://api.cloudflare.com/client/v4/accounts/{account-id}/load_balancers/pools/{pool-id}" \
-H "X-Auth-Email: [email protected]" \
-H "X-Auth-Key: REDACTED" \
-H "Content-Type: application/json" \
--data-binary '{
"load_shedding": {
"default_percent": 20,
"default_policy": "random",
"session_percent": 0,
"session_policy": "hash"
}
}'

For more guidance on choosing a shedding policy, see Shedding policies.

​​ Step 3 — Monitor traffic

Once you have started shedding default traffic, evaluate the effects by reviewing the Overview metrics in Load Balancing analytics. Based on these numbers and your internal metrics, you will know whether you need to divert additional traffic from the pool.

If you see increased traffic to a pool, you may need to shed additional traffic. Pools shed a percentage of total traffic, so any increase in total traffic will also increase the traffic reaching your pool.

​​ Step 4 — Shed additional traffic (optional)

If you need to shed additional pool traffic:

  1. Follow the steps outlined in Step 2.
    • In the dashboard, increase the Shed % for Default traffic and/or Session affinity traffic.
    • For the API, increase the value for default_percent and/or session_percent.

Since shedding Session Affinity traffic will disrupt existing sessions and may degrade the customer experience, only enable this option if your pool is in imminent danger of becoming unhealthy or your pool has a high percentage of traffic related to existing sessions. For more guidance, see Shedding policies.

​​ Step 5 — Disable load shedding

Once an origin is no longer at risk, remove load shedding from the pool.

To remove load shedding in the dashboard, perform the same steps as Configure load shedding via the dashboard but set the Shed % to 0 for both Default traffic and Session affinity traffic.

To remove load shedding via the API, perform the same steps as Configure load shedding via the API but set the load_shedding object to null.

​​ Additional notes

​​ Shedding policies

For Default traffic, you have two choices for shedding policy.

A Random policy:

  • Randomly sheds the percentage of requests specified in the Shed %.
  • Distributes traffic more accurately because it sheds at the request level.
  • May cause requests from the same IP to hit different origins, potentially leading to cache misses, inconsistent latency, or session disruption for DNS-only load balancers.

An IP hash policy:

  • Sheds the percentage of IP address hash space specified in the Shed %.
  • Ensures requests from the same IP will hit the same origin, which will increase cache hits, provide consistent latency, and preserve sessions.
  • Can over- or under-shed requests, since hashing does not guarantee a perfectly even IP distribution and individual IPs may be responsible for different percentages of your requests.

Choose a Random policy when you want a more accurate distribution of raw requests and an IP hash policy when you want to prevent a single IP from flapping between different origins.

For Session Affinity traffic, you can only use an IP hash policy since these requests relate to existing sessions. Only increase the Shed % if you are comfortable disrupting existing sessions.

​​ Fallback pools

If all pools within a load balancer have Load shedding enabled, some traffic will go to the fallback pool. To prevent any traffic from reaching the fallback pool, ensure at least one pool within the load balancer does not have load shedding enabled.

​​ Pools in multiple load balancers

If you enable load shedding on an origin pool, it will shed the same percentage of traffic across all your load balancers. If you need an origin to shed different percentages of traffic for different load balancers, put that origin in multiple pools.