You can create multiple versions of your agent and publish them to separate environments.
When you edit an agent, you are editing the draft agent. At any point, you can save the draft agent as an agent version, which is an immutable snapshot of your agent.
When you save the draft agent, it is published to the default environment. When you create agent versions, you can publish them to custom environments. You can create a variety of custom environments for:
- testing
- development
- production
- etc.
Production traffic
Always use agent versions for production traffic
A draft agent is updated every time a developer on your team makes a change. It is easy to break a draft agent unintentionally, especially if multiple people have write access to the agent. In addition, a recently edited draft agent may be inconsistent with the trained model, because training may have a delay or require manual execution.
You should always use agent versions for your production traffic. Draft agents should be tested before promoting them to production versions, and you can rollback to a previous version if any problems are discovered.
Consider possible agent errors while changing versions
If you change an agent version in your production environment while sessions are active, it may cause agent errors for some active sessions. These errors may happen if the previous and new versions are inconsistent with each other in a way that disrupts session state. Due to this, you should plan to change versions during down-time or off-peak hours.
Publish a version in a new environment
To publish an agent draft to a version and create a custom environment:
Console
- Go to the Dialogflow ES console.
- Select your agent near the top of the left sidebar menu.
- Click the settings settings button next to the agent name.
- Click the Environments tab.
- Click Publish a version.
- Add an optional description and click Next.
- Select +New Environment. 
- Enter an environment name. 
- Choose the fulfillment method for the environment. 
- Select Text-to-speech settings for the environment. 
- Click Publish. 
- The environment information is now listed in the Custom environments section. 
API
- Call the createmethod for the Version type to create a new agent version.
- Call the createmethod for the Environment type to create a new environment. Provide the agent version you just created to theagentVersionfield.
Revert an environment to a previous version
You can revert an environment to a previous agent version:
Console
- Click an environment in the Custom environments section.
- The environment settings dialog opens.
- Click the option more_vert button for a previously published version in the Publishing History section.
- Click Revert to this version.
- The publishing history will be updated.
API
Call the patch/update method for the
Environment type
to update an environment.
Provide the agent version you previously created to the agentVersion field.
Load a previous version to draft
Loading a previous version to draft overwrites the draft agent in the default environment with a selected agent version.
To load a previous version to draft:
Console
- Go to the Dialogflow ES console.
- Select your agent near the top of the left sidebar menu.
- Click the settings settings button next to the agent name.
- Click the Environments tab.
- Click View all versions in the Draft section.
- Click the option more_vert button for a version that you want to load to draft.
- Click Load to Draft.
- Click Yes, I'm sure.
- Reload any open console browser tabs, so they are refreshed with the latest agent data.
API
Call the patch/update method for the
Environment type
with the following inputs:
- Use -as the environment ID to specify the default environment.
- Set allowLoadToDraftAndDiscardChangesto true.
- For the agentVersionfield, supply the agent version that will overwrite the draft agent.
Export a version
To export a version, you need to load it to draft first, then export the agent.
Test your agent in an environment
You can use the API to test your agent in any of your custom environments.
Call the
detect intent
method, but alter the endpoint URL by inserting
environments/environment-name/users/-/ between agent and sessions.
For example, the following endpoint uses the "development" environment with an unspecified user:
"https://dialogflow.googleapis.com/v2/projects/my-project-id/agent/environments/development/users/-/sessions/123456789:detectIntent"
Environment-specific settings
Fulfillment and text-to-speech are configured by the environment, so the agent will use the environment's settings for these features.
For more information about how data is applied at various levels, see agent application levels.
Google Assistant
If you are using Actions on Google release environments, see the versioning limitations for the Dialogflow fulfillment library.
Mega agent
See how versions and environments work in mega agents.
Limitations
The following limitations apply:
- Maximum number of environments per agent: 10
- Maximum number of versions per agent: 1000