Tunnel MCP sedang dalam pratinjau riset. Minta akses untuk mencobanya.
Permintaan melalui tunnel dapat gagal di salah satu dari tiga lapisan; diagnosis secara berurutan: koneksi keluar ke tunnel edge, inner TLS dari Anthropic ke proxy Anda, lalu perutean dan validasi IP menuju server MCP upstream.
| Gejala | Penyebab | Perbaikan |
|---|---|---|
| Tunnel tidak muncul di pemilih + MCP Server pada agen | Pemilih hanya menampilkan tunnel di workspace sesi yang memiliki setidaknya satu sertifikat aktif. | Daftarkan sertifikat CA, atau buka sesi di workspace tempat tunnel dibuat. |
Pemanggil melihat HTTP 500; cloudflared mencatat log No ingress rules were defined | cloudflared tidak memiliki target lokal. | Tambahkan --url http://localhost:8080 dan network_mode: "service:mcp-proxy" ke layanan cloudflared. |
Proxy mencatat log no route for host | tunnel_domain tidak cocok dengan domain yang ditetapkan, atau config.yaml diedit tanpa memulai ulang. | Atur tunnel_domain ke domain persis yang ditampilkan di halaman detail tunnel, lalu mulai ulang proxy (docker compose restart mcp-proxy). |
Proxy mencatat log IP validation failed: <ip> is not a private address | Server MCP upstream me-resolve ke alamat di luar RFC1918. | Lihat Validasi IP upstream. |
Proxy keluar dengan cannot unmarshal !!seq into map[string]string | routes berupa daftar YAML. | Gunakan routes: { name: http://host:port }. |
Proxy keluar dengan open /data/tls.key: permission denied | Kunci memiliki izin 0600; kontainer proxy berjalan sebagai non-root. | chmod 644 data/tls.key. |
curl https://<proxy>:8080 gagal dengan wrong version number | Ini memang diharapkan; listener adalah WebSocket plaintext. TLS terjadi di dalam stream WS. | Verifikasi melalui Managed Agent atau Messages API sebagai gantinya. |
Bagian berikut membahas kegagalan yang memerlukan lebih dari sekadar perbaikan satu baris.
Alur OAuth gagal ketika allowlist IP sumber pada server otorisasi Anda memblokir backend Anthropic untuk mencapai /token, /register, dan endpoint discovery. Jika Anda tidak ingin menambahkan rentang egress Anthropic ke allowlist, Anda dapat merutekan panggilan OAuth backend-ke-backend melalui tunnel sambil tetap mempertahankan endpoint /authorize yang menghadap browser pada hostname publik Anda yang sudah ada.
Tambahkan rute proxy untuk server otorisasi
routes:
mcp: http://your-mcp-server:8080
auth: http://your-auth-server:8080Mulai ulang proxy setelah mengedit routes (docker compose restart mcp-proxy, atau helm upgrade).
Sajikan metadata discovery dengan endpoint terpisah
Respons /.well-known/oauth-authorization-server dari server otorisasi Anda harus mengarahkan authorization_endpoint ke hostname Anda yang sudah ada dalam allowlist, dan semua endpoint lainnya ke tunnel:
{
"issuer": "https://auth.<tunnel-domain>",
"authorization_endpoint": "https://<your-allowlisted-host>/authorize",
"token_endpoint": "https://auth.<tunnel-domain>/token",
"registration_endpoint": "https://auth.<tunnel-domain>/register",
"code_challenge_methods_supported": ["S256"]
}Arahkan server MCP ke issuer tunnel
Respons /.well-known/oauth-protected-resource dari server MCP Anda harus mereferensikan hostname tunnel sebagai server otorisasinya:
{
"resource": "https://mcp.<tunnel-domain>",
"authorization_servers": ["https://auth.<tunnel-domain>"]
}Dengan konfigurasi ini, browser pengguna mengakses /authorize pada hostname Anda yang sudah ada (yang sudah diizinkan oleh allowlist Anda), sementara backend Anthropic mencapai /token, /register, dan dokumen discovery melalui tunnel.
Komponen setup (Helm Job atau layanan setup Compose) melakukan autentikasi ke Tunnels API dengan menukar JWT OIDC melalui aturan federasi Anda. Ketika pertukaran gagal, lihat Memecahkan masalah pertukaran yang gagal di referensi Workload Identity Federation; mode kegagalannya (subject, audience, issuer, JWKS, lifetime) sama.
Penyebab khusus tunnel:
api.anthropic.com (tanpa skema). Jika audience aturan Anda adalah https://api.anthropic.com, atur api.wif.audience agar cocok.403 dari Tunnels API setelah pertukaran berhasil berarti scope aturan tidak menyertakan org:manage_tunnels, atau service account aturan bukan anggota workspace tunnel. Atur scope dan tambahkan service account ke workspace.Pada Helm, komponen setup berjalan sebagai Job hook pre-install. Saat gagal, Job dibiarkan tetap ada untuk inspeksi (kubectl logs job/mcp-tunnel-setup -n mcp-tunnel). Helm tidak mengelola resource hook, jadi hapus terlebih dahulu sebelum mencoba lagi:
helm uninstall mcp-tunnel -n mcp-tunnel
kubectl -n mcp-tunnel delete job mcp-tunnel-setupPeriksa log cloudflared terlebih dahulu. Penyebab umum:
TUNNEL_TOKEN hilang, kedaluwarsa, atau disalin dengan tidak benar.cloudflared juga dapat mencatat peringatan tentang ukuran buffer penerimaan UDP; ini adalah petunjuk tuning QUIC, bukan error.
Ketika Anthropic menolak sertifikat proxy selama inner TLS, proxy mencatat log tls handshake failed. Verifikasi bahwa:
*.<tunnel-domain>.Lihat persyaratan sertifikat untuk aturan validasi lengkap.
Untuk perlindungan SSRF, proxy secara default hanya menghubungi alamat dalam rentang privat RFC1918 (10.0.0.0/8, 172.16.0.0/12, 192.168.0.0/16). Hanya IPv4 yang didukung untuk koneksi proxy-ke-upstream. (Rentang egress cloudflared-ke-edge di Persyaratan jaringan adalah hop yang berbeda.)
Jika proxy mencatat log IP validation failed: <ip> is not a private address, hostname upstream me-resolve ke alamat di luar rentang tersebut. Pada Kubernetes, beberapa distribusi terkelola mengalokasikan Service CIDR di luar RFC1918; jika kubectl get svc kubernetes -n default -o jsonpath='{.spec.clusterIP}' mengembalikan alamat di luar rentang privat, cari Service CIDR cluster Anda dan tambahkan.
Jika alamat tersebut sah, tambahkan CIDR tersempit yang mencakupnya ke upstream.allowed_ips. Mengatur allowed_ips akan menggantikan default RFC1918 alih-alih memperluasnya, jadi sertakan rentang privat yang digunakan server MCP upstream Anda lainnya:
upstream:
allowed_ips:
- 10.0.0.0/8
- 172.16.0.0/12
- 192.168.0.0/16
- 127.0.0.0/8 # loopback, for local testing onlyHindari 0.0.0.0/0 di luar pengujian lokal; ini menonaktifkan perlindungan SSRF sepenuhnya.
Was this page helpful?