-
Notifications
You must be signed in to change notification settings - Fork 2.5k
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
podman manifest rm deletes referenced image instead of manifest list #11344
Comments
Thanks for reaching out, @stu-gott! I think that However, it seems like @flouthoc, since you're working in this area at the moment, do you want to tackle this bug? We need to make sure to add regression tests to nail down the behavior. |
@vrothberg Sure can look at this. This issue should be transferred to buildah right ? |
No, podman and buildah are both using |
@vrothberg then |
Can you elaborate on the difference? To me, Are you sure you looked at |
My bad 🤦 I looked at |
Thank you to both of you for looking into this. After retrying this, I can confirm @vrothberg's observation: podman manifest rm currently does the wrong thing. |
/assign |
buildah manifest rm and podman manifest rm, should work the same and in the end the manifest list should be removed, whether or not the images the manifest list refer to should be removed, is debatable. I would think the default is they get removed if they are not in use. |
I tend to think the opposite would be ideal. The images can be managed individually using well established commands. At this time there's no way to remove the manifest without affecting the associated images. I propose that manifest rm operates on just the manifest, but adding a "--all" or "--follow" flag would also delete any referenced images that are present. |
Well I guess I can go along with that. '--all' makes the most sense to me. |
I spent some time on this after having few discussions and brainstorming with @vrothberg on a similar topic. What i think is we should do operations only on |
But sure we can have a case to remove all referenced images when |
In retrospective, wished there was no |
@vrothberg, that's a very good point. We've conflated two separate conversations here. I think it would be sensible to handle decisions regarding [ |
Is this a BUG REPORT or FEATURE REQUEST? (leave only one on its own line)
/kind bug
Description
UPDATE: this description is out of date. clarification of the actual problem is in the first few comments.
I created a manifest, then attempted to delete it using podman rmi (this is likely wrong, but I couldn't figure out how to use podman manifest remove), and it deleted something I didn't expect it to.
Steps to reproduce the issue:
I pulled the amd64 and arch64 versions of fedora, then created a manifest and added them to it. here's the terminal transcript:
$ podman pull --arch=amd64 fedora:latest
Resolved "fedora" as an alias (/etc/containers/registries.conf.d/000-shortnames.conf)
Trying to pull registry.fedoraproject.org/fedora:latest...
Getting image source signatures
Copying blob ecfb9899f4ce done
Copying config 37e5619f4a done
Writing manifest to image destination
Storing signatures
37e5619f4a8ca9dbc4d6c0ae7890625674a10dbcfb76201399e2aaddb40da17d
$ podman tag 37e5619f4a8ca9dbc4d6c0ae7890625674a10dbcfb76201399e2aaddb40da17d localhost/fedora:latest.amd64
$ podman pull --arch=arm64 fedora:latest
Resolved "fedora" as an alias (/etc/containers/registries.conf.d/000-shortnames.conf)
Trying to pull registry.fedoraproject.org/fedora:latest...
Getting image source signatures
Copying blob 679663bf9a1d done
Copying config aace6e1f04 done
Writing manifest to image destination
Storing signatures
aace6e1f04bbdc9795884eb67c63514abd53b87f647630fa4263c07b931da5a5
$ podman tag aace6e1f04bbdc9795884eb67c63514abd53b87f647630fa4263c07b931da5a5 localhost/fedora:latest.arm64
$ podman manifest create localhost/fedora:latest
69c3faec36e64a3a5b521cd011893e9c16f445810ef888d7e69c158067fdfb3b
$ podman manifest add localhost/fedora:latest containers-storage:localhost/fedora:latest.amd64
69c3faec36e64a3a5b521cd011893e9c16f445810ef888d7e69c158067fdfb3b
$ podman manifest add localhost/fedora:latest containers-storage:localhost/fedora:latest.arm64
69c3faec36e64a3a5b521cd011893e9c16f445810ef888d7e69c158067fdfb3b
$ podman rmi localhost/fedora:latest
Untagged: localhost/fedora:latest.amd64
Deleted: 37e5619f4a8ca9dbc4d6c0ae7890625674a10dbcfb76201399e2aaddb40da17d
$ podman rmi localhost/fedora:latest
Untagged: localhost/fedora:latest
Deleted: 69c3faec36e64a3a5b521cd011893e9c16f445810ef888d7e69c158067fdfb3b
Describe the results you received:
The first invocation of podman rmi deleted the amd64 (my arch) version of the image referenced in the manifest.
The second invocation of podman rmi deleted the manifest itself.
Describe the results you expected:
podman rmi should have either deleted the manifest instead of the image, or should have refused to delete anything at all and asked the user if they really meant "podman manifest remove" (which I couldn't figure out, but that's not a bug lol).
Additional information you deem important (e.g. issue happens only occasionally):
Output of
podman version
:Output of
podman info --debug
:Package info (e.g. output of
rpm -q podman
orapt list podman
):Have you tested with the latest version of Podman and have you checked the Podman Troubleshooting Guide? (https://github.com/containers/podman/blob/master/troubleshooting.md)
Yes
Additional environment details (AWS, VirtualBox, physical, etc.):
physical host.
The text was updated successfully, but these errors were encountered: