Commands
Complete list of all commands available for wrangler β, the Workers CLI.
Scaffold a Cloudflare Workers project from a public GitHub repository.
wrangler generate [$NAME] [$TEMPLATE] [--type=$TYPE] [--site]Default values indicated by =value.
- 
$NAME=worker optional- The name of the Workers project. This is both the directory name and nameproperty in the generated Wrangler configuration file.
 
- The name of the Workers project. This is both the directory name and 
- 
$TEMPLATE=https://github.com/cloudflare/worker-template β optional- The GitHub URL of the repository to use as the template β for generating the project.
 
- 
--type=$TYPE=webpack optional- The type of project; one of webpack,javascript, orrust.
 
- The type of project; one of 
- 
--siteoptional- When defined, the default $TEMPLATEvalue is changed tocloudflare/workers-sdk/templates/worker-sitesβ. This scaffolds a Workers Site project.
 
- When defined, the default 
Create a skeleton Wrangler configuration file in an existing directory. This command can be used as an alternative to generate if you prefer to clone a template repository yourself or you already have a JavaScript project and would like to use Wrangler.
wrangler init [$NAME] [--type=$TYPE] [--site]Default values indicated by =value.
- 
$NAME=(Name of working directory) optional- The name of the Workers project. This is both the directory name and nameproperty in the generated Wrangler configuration file.
 
- The name of the Workers project. This is both the directory name and 
- 
--type=$TYPE=webpack optional- The type of project; one of webpack,javascript, orrust.
 
- The type of project; one of 
- 
--siteoptional- When defined, the default $TEMPLATEvalue is changed tocloudflare/workers-sdk/templates/worker-sitesβ. This scaffolds a Workers Site project.
 
- When defined, the default 
Build your project (if applicable). This command looks at your Wrangler file and reacts to the "type" value specified.
When using type = "webpack", Wrangler will build the Worker using its internal webpack installation. When using type = "javascript" , the build.command, if defined, will run.
wrangler build [--env $ENVIRONMENT_NAME]- --envoptional- If defined, Wrangler will load the matching environment's configuration before building. Refer to Environments for more information.
 
Authorize Wrangler with your Cloudflare account. This will open a login page in your browser and request your account access permissions. This command is the alternative to wrangler config and it uses OAuth tokens.
wrangler login [--scopes-list] [--scopes $SCOPES]All of the arguments and flags to this command are optional:
- --scopes-listoptional- List all the available OAuth scopes with descriptions.
 
- --scopes $SCOPESoptional- Allows to choose your set of OAuth scopes. The set of scopes must be entered in a whitespace-separated list,
for example, wrangler login --scopes account:read user:read.
 
- Allows to choose your set of OAuth scopes. The set of scopes must be entered in a whitespace-separated list,
for example, 
wrangler login uses all the available scopes by default if no flags are provided.
Remove Wrangler's authorization for accessing your account. This command will invalidate your current OAuth token and delete the configuration file, if present.
wrangler logoutThis command only invalidates OAuth tokens acquired through the wrangler login command. However, it will try to delete the configuration file regardless of your authorization method.
If you wish to delete your API token, log in to the Cloudflare dashboard and go to Overview > Get your API token in the right side menu > select the three-dot menu on your Wrangler token and select Delete if you wish to delete your API token.
Configure Wrangler so that it may acquire a Cloudflare API Token or Global API key, instead of OAuth tokens, in order to access and manage account resources.
wrangler config [--api-key]- --api-keyoptional- To provide your email and global API key instead of a token. (This is not recommended for security reasons.)
 
You can also use environment variables to authenticate, or wrangler login to authorize with OAuth tokens.
Publish your Worker to Cloudflare. Several keys in your Wrangler file determine whether you are publishing to a *.workers.dev subdomain or a custom domain. However, custom domains must be proxied (orange-clouded) through Cloudflare. Refer to the Get started guide for more information.
wrangler publish [--env $ENVIRONMENT_NAME]- --envoptional- If defined, Wrangler will load the matching environment's configuration before building and deploying. Refer to Environments for more information.
 
To use this command, the following fields are required in your Wrangler file:
- 
namestring- The name of the Workers project. This is both the directory name and nameproperty in the generated Wrangler configuration file.
 
- The name of the Workers project. This is both the directory name and 
- 
typestring- The type of project; one of webpack,javascript, orrust.
 
- The type of project; one of 
- 
account_idstring- The Cloudflare account ID. This can be found in the Cloudflare dashboard, for example, account_id = "a655bacaf2b4cad0e2b51c5236a6b974".
 
- The Cloudflare account ID. This can be found in the Cloudflare dashboard, for example, 
You can publish to <your-worker>.<your-subdomain>.workers.dev β or to a custom domain.
When you publish changes to an existing Worker script, all new requests will automatically route to the updated version of the Worker without downtime. Any inflight requests will continue running on the previous version until completion. Once all inflight requests have finished complete, the previous Worker version will be purged and will no longer handle requests.
To publish to *.workers.dev β, you will first need to have a subdomain registered. You can register a subdomain by executing the wrangler subdomain command.
After you have registered a subdomain, add workers_dev to your Wrangler file.
- workers_devbool- When true, indicates that the Worker should be deployed to a*.workers.devdomain.
 
- When 
To publish to your own domain, specify these three fields in your Wrangler file.
- 
zone_idstring- The Cloudflare zone ID, for example, zone_id = "b6558acaf2b4cad1f2b51c5236a6b972", which can be found in the Cloudflare dashboard β.
 
- The Cloudflare zone ID, for example, 
- 
routestring- The route you would like to publish to, for example, route = "example.com/my-worker/*".
 
- The route you would like to publish to, for example, 
- 
routesArray- The routes you would like to publish to, for example, routes = ["example.com/foo/*", example.com/bar/*].
 
- The routes you would like to publish to, for example, 
To publish your code to multiple domains, refer to the documentation for environments.
wrangler dev is a command that establishes a connection between localhost and a global network server that operates your Worker in development. A cloudflared tunnel forwards all requests to the global network server, which continuously updates as your Worker code changes. This allows full access to Workers KV, Durable Objects and other Cloudflare developer platform products. The dev command is a way to test your Worker while developing.
wrangler dev [--env $ENVIRONMENT_NAME] [--ip <ip>] [--port <port>] [--host <host>] [--local-protocol <http|https>] [--upstream-protocol <http|https>]- 
--envoptional- If defined, Wrangler will load the matching environment's configuration. Refer to Environments for more information.
 
- 
--ipoptional- The IP to listen on, defaults to 127.0.0.1.
 
- The IP to listen on, defaults to 
- 
--portoptional- The port to listen on, defaults to 8787.
 
- The port to listen on, defaults to 
- 
--hostoptional- The host to forward requests to, defaults to the zone of the project or to tutorial.cloudflareworkers.comif unauthenticated.
 
- The host to forward requests to, defaults to the zone of the project or to 
- 
--local-protocoloptional- The protocol to listen to requests on, defaults to http.
 
- The protocol to listen to requests on, defaults to 
- 
--upstream-protocoloptional- The protocol to forward requests to host on, defaults to https.
 
- The protocol to forward requests to host on, defaults to 
These arguments can also be set in your Wrangler file. Refer to the wrangler dev configuration documentation for more information.
You should run wrangler dev from your Worker directory. Wrangler will run a local server accepting requests, executing your Worker, and forwarding them to a host. If you want to use another host other than your zone or tutorials.cloudflare.com, you can specify with --host example.com.
wrangler devπ  JavaScript project found. Skipping unnecessary build!π  watching "./"π  Listening on http://127.0.0.1:8787With wrangler dev running, you can send HTTP requests to localhost:8787 and your Worker should execute as expected. You will also see console.log messages and exceptions appearing in your terminal. If either of these things do not happen, or you think the output is incorrect, file an issue β.
Start a session to livestream logs from a deployed Worker.
wrangler tail [--format $FORMAT] [--status $STATUS] [OPTIONS]- --format $FORMATjson|pretty- The format of the log entries.
 
- --status $STATUS- Filter by invocation status [possible values: ok,error,canceled].
 
- Filter by invocation status [possible values: 
- --header $HEADER- Filter by HTTP header.
 
- --method $METHOD- Filter by HTTP method.
 
- --sampling-rate $RATE- Add a percentage of requests to log sampling rate.
 
- --search $SEARCH- Filter by a text match in console.logmessages.
 
- Filter by a text match in 
After starting wrangler tail in a directory with a project, you will receive a live feed of console and exception logs for each request your Worker receives.
Like all Wrangler commands, run wrangler tail from your Workerβs root directory (the directory with your Wrangler file).
Preview your project using the Cloudflare Workers preview service β.
wrangler preview [--watch] [--env $ENVIRONMENT_NAME] [ --url $URL] [$METHOD] [$BODY]Default values indicated by =value.
- 
--env $ENVIRONMENT_NAMEoptional- If defined, Wrangler will load the matching environment's configuration. Refer to Environments for more information.
 
- 
--watchrecommended- When enabled, any changes to the Worker project will continually update the preview service with the newest version of your project. By default, wrangler previewwill only bundle your project a single time.
 
- When enabled, any changes to the Worker project will continually update the preview service with the newest version of your project. By default, 
- 
$METHOD="GET" optional- The type of request to preview your Worker with (GET,POST).
 
- The type of request to preview your Worker with (
- 
$BODY="Null" optional- The body string to post to your preview Worker request. For example, wrangler preview post hello=hello.
 
- The body string to post to your preview Worker request. For example, 
If you are using kv_namespaces with wrangler preview, you will need to specify a preview_id in your Wrangler file before you can start the session. This is so that you do not accidentally write changes to your production namespace while you are developing. You may make preview_id equal to id if you would like to preview with your production namespace, but you should ensure that you are not writing values to KV that would break your production Worker.
To create a preview_id run:
wrangler kv:namespace create --preview "NAMESPACE"WSL is a Linux environment, so Wrangler attempts to invoke xdg-open to open your browser. To make wrangler preview work with WSL, you should set your $BROWSER to the path of your browser binary:
export BROWSER="/mnt/c/tools/firefox.exe"wrangler previewSpaces in filepaths are not common in Linux, and some programs like xdg-open will break on paths with spaces β. You can work around this by linking the binary to your /usr/local/bin:
ln -s "/mnt/c/Program Files/Mozilla Firefox/firefox.exe" firefoxexport BROWSER=firefoxAnother option is to install wsl-open β and set the $BROWSER env variable to wsl-open via wsl-open -w. This ensures that xdg-open uses wsl-open when it attempts to open your browser.
If you are using WSL 2, you will need to install wsl-open following their standalone method β rather than through npm. This is because their npm package has not yet been updated with WSL 2 support.
List or delete a route associated with a domain:
wrangler route list [--env $ENVIRONMENT_NAME]Default values indicated by =value.
- --env $ENVIRONMENT_NAMEoptional- If defined, the changes will only apply to the specified environment. Refer to Environments for more information.
 
This command will forward the JSON response from the List Routes API. Each object within the JSON list will include the route id, route pattern, and the assigned Worker name for the route. Piping this through a tool such as jq will render the output nicely.
wrangler route delete $ID [--env $ENVIRONMENT_NAME]Default values indicated by =value.
- 
$IDrequired- The hash of the route ID to delete.
 
- 
--env $ENVIRONMENT_NAMEoptional- If defined, the changes will only apply to the specified environment. Refer to Environments for more information.
 
Create or change your *.workers.dev β subdomain.
wrangler subdomain <name>Interact with your secrets.
Create or replace a secret.
wrangler secret put <name> --env ENVIRONMENT_NAMEEnter the secret text you would like assigned to the variable name on the Worker named my-worker-ENVIRONMENT_NAME:You will be prompted to input the secret's value. This command can receive piped input, so the following example is also possible:
echo "-----BEGIN PRIVATE KEY-----\nM...==\n-----END PRIVATE KEY-----\n" | wrangler secret put PRIVATE_KEY- 
name- The variable name to be accessible in the script.
 
- 
--env $ENVIRONMENT_NAMEoptional- If defined, the changes will only apply to the specified environment. Refer to Environments for more information.
 
Delete a secret from a specific script.
wrangler secret delete <name> --env ENVIRONMENT_NAME- 
name- The variable name to be accessible in the script.
 
- 
--env $ENVIRONMENT_NAMEoptional- If defined, the changes will only apply to the specified environment. Refer to Environments for more information.
 
List all the secret names bound to a specific script.
wrangler secret list --env ENVIRONMENT_NAME- --env $ENVIRONMENT_NAMEoptional- If defined, only the specified environment's secrets will be listed. Refer to Environments for more information.
 
The kv subcommand allows you to store application data in the Cloudflare network to be accessed from Workers using Workers KV β. KV operations are scoped to your account, so in order to use any of these commands, you:
- must configure an account_idin your project's Wrangler file.
- run all wrangler kv:<command>operations in your terminal from the project's root directory.
To use Workers KV with your Worker, the first thing you must do is create a KV namespace. This is done with
the kv:namespace subcommand.
The kv:namespace subcommand takes a new binding name as its argument. A Workers KV namespace will be created using a concatenation of your Workerβs name (from your Wrangler file) and the binding name you provide:
wrangler kv:namespace create "MY_KV"π  Creating namespace with title "my-site-MY_KV"β¨  Success!Add the following to your configuration file:kv_namespaces = [  { binding = "MY_KV", id = "e29b263ab50e42ce9b637fa8370175e8" }]Successful operations will print a new configuration block that should be copied into your Wrangler file. Add the output to the existing kv_namespaces configuration if already present. You can now access the binding from within a Worker:
let value = await MY_KV.get("my-key");To write a value to your KV namespace using Wrangler, run the wrangler kv:key put subcommand.
wrangler kv:key put --binding=MY_KV "key" "value"β¨  SuccessInstead of --binding, you may use --namespace-id to specify which KV namespace should receive the operation:
wrangler kv:key put --namespace-id=e29b263ab50e42ce9b637fa8370175e8 "key" "value"β¨  SuccessAdditionally, KV namespaces can be used with environments. This is useful for when you have code that refers to
a KV binding like MY_KV, and you want to be able to have these bindings point to different namespaces (like
one for staging and one for production).
A Wrangler file with two environments:
{  "env": {    "staging": {      "kv_namespaces": [        {          "binding": "MY_KV",          "id": "e29b263ab50e42ce9b637fa8370175e8"        }      ]    },    "production": {      "kv_namespaces": [        {          "binding": "MY_KV",          "id": "a825455ce00f4f7282403da85269f8ea"        }      ]    }  }}[env.staging]kv_namespaces = [  { binding = "MY_KV", id = "e29b263ab50e42ce9b637fa8370175e8" }]
[env.production]kv_namespaces = [  { binding = "MY_KV", id = "a825455ce00f4f7282403da85269f8ea" }]To insert a value into a specific KV namespace, you can use:
wrangler kv:key put --env=staging --binding=MY_MV "key" "value"β¨  SuccessSince --namespace-id is always unique (unlike binding names), you do not need to specify an --env argument.
Most kv commands require you to specify a namespace. A namespace can be specified in two ways:
- 
With a --binding:Terminal window wrangler kv:key get --binding=MY_KV "my key"- This can be combined with --previewflag to interact with a preview namespace instead of a production namespace.
 
- This can be combined with 
- 
With a --namespace-id:Terminal window wrangler kv:key get --namespace-id=06779da6940b431db6e566b4846d64db "my key"
Most kv subcommands also allow you to specify an environment with the optional --env flag. This allows you to publish Workers running the same code but with different namespaces. For example, you could use separate staging and production namespaces for KV data in your Wrangler file:
{  "type": "webpack",  "name": "my-worker",  "account_id": "<account id here>",  "route": "staging.example.com/*",  "workers_dev": false,  "kv_namespaces": [    {      "binding": "MY_KV",      "id": "06779da6940b431db6e566b4846d64db"    }  ],  "env": {    "production": {      "route": "example.com/*",      "kv_namespaces": [        {          "binding": "MY_KV",          "id": "07bc1f3d1f2a4fd8a45a7e026e2681c6"        }      ]    }  }}type = "webpack"name = "my-worker"account_id = "<account id here>"route = "staging.example.com/*"workers_dev = false
kv_namespaces = [  { binding = "MY_KV", id = "06779da6940b431db6e566b4846d64db" }]
[env.production]route = "example.com/*"kv_namespaces = [  { binding = "MY_KV", id = "07bc1f3d1f2a4fd8a45a7e026e2681c6" }]With the Wrangler file above, you can specify --env production when you want to perform a KV action on the namespace MY_KV under env.production. For example, with the Wrangler file above, you can get a value out of a production KV instance with:
wrangler kv:key get --binding "MY_KV" --env=production "my key"To learn more about environments, refer to Environments.
Create a new namespace.
wrangler kv:namespace create $NAME [--env=$ENVIRONMENT_NAME] [--preview]- 
$NAME- The name of the new namespace.
 
- 
--env $ENVIRONMENT_NAMEoptional- If defined, the changes will only apply to the specified environment. Refer to Environments for more information.
 
- 
--previewoptional- Interact with a preview namespace (the preview_idvalue) instead of production.
 
- Interact with a preview namespace (the 
wrangler kv:namespace create "MY_KV"π  Creating namespace with title "worker-MY_KV"β¨  Add the following to your wrangler.toml:kv_namespaces = [  { binding = "MY_KV", id = "e29b263ab50e42ce9b637fa8370175e8" }]wrangler kv:namespace create "MY_KV" --previewπ  Creating namespace with title "my-site-MY_KV_preview"β¨  Success!Add the following to your wrangler.toml:kv_namespaces = [  { binding = "MY_KV", preview_id = "15137f8edf6c09742227e99b08aaf273" }]List all KV namespaces associated with an account ID.
wrangler kv:namespace listThis example passes the Wrangler command through the jq command:
wrangler kv:namespace list | jq "."[  {    "id": "06779da6940b431db6e566b4846d64db",    "title": "TEST_NAMESPACE"  },  {    "id": "32ac1b3c2ed34ed3b397268817dea9ea",    "title": "STATIC_CONTENT"  }]Delete a given namespace.
wrangler kv:namespace delete --binding= [--namespace-id=]- 
--bindingrequired (if no--namespace-id)- The name of the namespace to delete.
 
- 
--namespace-idrequired (if no--binding)- The ID of the namespace to delete.
 
- 
--env $ENVIRONMENT_NAMEoptional- If defined, the changes will only apply to the specified environment. Refer to Environments for more information.
 
- 
--previewoptional- Interact with a preview namespace instead of production.
 
wrangler kv:namespace delete --binding=MY_KVAre you sure you want to delete namespace f7b02e7fc70443149ac906dd81ec1791? [y/n]yesπ  Deleting namespace f7b02e7fc70443149ac906dd81ec1791β¨  Successwrangler kv:namespace delete --binding=MY_KV --previewAre you sure you want to delete namespace 15137f8edf6c09742227e99b08aaf273? [y/n]yesπ  Deleting namespace 15137f8edf6c09742227e99b08aaf273β¨  SuccessWrite a single key-value pair to a particular namespace.
wrangler kv:key put --binding= [--namespace-id=] $KEY $VALUE⨠ Success- 
$KEYrequired- The key to write to.
 
- 
$VALUErequired- The value to write.
 
- 
--bindingrequired (if no--namespace-id)- The name of the namespace to write to.
 
- 
--namespace-idrequired (if no--binding)- The ID of the namespace to write to.
 
- 
--env $ENVIRONMENT_NAMEoptional- If defined, the changes will only apply to the specified environment. Refer to Environments for more information.
 
- 
--previewoptional- Interact with a preview namespace instead of production. Pass this to the Wrangler fileβs kv_namespaces.preview_idinstead ofkv_namespaces.id.
 
- Interact with a preview namespace instead of production. Pass this to the Wrangler fileβs 
- 
--ttloptional- The lifetime (in number of seconds) the document should exist before expiring. Must be at least 60seconds. This option takes precedence over theexpirationoption.
 
- The lifetime (in number of seconds) the document should exist before expiring. Must be at least 
- 
--expirationoptional- The timestamp, in UNIX seconds, indicating when the key-value pair should expire.
 
- 
--pathoptional- When defined, Wrangler reads the --pathfile location to upload its contents as KV documents. This is ideal for security-sensitive operations because it avoids saving keys and values into your terminal history.
 
- When defined, Wrangler reads the 
wrangler kv:key put --binding=MY_KV "key" "value"⨠ Successwrangler kv:key put --binding=MY_KV --preview "key" "value"⨠ Successwrangler kv:key put --binding=MY_KV "key" "value" --ttl=10000⨠ Successwrangler kv:key put --binding=MY_KV "key" value.txt --path⨠ SuccessOutput a list of all keys in a given namespace.
wrangler kv:key list --binding= [--namespace-id=] [--prefix] [--env]- 
--bindingrequired (if no--namespace-id)- The name of the namespace to list.
 
- 
--namespace-idrequired (if no--binding)- The ID of the namespace to list.
 
- 
--env $ENVIRONMENT_NAMEoptional- If defined, the changes will only apply to the specified environment. Refer to Environments for more information.
 
- 
--prefixoptional- A prefix to filter listed keys.
 
This example passes the Wrangler command through the jq command:
wrangler kv:key list --binding=MY_KV --prefix="public" | jq "."[  {    "name": "public_key"  },  {    "name": "public_key_with_expiration",    "expiration": "2019-09-10T23:18:58Z"  }]Read a single value by key from the given namespace.
wrangler kv:key get --binding= [--env=] [--preview] [--namespace-id=] "$KEY"- 
$KEYrequired- The key value to get.
 
- 
--bindingrequired (if no--namespace-id)- The name of the namespace to get from.
 
- 
--namespace-idrequired (if no--binding)- The ID of the namespace to get from.
 
- 
--env $ENVIRONMENT_NAMEoptional- If defined, the operation will only apply to the specified environment. Refer to Environments for more information.
 
- 
--previewoptional- Interact with a preview namespace instead of production. Pass this to use your Wrangler fileβs kv_namespaces.preview_idinstead ofkv_namespaces.id
 
- Interact with a preview namespace instead of production. Pass this to use your Wrangler fileβs 
wrangler kv:key get --binding=MY_KV "key"valueRemoves a single key value pair from the given namespace.
wrangler kv:key delete --binding= [--env=] [--preview] [--namespace-id=] "$KEY"- 
$KEYrequired- The key value to delete.
 
- 
--bindingrequired (if no--namespace-id)- The name of the namespace to delete from.
 
- 
--namespace-idrequired (if no--binding)- The id of the namespace to delete from.
 
- 
--envoptional- Perform on a specific environment specified as $ENVIRONMENT_NAME.
 
- Perform on a specific environment specified as 
- 
--previewoptional- Interact with a preview namespace instead of production. Pass this to use your Wrangler configuration file's kv_namespaces.preview_idinstead ofkv_namespaces.id
 
- Interact with a preview namespace instead of production. Pass this to use your Wrangler configuration file's 
wrangler kv:key delete --binding=MY_KV "key"Are you sure you want to delete key "key"? [y/n]yesπ  Deleting key "key"β¨  SuccessWrite a file full of key-value pairs to the given namespace.
wrangler kv:bulk put --binding= [--env=] [--preview] [--namespace-id=] $FILENAME- 
$FILENAMErequired- The file to write to the namespace
 
- 
--bindingrequired (if no--namespace-id)- The name of the namespace to put to.
 
- 
--namespace-idrequired (if no--binding)- The id of the namespace to put to.
 
- 
--env $ENVIRONMENT_NAMEoptional- If defined, the changes will only apply to the specified environment. Refer to Environments for more information.
 
- 
--previewoptional- Interact with a preview namespace instead of production. Pass this to use your Wrangler fileβs kv_namespaces.preview_idinstead ofkv_namespaces.id
 
- Interact with a preview namespace instead of production. Pass this to use your Wrangler fileβs 
This command takes a JSON file as an argument with a list of key-value pairs to upload. An example of JSON input:
[  {    "key": "test_key",    "value": "test_value",    "expiration_ttl": 3600  }]In order to save JSON data, cast value to a string:
[  {    "key": "test_key",    "value": "{\"name\": \"test_value\"}",    "expiration_ttl": 3600  }]The schema below is the full schema for key-value entries uploaded via the bulk API:
- 
keystring required- The keyβs name. The name may be 512 bytes maximum. All printable, non-whitespace characters are valid.
 
- 
valuestring required- The UTF-8 encoded string to be stored, up to 25 MB in length.
 
- 
expirationint optional- The time, measured in number of seconds since the UNIX epoch, at which the key should expire.
 
- 
expiration_ttlint optional- The number of seconds the document should exist before expiring. Must be at least 60seconds.
 
- The number of seconds the document should exist before expiring. Must be at least 
- 
base64bool optional- When true, the server will decode the value as base64 before storing it. This is useful for writing values that would otherwise be invalid JSON strings, such as images. Defaults to false.
 
- When true, the server will decode the value as base64 before storing it. This is useful for writing values that would otherwise be invalid JSON strings, such as images. Defaults to 
If both expiration and expiration_ttl are specified for a given key, the API will prefer expiration_ttl.
wrangler kv:bulk put --binding=MY_KV allthethingsupload.jsonπ  uploading 1 key value pairsβ¨  SuccessDelete all specified keys within a given namespace.
wrangler kv:bulk delete --binding= [--env=] [--preview] [--namespace-id=] $FILENAME- 
$FILENAMErequired- The file with key-value pairs to delete.
 
- 
--bindingrequired (if no--namespace-id)- The name of the namespace to delete from.
 
- 
--namespace-idrequired (if no--binding)- The ID of the namespace to delete from.
 
- 
--env $ENVIRONMENT_NAMEoptional- If defined, the changes will only apply to the specified environment. Refer to Environments for more information.
 
- 
--previewoptional- Interact with a preview namespace instead of production. Pass this to use your Wrangler fileβs kv_namespaces.preview_idinstead ofkv_namespaces.id
 
- Interact with a preview namespace instead of production. Pass this to use your Wrangler fileβs 
This command takes a JSON file as an argument with a list of key-value pairs to delete. An example of JSON input:
[  {    "key": "test_key",    "value": ""  }]- 
keystring required- The keyβs name. The name may be at most 512 bytes. All printable, non-whitespace characters are valid.
 
- 
valuestring required- This field must be specified for deserialization purposes, but is unused because the provided keys are being deleted, not written.
 
wrangler kv:bulk delete --binding=MY_KV allthethingsdelete.jsonAre you sure you want to delete all keys in allthethingsdelete.json? [y/n]yπ  deleting 1 key value pairsβ¨  SuccessWrangler supports any Wrangler configuration file keys passed in as environment variables. This works by passing in CF_ + any uppercased TOML key. For example:
CF_NAME=my-worker CF_ACCOUNT_ID=1234 wrangler dev
wrangler --helpπ· β¨  wrangler 1.12.3The Wrangler Team <wrangler@cloudflare.com>
USAGE:    wrangler [SUBCOMMAND]
FLAGS:    -h, --help       Prints help information    -V, --version    Prints version information
SUBCOMMANDS:    kv:namespace    ποΈ  Interact with your Workers KV Namespaces    kv:key          π  Individually manage Workers KV key-value pairs    kv:bulk         πͺ  Interact with multiple Workers KV key-value pairs at once    route           β‘οΈ  List or delete worker routes.    secret          π€«  Generate a secret that can be referenced in the worker script    generate        π―  Generate a new worker project    init            π₯  Create a wrangler.toml for an existing project    build           π¦  Build your worker    preview         π¬  Preview your code temporarily on cloudflareworkers.com    dev             π  Start a local server for developing your worker    publish         π  Publish your worker to the orange cloud    config          π΅οΈ  Authenticate Wrangler with a Cloudflare API Token or Global API Key    subdomain       π·  Configure your workers.dev subdomain    whoami          π΅οΈ  Retrieve your user info and test your auth config    tail            π¦  Aggregate logs from production worker    login           π  Authorize Wrangler with your Cloudflare username and password    logout          βοΈ  Remove authorization from Wrangler.    help            Prints this message or the help of the given subcommand(s)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