Environments
Environments are different contexts that your code runs in. Cloudflare Developer Platform allows you to create and manage different environments. Through environments, you can deploy the same project to multiple places under multiple names.
To specify different D1 databases for different environments, use the following syntax in your Wrangler file:
{ "env": { "staging": { "d1_databases": [ { "binding": "<BINDING_NAME_1>", "database_name": "<DATABASE_NAME_1>", "database_id": "<UUID1>" } ] }, "production": { "d1_databases": [ { "binding": "<BINDING_NAME_2>", "database_name": "<DATABASE_NAME_2>", "database_id": "<UUID2>" } ] } }}# This is a staging environment[env.staging]d1_databases = [ { binding = "<BINDING_NAME_1>", database_name = "<DATABASE_NAME_1>", database_id = "<UUID1>" },]
# This is a production environment[env.production]d1_databases = [ { binding = "<BINDING_NAME_2>", database_name = "<DATABASE_NAME_2>", database_id = "<UUID2>" },]In the code above, the staging environment is using a different database (DATABASE_NAME_1) than the production environment (DATABASE_NAME_2).
If you need to specify different D1 databases for different environments, your Wrangler configuration file may contain bindings that resemble the following:
{ "production": { "d1_databases": [ { "binding": "DB", "database_name": "DATABASE_NAME", "database_id": "DATABASE_ID" } ] }}[[production.d1_databases]]binding = "DB"database_name = "DATABASE_NAME"database_id = "DATABASE_ID"In the above configuration:
[[production.d1_databases]]creates an objectproductionwith a propertyd1_databases, whered1_databasesis an array of objects, since you can create multiple D1 bindings in case you have more than one database.- Any property below the line in the form
<key> = <value>is a property of an object within thed1_databasesarray.
Therefore, the above binding is equivalent to:
{ "production": { "d1_databases": [ { "binding": "DB", "database_name": "DATABASE_NAME", "database_id": "DATABASE_ID" } ] }}{ "env": { "staging": { "d1_databases": [ { "binding": "BINDING_NAME_1", "database_name": "DATABASE_NAME_1", "database_id": "UUID_1" } ] }, "production": { "d1_databases": [ { "binding": "BINDING_NAME_2", "database_name": "DATABASE_NAME_2", "database_id": "UUID_2" } ] } }}[[env.staging.d1_databases]]binding = "BINDING_NAME_1"database_name = "DATABASE_NAME_1"database_id = "UUID_1"
[[env.production.d1_databases]]binding = "BINDING_NAME_2"database_name = "DATABASE_NAME_2"database_id = "UUID_2"The above is equivalent to the following structure in JSON:
{ "env": { "production": { "d1_databases": [ { "binding": "BINDING_NAME_2", "database_id": "UUID_2", "database_name": "DATABASE_NAME_2" } ] }, "staging": { "d1_databases": [ { "binding": "BINDING_NAME_1", "database_id": "UUID_1", "database_name": "DATABASE_NAME_1" } ] } }}Was this helpful?
- Resources
- API
- New to Cloudflare?
- Products
- 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