-
-
Notifications
You must be signed in to change notification settings - Fork 148
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_image: using force is required to pull locally existing changed image from registry #879
Comments
There is no module to get latest image information from repository, which causes this problem to be currently only solvable by using uri module and using HEAD request. |
Podman doesn't support such functionality, there is a Skopeo tool for this. I don't think image module should require a Skopeo. |
related to #876 as well |
If its not possible to make it with podman itself then skopeo module would be good solution to make. |
Yeah, I'd like to have it. Would you like to prepare a patch 😄 ? |
Unfortunately I have no time and original reason why I suggested this wasn't solution to my real problem with Docker Hub quota. Docker Hub requires clients to login when getting digest in HEAD request from images and I'm not aware of what scope should be in login request to get info about all public images with one login request. But in current documentation of Docker Hub API it will have scope of one image and this will consume quota as fast as issuing podman pull directly. I'm not sure if skopeo has solved this quota issue itself somehow, if they have then it could be solution, but currently I have too much work todo before the end of the year. |
I wanted to achieve similar results, but failed. pull: newer | always recreate: true - always recreates container even if image stays the same 🔴
Used task: - name: Deploy applications
containers.podman.podman_container:
name: "{{ item.name }}"
image: "{{ item.name }}:{{ item.version | default('latest') }}"
restart_policy: unless-stopped
pull: newer
with_items: "{{ applications }}" |
@sgflt in order to use the newest image that exists locally with same tag exactly you need to use |
I've started to work on HEAD requests for dockerhub in |
I have tested your recommendation, but still it does not discover newer image in registry. Even following combination does not redeploy changed image: 🔴 pull: always
image_strict: true But if I pull manually and then run playbook, then only the updated image is redeployed. 🟠 |
Yes, this is exactly what I meant. It will discover it locally, currently it doesn't communicate with a registry. |
I think using pull with this module should check from registry if it has newer image or digest has changed, then pull image only when it has changed. I would like to not use force parameter, because it will waste limited quota very fast. In my own registry there is no quota and I can continue to use force: true, but in case of Docker Hub this isn't possible.
I will build my own versions of these images in single machine and then push them to my own Gitea instance.
This might be related to issue in the past #153.
The text was updated successfully, but these errors were encountered: