Migrating from zrok v1 to v2
This guide helps you transition from zrok v1.x to v2.0, focusing on the paradigm shift from reserved shares to the new namespaces model.
zrok v2.0 introduces breaking changes. The reserved sharing commands (zrok reserve, zrok release, zrok share reserved) have been removed and replaced with a more flexible namespace system.
What's Changing?
The Big Picture
In v1.x, you created reserved shares with persistent share tokens using zrok reserve. In v2.0, this concept has evolved into a more powerful system:
- namespaces - "zones" that contain names (typically corresponding with a DNS zone)
- names - unique identifiers within namespaces that can be reserved or ephemeral (typically corresponding with an Arecord in a DNS zone)
This new model provides:
- Less coupling between environments and external names; this means you can more easily move your share backends around between hosts and reconfigure how you're sharing, without changing the names you're sharing with
- Support for multiple names per share
Configuration Changes
The defaultFrontend configuration option has been replaced with defaultNamespace. You'll need to update your configuration files accordingly (see zrok status and zrok config --help).
Concept Mapping: v1 → v2
| v1.x concept | v2.0 equivalent | description | 
|---|---|---|
| reserved share | reserved name in a namespace | A persistent external name for your share | 
| zrok reserve | zrok create name | Create a reserved name | 
| zrok share reserved <token> | zrok share public/private -n <namespaceToken>:<name> | Share using a name ( -nselects a name in a namespace) | 
| zrok release <token> | zrok delete name <name> | Remove a reserved name | 
Command Reference
Removed Commands
These commands no longer exist in v2.0:
# no longer available
zrok reserve public --backend-mode web /path/to/files
zrok reserve private http://localhost:3000
zrok share reserved <token>
zrok release <token>
zrok overview public-frontends
New Commands
Namespace Management (End Users)
# list available namespaces
zrok list namespaces
# list all your names
zrok list names
# create a reserved name (persistent)
zrok create name -n <namespaceToken> <name>
# modify a name (e.g., toggle reserved status)
zrok modify name -n <namespaceToken> <name> -r|-r=false
# delete a name
zrok delete name -n <namespaceToken> <name>
Sharing with Names
# public share with a name selection
zrok share public <target> -n <namespaceToken>:<name>
# private share with vanity token
zrok share private <target> --share-token my-custom-token
Migration Walkthrough
Scenario 1: Simple Reserved Public Share
v1.x workflow:
# create a reserved share
$ zrok reserve public --backend-mode web /var/www/mysite
your reserved share token is 'abc123xyz'
reserved frontend endpoint: https://abc123xyz.share.zrok.io
# start sharing
$ zrok share reserved abc123xyz
# later, release it
$ zrok release abc123xyz
v2.0 workflow:
# first, check available namespaces
$ zrok list namespaces
╭───────────────────────┬─────────────────┬─────────────╮
│ NAME                  │ NAMESPACE TOKEN │ DESCRIPTION │
├───────────────────────┼─────────────────┼─────────────┤
│ example.com           │ public          │             │
╰───────────────────────┴─────────────────┴─────────────╯
# create a reserved name in the 'public' namespace
$ zrok create name -n public api
# start sharing using the name selection
$ zrok share public localhost:8080 -n public:api
# the name persists across share restarts
$ zrok share public localhost:8080 -n public:api
# when done, delete the name
$ zrok delete name -n public api
Scenario 2: Private Reserved Share
v1.x workflow:
# reserve a private share
$ zrok reserve private http://localhost:8080
your reserved share token is 'xyz789abc'
# share it
$ zrok share reserved xyz789abc
# access from another environment
$ zrok access private xyz789abc
v2.0 workflow:
# share privately using the name (-s specifies a share token name)
$ zrok share private http://localhost:8080 -s myapi-prod
# access from another environment
$ zrok access private myapi-prod
Scenario 3: Ephemeral Shares (Unchanged)
Ephemeral shares work mostly the same, but now support optional name selections:
# v1.x - still works in v2.0
$ zrok share public :8080
Using the zrok Agent with v2
If you're using the zrok agent, there are significant improvements in v2.0:
Automatic Retry and Error Handling
The agent now automatically retries failed shares with exponential backoff. Errored processes receive transient err_XXXX tokens for management.
Persistent Shares
Shares with reserved name selections automatically restart after abnormal exit or agent restart:
# create a reserved name (-n defaults to 'public')
$ zrok create name myapp
# when agent running, share will persist across agent restarts due to reserved name
# selection
$ zrok share public http://localhost:3000 -n public:myapp
# when agent running, private share with --share-token will persist across agent restarts
$ zrok share private http://localhost:3000 --share-token myapp
Improved Status Command
The zrok agent status command now shows:
- Detailed error states for failed processes
- Frontend endpoints for public shares
- Failure information with error messages
Working with Multiple Names
One powerful v2.0 feature: a single share can use multiple name selections:
# create multiple names
$ zrok create name myapp
$ zrok create name myapp-staging
# share using both names
$ zrok share public http://localhost:3000 \
  -n public:myapp \
  -n public:myapp-staging
# both URLs now point to the same share:
 - https://myapp.share.zrok.io
 - https://myapp-staging.share.zrok.io
Understanding Namespaces
What is a Namespace?
A namespace is a logical grouping for names, similar to how a DNS zone works. Your zrok instance may have one or more namespaces available:
- public - typically the default namespace for all users
- custom namespaces - may be created by administrators for specific purposes (custom domains, for example)
Listing Available Namespaces
$ zrok list namespaces
╭───────────────────────┬─────────────────┬─────────────╮
│ NAME                  │ NAMESPACE TOKEN │ DESCRIPTION │
├───────────────────────┼─────────────────┼─────────────┤
│ share.zrok.io         │ public          │             │
╰───────────────────────┴─────────────────┴─────────────╯
Checking Your Current Shares and Names
View All Your Names
$ zrok list names
╭───────────────────────────────┬─────────┬───────────┬─────────────┬──────────┬─────────────────────╮
│ URL                           │ NAME    │ NAMESPACE │ SHARE TOKEN │ RESERVED │ CREATED             │
├───────────────────────────────┼─────────┼───────────┼─────────────┼──────────┼─────────────────────┤
│ testing.share.zrok.io         │ testing │ public    │             │ true     │ 2025-10-17 13:17:11 │
╰───────────────────────────────┴─────────┴─── ────────┴─────────────┴──────────┴─────────────────────╯
View Overview (Now Includes Names)
$ zrok overview
# shows human-readable format with names and namespaces
# for json output
$ zrok overview --json
Common Questions
Do I Need to Keep the Same URL?
No, with the namespace/name system, your URLs will change based on the name you choose. If you need to maintain the same identifier, you can choose a name that matches your old token, though the full URL structure may differ based on how your zrok instance's frontends are configured.
Can I Use the Old Share Tokens as Names?
Yes, names can use the same format as old share tokens. However, this is your opportunity to choose more meaningful, memorable names for your shares.
What Happens to Permission Modes?
Permission modes (open/closed) still work the same way with --open and --closed flags, plus the --access-grant flag for granting access to specific accounts.
Do Ephemeral Shares Still Work?
Yes! Ephemeral shares work just as before. The main difference is they now support optional name selections, and by default names created without a reserved name selection are ephemeral.
What if I Have Scripts Using the Old Commands?
You'll need to update your scripts to use the new command structure. The good news is the new system is more flexible and often requires fewer steps for common workflows.
Getting Help
If you run into issues during migration:
- Check zrok statusto verify your environment is properly enabled
- Use zrok list namespacesto see what namespaces are available to you
- Use zrok list namesto see your current names
- Review the error messages - v2.0 has improved error reporting
- Consult the self-hosting guides if you manage your own instance
- Check the concepts documentation for deeper understanding
- Reach out on the OpenZiti Discourse for help