Durable Objects migrations
A migration is a mapping process from a class name to a runtime state. This process communicates the changes to the Workers runtime and provides the runtime with instructions on how to deal with those changes.
To apply a migration, you need to:
- Edit your wrangler.toml / wrangler.jsonfile, as explained below.
- Re-deploy your Worker using npx wrangler deploy.
You must initiate a migration process when you:
- Create a new Durable Object class.
- Rename a Durable Object class.
- Delete a Durable Object class.
- Transfer an existing Durable Objects class.
The most common migration performed is a new class migration, which informs the runtime that a new Durable Object class is being uploaded. This is also the migration you need when creating your first Durable Object class.
To apply a Create migration:
- 
Add the following lines to your wrangler.toml / wrangler.jsonfile:{"migrations": [{"tag": "<v1>","new_sqlite_classes": ["<NewDurableObjectClass>"]}]}[[migrations]]tag = "<v1>" # Migration identifier. This should be unique for each migration entrynew_sqlite_classes = ["<NewDurableObjectClass>"] # Array of new classes# For SQLite storage backend use new_sqlite_classes=["<NewDurableObjectClass>"] insteadThe Create migration contains: - A tagto identify the migration.
- The array new_sqlite_classes, which contains the new Durable Object class.
 
- A 
- 
Ensure you reference the correct name of the Durable Object class in your Worker code. 
- 
Deploy the Worker. 
Create migration example
 To create a new Durable Object binding DURABLE_OBJECT_A, your wrangler.toml / wrangler.json file should look like the following:
{  "durable_objects": {    "bindings": [      {        "name": "DURABLE_OBJECT_A",        "class_name": "DurableObjectAClass"      }    ]  },  "migrations": [    {      "tag": "v1",      "new_sqlite_classes": [        "DurableObjectAClass"      ]    }  ]}# Creating a new Durable Object class[[durable_objects.bindings]]name = "DURABLE_OBJECT_A"class_name = "DurableObjectAClass"
# Add the lines below for a Create migration.
[[migrations]]tag = "v1"new_sqlite_classes = ["DurableObjectAClass"]Use new_classes on the migration in your Worker's Wrangler file to create a Durable Object class with the key-value storage backend:
{  "migrations": [    {      "tag": "v1",      "new_classes": [        "MyDurableObject"      ]    }  ]}[[migrations]]tag = "v1" # Should be unique for each entrynew_classes = ["MyDurableObject"] # Array of new classesRunning a Delete migration will delete all Durable Objects associated with the deleted class, including all of their stored data.
- Do not run a Delete migration on a class without first ensuring that you are not relying on the Durable Objects within that Worker anymore, that is, first remove the binding from the Worker.
- Copy any important data to some other location before deleting.
- You do not have to run a Delete migration on a class that was renamed or transferred.
To apply a Delete migration:
- 
Remove the binding for the class you wish to delete from the wrangler.toml / wrangler.jsonfile.
- 
Remove references for the class you wish to delete from your Worker code. 
- 
Add the following lines to your wrangler.toml / wrangler.jsonfile.{"migrations": [{"tag": "<v2>","deleted_classes": ["<ClassToDelete>"]}]}[[migrations]]tag = "<v2>" # Migration identifier. This should be unique for each migration entrydeleted_classes = ["<ClassToDelete>"] # Array of deleted class namesThe Delete migration contains: - A tagto identify the migration.
- The array deleted_classes, which contains the deleted Durable Object classes.
 
- A 
- 
Deploy the Worker. 
Delete migration example
 To delete a Durable Object binding DEPRECATED_OBJECT, your wrangler.toml / wrangler.json file should look like the following:
{  "migrations": [    {      "tag": "v3",      "deleted_classes": [        "DeprecatedObjectClass"      ]    }  ]}# Remove the binding for the DeprecatedObjectClass DO#[[durable_objects.bindings]]#name = "DEPRECATED_OBJECT"#class_name = "DeprecatedObjectClass"
[[migrations]]tag = "v3" # Should be unique for each entrydeleted_classes = ["DeprecatedObjectClass"] # Array of deleted classesRename migrations are used to transfer stored Durable Objects between two Durable Object classes in the same Worker code file.
To apply a Rename migration:
- 
Update the previous class name to the new class name by editing your wrangler.toml / wrangler.jsonfile in the following way:{"durable_objects": {"bindings": [{"name": "<MY_DURABLE_OBJECT>","class_name": "<UpdatedDurableObject>"}]},"migrations": [{"tag": "<v3>","renamed_classes": [{"from": "<OldDurableObject>","to": "<UpdatedDurableObject>"}]}]}[[durable_objects.bindings]]name = "<MY_DURABLE_OBJECT>"class_name = "<UpdatedDurableObject>" # Update the class name to the new class name[[migrations]]tag = "<v3>" # Migration identifier. This should be unique for each migration entryrenamed_classes = [{from = "<OldDurableObject>", to = "<UpdatedDurableObject>" }] # Array of rename directivesThe Rename migration contains: - A tagto identify the migration.
- The renamed_classesarray, which contains objects withfromandtoproperties.- fromproperty is the old Durable Object class name.
- toproperty is the renamed Durable Object class name.
 
 
- A 
- 
Reference the new Durable Object class name in your Worker code. 
- 
Deploy the Worker. 
Rename migration example
 To rename a Durable Object class, from OldName to UpdatedName, your wrangler.toml / wrangler.json file should look like the following:
{  "durable_objects": {    "bindings": [      {        "name": "MY_DURABLE_OBJECT",        "class_name": "UpdatedName"      }    ]  },  "migrations": [    {      "tag": "v3",      "renamed_classes": [        {          "from": "OldName",          "to": "UpdatedName"        }      ]    }  ]}# Before deleting the `DeprecatedClass` remove the binding for the `DeprecatedClass`.# Update the binding for the `DurableObjectExample` to the new class name `UpdatedName`.[[durable_objects.bindings]]name = "MY_DURABLE_OBJECT"class_name = "UpdatedName"
# Renaming classes[[migrations]]tag = "v3"renamed_classes = [{from = "OldName", to = "UpdatedName" }] # Array of rename directivesTransfer migrations are used to transfer stored Durable Objects between two Durable Object classes in different Worker code files.
If you want to transfer stored Durable Objects between two Durable Object classes in the same Worker code file, use Rename migrations instead.
To apply a Transfer migration:
- 
Edit your wrangler.toml / wrangler.jsonfile in the following way:{"durable_objects": {"bindings": [{"name": "<MY_DURABLE_OBJECT>","class_name": "<DestinationDurableObjectClass>"}]},"migrations": [{"tag": "<v4>","transferred_classes": [{"from": "<SourceDurableObjectClass>","from_script": "<SourceWorkerScript>","to": "<DestinationDurableObjectClass>"}]}]}[[durable_objects.bindings]]name = "<MY_DURABLE_OBJECT>"class_name = "<DestinationDurableObjectClass>"[[migrations]]tag = "<v4>" # Migration identifier. This should be unique for each migration entrytransferred_classes = [{from = "<SourceDurableObjectClass>", from_script = "<SourceWorkerScript>", to = "<DestinationDurableObjectClass>" }]The Transfer migration contains: - A tagto identify the migration.
- The transferred_classarray, which contains objects withfrom,from_script, andtoproperties.- fromproperty is the name of the source Durable Object class.
- from_scriptproperty is the name of the source Worker script.
- toproperty is the name of the destination Durable Object class.
 
 
- A 
- 
Ensure you reference the name of the new, destination Durable Object class in your Worker code. 
- 
Deploy the Worker. 
Transfer migration example
 You can transfer stored Durable Objects from DurableObjectExample to TransferredClass from a Worker script named OldWorkerScript. The configuration of the wrangler.toml / wrangler.json file for your new Worker code (destination Worker code) would look like this:
{  "durable_objects": {    "bindings": [      {        "name": "MY_DURABLE_OBJECT",        "class_name": "TransferredClass"      }    ]  },  "migrations": [    {      "tag": "v4",      "transferred_classes": [        {          "from": "DurableObjectExample",          "from_script": "OldWorkerScript",          "to": "TransferredClass"        }      ]    }  ]}# destination worker[[durable_objects.bindings]]name = "MY_DURABLE_OBJECT"class_name = "TransferredClass"
# Transferring class
[[migrations]]tag = "v4"transferred_classes = [{from = "DurableObjectExample", from_script = "OldWorkerScript", to = "TransferredClass" }]- 
Migrations are performed through the [[migrations]]configurations key in yourwrangler.tomlfile ormigrationkey in yourwrangler.jsonfile.
- 
Migrations require a migration tag, which is defined by the tagproperty in each migration entry.
- 
Migration tags are treated like unique names and are used to determine which migrations have already been applied. Once a given Worker code has a migration tag set on it, all future Worker code deployments must include a migration tag. 
- 
The migration list is an ordered array of tables, specified as a key in your Wrangler configuration file. 
- 
You can define the migration for each environment, as well as at the top level. - Top-level migration is specified at the top-level migrationskey in the Wrangler configuration file.
- Environment-level migration is specified by a migrationskey inside theenvkey of the Wrangler configuration file ([env.<environment_name>.migrations]).- Example Wrangler file:
 wrangler.jsonc {// top-level default migrations"migrations": [{ ... }],"env": {"staging": {// migration override for staging"migrations": [{...}]}}}
- If a migration is only specified at the top-level, but not at the environment-level, the environment will inherit the top-level migration.
- Migrations at at the environment-level override migrations at the top level.
 
- Top-level migration is specified at the top-level 
- 
All migrations are applied at deployment. Each migration can only be applied once per environment. 
- 
Each migration in the list can have multiple directives, and multiple migrations can be specified as your project grows in complexity. 
You cannot enable a SQLite storage backend on an existing, deployed Durable Object class, so setting new_sqlite_classes on later migrations will fail with an error. Automatic migration of deployed classes from their key-value storage backend to SQLite storage backend will be available in the future.
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