gcloud app deploy does not remove previous versions

后端 未结 3 1167
我寻月下人不归
我寻月下人不归 2021-02-07 11:55

I am running a Node.js app on Google App Engine, using the following command to deploy my code:

gcloud app deploy --stop-previous-version

My de

相关标签:
3条回答
  • 2021-02-07 12:05

    Google may have updated their documentation cited in @IAmKale's answer

    Note that if the version is running on an instance of an auto-scaled service, using --stop-previous-version will not work and the previous version will continue to run because auto-scaled service instances are always running.

    Seems like that flag only works with manually scaled services.

    0 讨论(0)
  • 2021-02-07 12:19

    We accidentally blew through our free Google App Engine credit in less than 30 days because of an errant flexible instance that wasn't cleared by subsequent deployments. When we pinpointed it as the cause it had scaled up to four simultaneous instances that were basically idling away.

    tl;dr: Use the --version flag when deploying to specify a version name. An existing instance with the same version will be replaced then next time you deploy.

    That led me down the rabbit hole that is --stop-previous-version. Here's what I've found out so far:

    --stop-previous-version doesn't seem to be supported anymore. It's mentioned under Flags on the gcloud app deploy reference page, but if you look at the top of the page where all the flags are listed, it's nowhere to be found.

    I tried deploying with that flag set to see what would happen but it seemingly had no effect. A new version was still created, and I still had to go in and manually delete the old instance.

    There's an open Github issue on the gcloud-maven-plugin repo that specifically calls this out as an issue with that plugin but the issue has been seemingly ignored.

    At this point our best bet at this point is to add --version=staging or whatever to gcloud deploy app. The reference docs for that flag seem to indicate that that it'll replace an existing instance that shares that "version":

    --version=VERSION, -v VERSION

    The version of the app that will be created or replaced by this deployment. If you do not specify a version, one will be generated for you.

    (emphasis mine)

    Additionally, Google's own reference documentation on app.yaml (the link's for the Python docs but it's still relevant) specifically calls out the --version flag as the "preferred" way to specify a version when deploying:

    The recommended approach is to remove the version element from your app.yaml file and instead, use a command-line flag to specify your version ID

    0 讨论(0)
  • 2021-02-07 12:22

    As far as I can tell, for Standard Environment with automatic scaling at least, it is normal for old versions to remain "serving", though they should hopefully have zero instances (even if your scaling configuration specifies a nonzero minimum). At least that's what I've seen. I think (I hope) that those old "serving" instances won't result in any charges, since billing is per instance.

    I know most of the above answers are for Flexible Environment, but I thought I'd include this here for people who are wondering.

    (And it would be great if someone from Google could confirm.)

    0 讨论(0)
提交回复
热议问题