4.3 KiB
4.3 KiB
Workers Configuration
wrangler.jsonc (Recommended)
{
"$schema": "./node_modules/wrangler/config-schema.json",
"name": "my-worker",
"main": "src/index.ts",
"compatibility_date": "2025-01-01", // Use current date for new projects
// Bindings (non-inheritable)
"vars": { "ENVIRONMENT": "production" },
"kv_namespaces": [{ "binding": "MY_KV", "id": "abc123" }],
"r2_buckets": [{ "binding": "MY_BUCKET", "bucket_name": "my-bucket" }],
"d1_databases": [{ "binding": "DB", "database_name": "my-db", "database_id": "xyz789" }],
// Environments
"env": {
"staging": {
"vars": { "ENVIRONMENT": "staging" },
"kv_namespaces": [{ "binding": "MY_KV", "id": "staging-id" }]
}
}
}
Configuration Rules
Inheritable: name, main, compatibility_date, routes, workers_dev
Non-inheritable: All bindings (vars, kv_namespaces, r2_buckets, etc.)
Top-level only: migrations, keep_vars, send_metrics
ALWAYS set compatibility_date to current date for new projects
Bindings
{
// Environment variables - access via env.VAR_NAME
"vars": { "ENVIRONMENT": "production" },
// KV (key-value storage)
"kv_namespaces": [{ "binding": "MY_KV", "id": "abc123" }],
// R2 (object storage)
"r2_buckets": [{ "binding": "MY_BUCKET", "bucket_name": "my-bucket" }],
// D1 (SQL database)
"d1_databases": [{ "binding": "DB", "database_name": "my-db", "database_id": "xyz789" }],
// Durable Objects (stateful coordination)
"durable_objects": {
"bindings": [{ "name": "COUNTER", "class_name": "Counter" }]
},
// Queues (message queues)
"queues": {
"producers": [{ "binding": "MY_QUEUE", "queue": "my-queue" }],
"consumers": [{ "queue": "my-queue", "max_batch_size": 10 }]
},
// Service bindings (worker-to-worker RPC)
"services": [{ "binding": "SERVICE_B", "service": "service-b" }],
// Analytics Engine
"analytics_engine_datasets": [{ "binding": "ANALYTICS" }]
}
Secrets
Set via CLI (never in config):
npx wrangler secret put API_KEY
Access: env.API_KEY
Automatic Provisioning (Beta)
Bindings without IDs are auto-created:
{ "kv_namespaces": [{ "binding": "MY_KV" }] } // ID added on deploy
Routes & Triggers
{
"routes": [
{ "pattern": "example.com/*", "zone_name": "example.com" }
],
"triggers": {
"crons": ["0 */6 * * *"] // Every 6 hours
}
}
TypeScript Setup
Automatic Type Generation (Recommended)
npm install -D @cloudflare/workers-types
npx wrangler types # Generates .wrangler/types/runtime.d.ts from wrangler.jsonc
tsconfig.json:
{
"compilerOptions": {
"target": "ES2022",
"lib": ["ES2022"],
"types": ["@cloudflare/workers-types"]
},
"include": [".wrangler/types/**/*.ts", "src/**/*"]
}
Import generated types:
import type { Env } from './.wrangler/types/runtime';
export default {
async fetch(request: Request, env: Env, ctx: ExecutionContext): Promise<Response> {
await env.MY_KV.get('key'); // Fully typed, autocomplete works
return new Response('OK');
},
};
Re-run npx wrangler types after changing bindings in wrangler.jsonc
Manual Type Definition (Legacy)
interface Env {
MY_KV: KVNamespace;
DB: D1Database;
API_KEY: string;
}
Advanced Options
{
// Auto-locate compute near data sources
"placement": { "mode": "smart" },
// Enable Node.js built-ins (Buffer, process, path, etc.)
"compatibility_flags": ["nodejs_compat_v2"],
// Observability (10% sampling)
"observability": { "enabled": true, "head_sampling_rate": 0.1 }
}
Node.js Compatibility
nodejs_compat_v2 enables:
Buffer,process.env,path,stream- CommonJS
require()for Node modules node:imports (e.g.,import { Buffer } from 'node:buffer')
Note: Adds ~1-2ms cold start overhead. Use Workers APIs (R2, KV) when possible
Deployment Commands
npx wrangler deploy # Production
npx wrangler deploy --env staging
npx wrangler deploy --dry-run # Validate only