Table of Contents
- Overview
- Installation
- Basic Usage
- Tunnel Management
- Configuration
- Access Management
- Monitoring
- Troubleshooting
- Best Practices
Overview
Cloudflared is the command-line client for Cloudflare Tunnel, enabling secure connections between your resources and the Cloudflare network without exposing public IPs.
Key Features
- Secure tunnel creation
- Zero Trust access
- Local development
- Service proxying
- DNS management
- Access policies
- Metrics and logging
Installation
Ubuntu (22.04/24.04)
# Using package manager
curl -L https://pkg.cloudflare.com/cloudflare-main.gpg | sudo tee /usr/share/keyrings/cloudflare-archive-keyring.gpg >/dev/null
echo "deb [signed-by=/usr/share/keyrings/cloudflare-archive-keyring.gpg] https://pkg.cloudflare.com/cloudflared $(lsb_release -cs) main" | sudo tee /etc/apt/sources.list.d/cloudflared.list
sudo apt update
sudo apt install cloudflaredmacOS
# Using Homebrew
brew install cloudflare/cloudflare/cloudflaredBasic Usage
Authentication
# Login to Cloudflare
cloudflared tunnel login
 
# Verify authentication
cloudflared tunnel tokenQuick Start
# Create tunnel
cloudflared tunnel create my-tunnel
 
# Start tunnel
cloudflared tunnel run my-tunnel
 
# List tunnels
cloudflared tunnel listTunnel Management
Create and Configure
# Create new tunnel
cloudflared tunnel create tunnel-name
 
# Configure tunnel
cloudflared tunnel route dns tunnel-name subdomain.example.com
 
# Delete tunnel
cloudflared tunnel delete tunnel-nameRunning Tunnels
# Run with config file
cloudflared tunnel --config path/to/config.yml run
 
# Run with specific hostname
cloudflared tunnel --hostname example.com run
 
# Run with specific credentials
cloudflared tunnel --credentials-file /path/to/creds.json runTunnel Routes
# Add DNS route
cloudflared tunnel route dns tunnel-name hostname
 
# List routes
cloudflared tunnel route list
 
# Delete route
cloudflared tunnel route dns --overwrite-dns tunnel-name hostnameConfiguration
Config File
# config.yml
tunnel: tunnel-id
credentials-file: /path/to/credentials.json
 
ingress:
  - hostname: example.com
    service: http://localhost:8000
  - hostname: api.example.com
    service: http://localhost:3000
  - service: http_status:404Service Configuration
# HTTP service
ingress:
  - hostname: app.example.com
    service: http://localhost:8000
    originRequest:
      connectTimeout: 30s
      noTLSVerify: false
 
# TCP service
ingress:
  - hostname: ssh.example.com
    service: tcp://localhost:22Access Control
# Access policies
ingress:
  - hostname: internal.example.com
    service: http://localhost:8000
    originRequest:
      access:
        required: true
        teamName: "example-team"Access Management
Authentication Methods
# Basic authentication
ingress:
  - hostname: app.example.com
    service: http://localhost:8000
    originRequest:
      auth:
        type: basic
        credentials:
          - user: password
 
# OAuth
ingress:
  - hostname: app.example.com
    service: http://localhost:8000
    originRequest:
      auth:
        type: oauthAccess Policies
# Team access
ingress:
  - hostname: app.example.com
    service: http://localhost:8000
    originRequest:
      access:
        required: true
        teamName: ["team1", "team2"]Monitoring
Metrics
# Enable metrics
cloudflared tunnel --metrics localhost:2000 run
 
# View tunnel status
cloudflared tunnel info
 
# Check connection status
cloudflared tunnel statusLogging
# Enable debug logging
cloudflared tunnel --loglevel debug run
 
# Log to file
cloudflared tunnel --logfile /path/to/tunnel.log run
 
# JSON logging
cloudflared tunnel --json runTroubleshooting
Common Issues
- Connection Problems
# Check tunnel status
cloudflared tunnel status
 
# Verify credentials
cloudflared tunnel token
 
# Test connectivity
cloudflared tunnel diagnose- Configuration Issues
# Validate config
cloudflared tunnel ingress validate
 
# Check DNS records
cloudflared tunnel route list
 
# Test specific hostname
cloudflared tunnel diagnose --hostname example.com- Performance Issues
# Enable tracing
cloudflared tunnel --trace run
 
# Monitor metrics
cloudflared tunnel --metrics localhost:2000 runBest Practices
Security
# Secure configuration
ingress:
  - hostname: app.example.com
    service: http://localhost:8000
    originRequest:
      noTLSVerify: false
      connectTimeout: 30s
      disableChunkedEncoding: falseHigh Availability
# Replica configuration
replica: 2
retries: 5
grace_period: 30sQuick Reference
Essential Commands
# Create tunnel
cloudflared tunnel create name
 
# Run tunnel
cloudflared tunnel run name
 
# List tunnels
cloudflared tunnel list
 
# Delete tunnel
cloudflared tunnel delete nameCommon Options
--config       # Config file path
--credentials  # Credentials file
--hostname     # Tunnel hostname
--url         # Origin URL
--metrics     # Metrics address
--loglevel    # Log levelExample Configurations
Web Application
tunnel: tunnel-id
credentials-file: /path/to/creds.json
 
ingress:
  - hostname: app.example.com
    service: http://localhost:3000
    originRequest:
      connectTimeout: 30s
      noTLSVerify: false
  - service: http_status:404Multiple Services
tunnel: tunnel-id
credentials-file: /path/to/creds.json
 
ingress:
  - hostname: app.example.com
    service: http://localhost:3000
  - hostname: api.example.com
    service: http://localhost:8080
  - hostname: ssh.example.com
    service: tcp://localhost:22
  - service: http_status:404Remember:
- Regular backup of credentials
- Monitor tunnel status
- Keep configuration secure
- Use access controls
- Regular updates
- Monitor logs
For detailed information, consult the official Cloudflare documentation.