-
Notifications
You must be signed in to change notification settings - Fork 68
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
The behaviour of KeepLatestNVersionImagesByProperty is unclear and possibly incorrect #60
Comments
Yep, it looks so. We appreciate providing the detail explanation and examples and digging into the problem, it's helpful for debbuging! |
Apart from that, I've found that the property which the version is looked in ("docker.manifest") is set only on the manifest.json files, not in the layer files, resulting in a key error:
So the search should be restricted to the "manifest.json" file names. Then, after the artifacts to be deleted have been determined, their parent (the folder that contains the manifest.json file) should be deleted, not only the manifest. |
@afolgado I think the rule But yeah, we can filter out
Yep, DeleteDockerImagesOlderThan does it under the hood too |
Thanks for the clarification, @allburov . Yes, maybe By the way, I can't see why |
I don't remember :( |
@kenny-monster in the new version (which is coming soon) the rule For you case (save 2 builds in major releases) the config is: #artifactory-cleanup.yaml
artifactory-cleanup:
server: https://repo.example.com/artifactory
user: $ARTIFACTORY_USERNAME
password: $ARTIFACTORY_PASSWORD
policies:
- name: Remove docker images older than 7 days, but keep 2 major anyway
rules:
- rule: Repo
name: "repo-name-here"
- rule: DeleteDockerImagesOlderThan
days: 7
- rule: KeepLatestNVersionImagesByProperty
count: 2
number_of_digits_in_version: 1 |
Hey @allburov, I've finally had a chance to try the My policy looks like this:
Both images have not been used for more than 60 days. Running with either image alone results in the two latest image versions being filtered out as expected. |
I want to use
KeepLatestNVersionImagesByProperty
as a safeguard to ensure that a few versions are always retained. I've been debugging the method and I'm still not sure what the intended behaviour is.Assume the input is (with importance to the ordering):
and that the rule has been called like so:
The final result ends up being that nothing is deleted. I would have expected that A and B would have been filtered out and that C remains for potential deletion.
If I then alter this line (https://github.com/devopshq/artifactory-cleanup/blob/master/artifactory_cleanup/rules/docker.py#L183) from:
to
then B and C are filtered out and A remains for potential deletion. This is because the three image versions are able to be grouped together. Previously, the version would be part of the grouping which seems incorrect to me. This still doesn't meet what I expect the result to be.
From here, it seems like the sorting isn't right (assuming what I said above is correct). https://github.com/devopshq/artifactory-cleanup/blob/master/artifactory_cleanup/rules/docker.py#L189
The text was updated successfully, but these errors were encountered: