-
-
Notifications
You must be signed in to change notification settings - Fork 750
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
dockerutil.BuildEmptyImage() fails with bad API version #646
Comments
Interesting... need to investigate/repro. Either way, the next release should address this. Check back a bit later or follow me on Github or Twitter to be notified when the new release is out. |
Sounds good, thanks. I'll see how the next version works out. We're still having some build issues, but it looks like if we set a |
For reference, other versions may work (
in our pipeline |
@jimcottrell this might work as-is https://github.com/mintoolkit/mint/releases/tag/1.41.1 let me know if you still have problems there |
I've tried with v1.41.1 and no explicit |
@jimcottrell which version of Docker do you have installed? Are you on Mac or Linux? If you are on Linux are you using Docker Desktop or only Docker Engine? If you are on a Mac is it an AMD or an M1/M2? Trying to repro... more info on your environment will help |
Getting this on Fedora 39 with the latest stable docker-ce and slim installed.
Setting Seems to be a common problem looking at #637 and caused by #641 |
@sammcj Here's the Vagrant-based repro with Fedora 39 and Docker 26.1.1. You should be good with the release version in the repro config. The release version you shared in this issue is out of date. |
@kcq Sorry for the delay in responding. As noted before, this is happening only on a self-hosted Bitbucket pipeline runner (linux/amd64). When I run locally, I have no issue. To make Slim work in the pipeline environment, it has to run via the Host Docker
|
@jimcottrell Running with dind in Bitbucket runners makes it more complicated because each CI/CD vendor does the dind setup in slightly different ways, which requires different ways to connect to the (correct) Docker runtime. Some environments don't expose the Docker unix socket. Other environments need certs to connect to the Docker runtime. Some have more advanced network configurations that prevents direct container communication, so the To troubleshoot your setup we need two things to get started:
|
Here's a simplified version of our image:
name: atlassian/default-image:4
definitions:
services:
privileged-docker:
type: docker
image:
name: docker:dind
pipelines:
custom:
test:
- step:
runs-on:
- linux
- self.hosted
name: Build Optimized Image
services:
- privileged-docker
script:
- curl https://downloads.dockerslim.com/releases/1.40.11/dist_linux.tar.gz -o slim.tar.gz
- tar xvf slim.tar.gz
#- export DOCKER_API_VERSION='1.25' # Temporary, see https://github.com/slimtoolkit/slim/issues/646
- ./dist_linux/slim build --continue-after=enter alpine I tried it with |
Are there any updates here? I am having the same problem with a gitlab pipeline and dind |
The latest release, 1.41.5, shouldn't have the docker API problem. To connect to the Docker daemon it might be necessary to extract the daemon IP address from the /etc/hosts file if the environment doesn't configure DOCKER_HOST on its own properly. Here's an example for Gitlab (need to double check if it still works): Might need to use the I'll repro it with Gitlab first to confirm that the setup is still ok. Then I'll try to repro with a Bitbucket setup. |
Okay, than the installation routine should be adapted:
|
should be this install script |
Hello @kcq ! |
What image did you try to slim or was it a different command? Do you have a repro? |
It is a custom internal image, already created. Found just now that i'm forced to use the 'export' =>
or While if i do:
It says again client API 1.12 is too old. |
Thank you for the additional context @marcoaversanoigt ! This will help with my repro. We have the environment and the command context that should be enough. Working on the repro (hopefully can repro it without the Github workflow part :-)) |
Hello guys. |
For anyone confused like me regarding the updates, version problem or whatever, |
Yes, the latest enhancements are there. There's a new release coming soon too. |
You said
Are these enhancements in |
It was a typo. He meant to say slim :-) It's not really deprecated, but the current updates are in the mint releases. @NilsMoller are you using the latest release ? If not try using it and let me know if you are getting the same behavior. This particular API version problem has been tricky to track down / repro. The upcoming release will have a number docker client/API enhancements and also container image format handling enhancements for XRAY among other things. |
I am using the latest version (as far as i know). I will move to mint and try again. Thanks! |
I am now using Mint installed using the scripted install both locally and in the Bitbucket pipeline (as specified in the README). It works locally, but in the Bitbucket pipeline it fails with the same error as above.
And the output of the command is this:
Should I create an issue in the |
Thanks for the update @NilsMoller ! Good that it's functional locally. That's a useful data point for the repro. Next is for me to repro a bitbucket setup. |
I am confused about the different tools slim versus mint. Both look similar. Which one is maintained, which one is deprecated. There is no info in either of the repos. Could you please bring some light into the dark? And maybe add some little docs in the readme's about this? Thanks |
@klauss42 it's a bit messy at this point in time. Sorry about that. It's partially related to the CNCF requirement to change the project name when the project was accepted into CNCF. There's more to it... I hope to make it more straight forward in the future and ideally it'll be back to one. If you'd like to chat more about the details around it let's pick a time to chat. Either way, the new enhancements and features are added in Mint. |
You can create an issue there as well, but it's optional only if you want to :-) |
I've got a CI/CD pipeline that's run occasionally when we rebuild a image and create an optimized version with Slim. Without anything having changed that I'm aware of (same Slim version, same pipeline runner), this process has started failing with:
I thought this might be related to #637, but it seems to be a separate issue, and the same thing happens whether or not I try setting
--crt-api-version
. Having updated everything to the latest versions, the problem continues. The issue seems to be specific to this environment, as a local build works.Steps to Reproduce the Problem
(trivial reproduction; of course not our actual image)
Specifications
slim version
:The text was updated successfully, but these errors were encountered: