-
Notifications
You must be signed in to change notification settings - Fork 82
RFE: Label based snapshot #1094
Comments
LabelsLabels are a unique independent entity that can be used to tag an object. With the help of labels, we can group objects and perform different operations based on configuration values stored in the labels. What are the Rest endpoints it supports
Where Can we use labelsThe first consumer of labels will be Snapshot. We can use labels to list snapshot, delete the snapshot and perform other high-level actions. For example, In a customer setup, a snapshot can schedule based on different labels like Monthly, Hourly, Yearly, Daily etc. Each one of this can have different configuration values. In a typical set up, the maximum number of a snapshot for the Hourly label can set to 24, while the same value will be 12 for the Monthly snapshot. So performing auto-delete based on this max values will be based on label values. Snapshot Based Geo-replicationLabels are the first pre-requisite for Snapshot Based Geo-replication . To implement the feature we need to create an internal snapshot in a shorter interval, and the auto-delete should be true as well as the max snapshot count should be minimal. We cannot use a default value for this snapshots. |
Moving the discussion from PR #1228. This kind of actions are not triggered by a scheduler or a plugin but as part of a snapshot command. I'm not able to understand how a key-value pair can solve this. I have not thought about any use case for other commands., My intention behind implementing it as a generic command was to make it available for other commands like volume. But I can implement this as part of snapshot endpoints. |
This can be part of snapshot and/or georep API.
When you say "autodelete", usually there is someone (a separate process or thread in gd2 or a goroutine) who does the deletion. That someone has to know about when and what action to take. This information has to be stored somewhere. Depending on who this entity is, one place to store this information is metadata. As you pointed out, in your usecase, all actions happen only when a command is issued. This wasn't clear earlier. If it's part of a synchronous command initiated by client/user, it can be part of the normal snapshot/georep API.
I'd prefer that, unless you can justify how labels can be used for usecases beyond snapshot. |
Okay. At the moment, I can't think of any use case other than snapshot. I will resubmit the patch, moving it to the snapshot endpoints . |
It is very helpful if there is a way to tag snapshots with labels. This allows us to schedule snapshot operations better. Also make easy to manage snapshots based on labels
The text was updated successfully, but these errors were encountered: