Cloudflare Tunnel
Faster, more reliable UDP traffic for Cloudflare Tunnel
Your real-time applications running over Cloudflare Tunnel are now faster and more reliable. We've completely re-architected the way cloudflared proxies UDP traffic in order to isolate it from other traffic, ensuring latency-sensitive applications like private DNS are no longer slowed down by heavy TCP traffic (like file transfers) on the same Tunnel.
This is a foundational improvement to Cloudflare Tunnel, delivered automatically to all customers. There are no settings to configure — your UDP traffic is already flowing faster and more reliably.
What’s new:
- Faster UDP performance: We've significantly reduced the latency for establishing new UDP sessions, making applications like private DNS much more responsive.
- Greater reliability for mixed traffic: UDP packets are no longer affected by heavy TCP traffic, preventing timeouts and connection drops for your real-time services.
Learn more about running TCP or UDP applications and private networks through Cloudflare Tunnel.
Troubleshoot tunnels with diagnostic logs
The latest cloudflared build 2024.12.2 ↗ introduces the ability to collect all the diagnostic logs needed to troubleshoot a cloudflared instance.
A diagnostic report collects data from a single instance of cloudflared running on the local machine and outputs it to a cloudflared-diag file.
The cloudflared-diag-YYYY-MM-DDThh-mm-ss.zip archive contains the files listed below. The data in a file either applies to the cloudflared instance being diagnosed (diagnosee) or the instance that triggered the diagnosis (diagnoser). For example, if your tunnel is running in a Docker container, the diagnosee is the Docker instance and the diagnoser is the host instance.
| File name | Description | Instance | 
|---|---|---|
| cli-configuration.json | Tunnel run parameters used when starting the tunnel | diagnosee | 
| cloudflared_logs.txt | Tunnel log file1 | diagnosee | 
| configuration.json | Tunnel configuration parameters | diagnosee | 
| goroutine.pprof | goroutine profile made available by pprof | diagnosee | 
| heap.pprof | heap profile made available by pprof | diagnosee | 
| metrics.txt | Snapshot of Tunnel metrics at the time of diagnosis | diagnosee | 
| network.txt | JSON traceroutes to Cloudflare's global network using IPv4 and IPv6 | diagnoser | 
| raw-network.txt | Raw traceroutes to Cloudflare's global network using IPv4 and IPv6 | diagnoser | 
| systeminformation.json | Operating system information and resource usage | diagnosee | 
| task-result.json | Result of each diagnostic task | diagnoser | 
| tunnelstate.json | Tunnel connections at the time of diagnosis | diagnosee | 
- 
If the log file is blank, you may need to set --logleveltodebugwhen you start the tunnel. The--loglevelparameter is only required if you ran the tunnel from the CLI using acloudflared tunnel runcommand. It is not necessary if the tunnel runs as a Linux/macOS service or runs in Docker/Kubernetes. ↩
For more information, refer to Diagnostic logs.
Simplifed WARP Connector deployment
You can now deploy WARP Connector using a simplified, guided workflow similar to cloudflared connectors. For detailed instructions, refer to the WARP Connector documentation.
Bugfix for --grace-period
The new cloudflared build 2024.10.0 ↗ has a bugfix related to the --grace-period tunnel run parameter. cloudflared connectors will now abide by the specified waiting period before forcefully closing connections to Cloudflare's network.
cloudflared builds available in GitHub for Apple silicon
macOS users can now download cloudflared-arm64.pkg directly from GitHub ↗, in addition to being available via Homebrew.
Was this helpful?
- Resources
- API
- New to Cloudflare?
- Directory
- Sponsorships
- Open Source
- Support
- Help Center
- System Status
- Compliance
- GDPR
- Company
- cloudflare.com
- Our team
- Careers
- © 2025 Cloudflare, Inc.
- Privacy Policy
- Terms of Use
- Report Security Issues
- Trademark