VPC Services
VPC Services are the core building block of Workers VPC. They represent specific resources in your private network that Workers can access through Cloudflare Tunnel.
You can use bindings to connect to VPC Services from Workers. Every request made to a VPC Service using its fetch function will be securely routed to the configured service in the private network.
VPC Services enforce that requests are routed to their intended service without exposing the entire network, securing your workloads and preventing server-side request forgery (SSRF).
Members must possess Connectivity Directory Bind role to bind to existing VPC Services from Workers. Creating VPC Services requires members to possess the Connectivity Directory Admin role.
A VPC Service consists of:
- Type: Currently only
httpis supported (support fortcpcoming soon) - Tunnel ID: The Cloudflare Tunnel that provides network connectivity
- Hostname or IPv4/IPv6 addresses: The hostname, or IPv4 and/or IPv6 addresses to use to route to your service from the tunnel in your private network
- Ports: HTTP and/or HTTPS port configuration (optional, defaults to 80/443)
- Resolver IPs: Optionally, a specific resolver IP can be provided -- when not provided,
cloudflaredwill direct DNS traffic to the currently configured default system resolver.
Requests are encrypted in flight until they reach your network via a tunnel, regardless of the scheme used in the URL provided to fetch. If the http scheme is used, a plaintext connection is established to the service from the tunnel.
The https scheme can be used for an encrypted connection within your network, between the tunnel and your service. When the https scheme is specified, a hostname provided to the fetch() operation is utilized as the Server Name Indication (SNI) value.
VPC Services default to allowing both http and https schemes to be used. You can provide values for only one of http_port or https_port to enforce the use of a particular scheme.
When Workers VPC is unable to establish a connection to your service, fetch() will throw an exception.
The following is an example of a VPC Service for a service using custom HTTP and HTTPS ports, and both IPv4 and IPv6 addresses. These configurations represent the expected contract of the REST API for creating a VPC Service, a type of service within the broader connectivity directory.
{ "type": "http", "name": "human-readable-name",
// Port configuration (optional - defaults to 80/443) "http_port": 80, "https_port": 443,
// Host configuration "host": { "ipv4": "10.0.0.1", "ipv6": "fe80::", "network": { "tunnel_id": "0191dce4-9ab4-7fce-b660-8e5dec5172da" } }}The following is an example of a VPC Service for a service using custom HTTP and HTTPS ports as well, using a hostname. Note that since we are using a hostname, we must provide our service with a resolver_network that optionally has resolver_ips.
{ "type": "http", "name": "human-readable-name",
// Port configuration (optional - defaults to 80/443) "http_port": 80, "https_port": 443,
// Hostname Host (with DNS resolver) "host": { "hostname": "example.com", "resolver_network": { "tunnel_id": "0191dce4-9ab4-7fce-b660-8e5dec5172da", "resolver_ips": ["10.0.0.1"] // Optional } }}Once you have created a VPC Service, you can bind it to your Worker:
{ "$schema": "./node_modules/wrangler/config-schema.json", "name": "my-worker", "main": "src/index.js", "vpc_services": [ { "binding": "PRIVATE_API", "service_id": "e6a0817c-79c5-40ca-9776-a1c019defe70", "remote": true } ]}name = "my-worker"main = "src/index.js"
[[vpc_services]]binding = "PRIVATE_API"service_id = "e6a0817c-79c5-40ca-9776-a1c019defe70"remote = true # When true, utilizes [remote bindings](/workers/development-testing/#remote-bindings) to allow access to the VPC Service during local development.You can have multiple VPC service bindings:
{ "$schema": "./node_modules/wrangler/config-schema.json", "vpc_services": [ { "binding": "PRIVATE_API", "service_id": "daf43e8c-a81a-4242-9912-4a2ebe4fdd79", "remote": true }, { "binding": "PRIVATE_DATABASE", "service_id": "453b6067-1327-420d-89b3-2b6ad16e6551", "remote": true }, { "binding": "INTERNAL_CACHE", "service_id": "6c39b574-237e-49f4-852a-cea5a93ed8f9", "remote": true } ]}[[vpc_services]]binding = "PRIVATE_API"service_id = "daf43e8c-a81a-4242-9912-4a2ebe4fdd79"remote = true
[[vpc_services]]binding = "PRIVATE_DATABASE"service_id = "453b6067-1327-420d-89b3-2b6ad16e6551"remote = true
[[vpc_services]]binding = "INTERNAL_CACHE"service_id = "6c39b574-237e-49f4-852a-cea5a93ed8f9"remote = true- Set up Cloudflare Tunnel for your environment
- Learn about the Service Binding API
- Refer to examples of common use cases
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