Tunnel capacity for cloudflared
Now that you have a Cloudflare Tunnel up and running, evaluate whether cloudflared
has enough system resources to handle the expected volume of requests from end users.
Unlike legacy VPNs where throughput is determined by the server's memory, CPU and other hardware specifications, Cloudflare Tunnel throughput is primarily limited by the number of ports configured in system software. Therefore, when sizing your cloudflared
server, the most important element is sizing the available ports on the machine to reflect the expected throughput of TCP and UDP traffic.
cloudflared
.
To determine how many cloudflared
host servers you need:
-
Start with our baseline recommendations:
- Run a
cloudflared
replica on two dedicated host machines per network location. Using two hosts enables server-side redundancy and traffic balancing. - Size each host with minimum 4GB of RAM and 4 CPU cores.
- Allocate 50,000 ports to the
cloudflared
process on each host.
This setup is usually sufficient to handle traffic from 8,000 users (4,000 per host).
- Run a
-
After you have completed this learning path and have users actively engaging with the network, calculate your actual tunnel usage.
-
Decide how much headroom you want to include and resize the tunnel if needed.
There are two ways to scale Cloudflare Tunnel: you could either add additional replicas of the existing tunnel (Figure 1), or you could divide your network's IP space across multiple tunnels (Figure 2).
flowchart TB accTitle: Figure 1: Multiple replicas of a tunnel that proxies all private networks. subgraph replica1[my-tunnel] ip1[10.0.0.0/8 </br> 172.0.0.0/8 </br> 192.0.0.0/8] end subgraph replica2[my-tunnel] ip2[10.0.0.0/8 </br> 172.0.0.0/8 </br> 192.0.0.0/8] end subgraph replica3[my-tunnel] ip3[10.0.0.0/8 </br> 172.0.0.0/8 </br> 192.0.0.0/8] end replica1 <--> C((Cloudflare)) replica2 <--> C replica3 <--> C
flowchart TB accTitle: Figure 2: Multiple tunnels proxying different private networks. subgraph tunnel-1 ip1[10.0.0.0/8] end subgraph tunnel-2 ip2[172.0.0.0/8] end subgraph tunnel-3 ip3[192.0.0.0/8] end tunnel-1 <--> C((Cloudflare)) tunnel-2 <--> C tunnel-3 <--> C
Adding additional replicas of an existing Cloudflare Tunnel (two is the baseline recommendation) should only be done to support additional traffic to the IP routes in the tunnel. Replicas should always be added in the same physical location as one another so that they can operate in a pooled mode. If you are considering adding a replica in a different geographic location, reevaluate the network proxy design for your Cloudflare Tunnel and refer to When to add tunnels.
Consider creating brand new tunnels when your network is dispersed across different geographic locations. For example, assume that the network represented by 10.0.0.0/8
is almost entirely contiguous in Eastern United States, with one non-overlapping exception for 10.0.50.0/24
served out of the Pacific Northwest. Rather than serve an additional replica from the Pacific Northwest, we recommend breaking out 10.0.50.0/24
into a separate Cloudflare Tunnel. Serve this new tunnel from a host machine near the Pacific Northwest with its own balanced replica implementation.
Even if all routes in your network are served from the same physical location, it may eventually make sense from a control-plane redundancy perspective to split up the network into separate tunnels rather than add replicas.
For instance, if you proxy the ranges 10.0.0.0/8
, 172.0.0.0/8
, and 192.0.0.0/8
from a single tunnel with multiple replicas, you may reach a point of port exhaustion with respect to the traffic flowing through the multitude of networks. It may make sense to break out 10.0.0.0/8
, 172.0.0.0/8
, and 192.0.0.0/8
into their own independent tunnels, each with their own replica. Alternatively, you could find specific applications or functions (like DNS servers or other functions that generate a high volume of independent traffic) and break them out into standalone tunnels with properly rated throughput and replica volume.