This page provides detailed configuration and deployment procedures for changing the version number of your API. The procedure that you use depends on whether the changes to your API are backwards compatible.
- If your new API version has backwards-compatible changes, such as adding new fields or methods, see Backwards-compatible changes.
- If your new API has changes to an existing method that breaks your customers' client code, see Backwards-incompatible changes.
For additional information and best practices, see API lifecycle management.
Backwards-compatible changes
When you make changes to your API that are backwards compatible with existing client code, as a best practice, increment the minor version number of your API before you deploy the new version. Although Cloud Endpoints runs only one minor version of an API at a time, the graphs and logs in Endpoints > Services display the version number. By incrementing the minor version number before you deploy, the graphs and logs provide a labeled history of your deployments.
To increment the minor version number:
In
openapi.yaml, increment the minor version number of theinfo.versionfield. For example, if the current version is1.1, setinfo.versionto1.2:info: description: "A simple Cloud Endpoints API example." title: "Endpoints Example" version: "1.2" host: "echo-api.endpoints.example-project-12345.cloud.goog"Use the Google Cloud CLI to deploy the API configuration:
gcloud endpoints services deploy openapi.yamlDeploy the API backend by using the configuration ID returned from the previous step. For details, see Deploying the API backend.
Backwards-incompatible changes
When you make changes to your API that breaks your customers' client code, as a best practice, increment the major version number of your API. Endpoints can run more than one major version of an API concurrently. By providing both versions of the API, your customers can pick which version they want to use and control when they migrate to the new version.
To run the existing and new versions of an API concurrently:
Create separate OpenAPI configuration files for each version you need to serve. This procedure uses the file names
openapi-v1.yamlandopenapi-v2.yamlfor example purposes.Copy the contents of
openapi-v1.yamltoopenapi-v2.yaml.In
openapi-v1.yamlconfigure the following:- Set the
info.versionfield to the existing version number. - Leave the
basePathfield unchanged.
For example:
info: description: "A simple Cloud Endpoints API example." title: "Endpoints Example" version: "1.1" host: "echo-api.endpoints.example-project-12345.cloud.goog" basePath: "/v1"- Set the
In
openapi-v2.yamlconfigure the following:- Make backwards-incompatible changes.
- Set the
info.versionfield to the new version number. - Set the
basePathfield to include the new major version number. - Remove the
x-google-endpointssection. This section is needed if you want to specify DNS IP address orallowCorsflag. When deploying two versions of the API with two yaml config files, only one of them can havex-google-endpoints, but its config will apply to both versions.
For example:
info: description: "A simple Google Cloud Endpoints API example." title: "Endpoints Example" version: "2.0" host: "echo-api.endpoints.example-project-12345.cloud.goog" basePath: "/v2"Use the Google Cloud CLI to deploy both API configuration files:
gcloud endpoints services deploy openapi-v1.yaml openapi-v2.yamlDeploy a single backend that serves both versions of the API by using the configuration ID returned from the previous step. For details, see Deploying the API backend.