Skip to content
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

Add caching to gitlab-ci example #4

Open
ochorocho opened this issue Jun 7, 2024 · 11 comments
Open

Add caching to gitlab-ci example #4

ochorocho opened this issue Jun 7, 2024 · 11 comments

Comments

@ochorocho
Copy link
Collaborator

Caching the downloaded docker images on a project base would make sense to speed up builds.
Currently, all images are download on each and every job run.

@rfay
Copy link
Member

rfay commented Jun 7, 2024

Our experience with trying to cache images in GitHub hasn't been very successful, largely because just saving them or extracting them takes more time than downloading them in the first place.

@ayalon
Copy link

ayalon commented Oct 31, 2024

@rfay @ochorocho
I was thinking a lot about how we could cache the pipeline stuff.
For the moment, this is the biggest draw back of this approach.

I was thinking of a possible solution.

Is DDEV somehow capable of building and pushing a docker image to a registry?

If this would be possible, we could somehow check if the DDEV configuration has changed (maybe a salt.txt file or similar).
In the pipeline we start and build a DDEV container first and push the resulting docker image to the registry like that:
docker push $CI_REGISTRY_IMAGE:$DDEV_SALT

If the DDEV configuration did not change, we can just pull the image from the registry and run the ddev tests.

Or are there other ideas how to avoid the constant download of all docker layers within the container?

@rfay
Copy link
Member

rfay commented Oct 31, 2024

DDEV's docker images are all in the hub.docker.com registry. That's the problem here, we don't have a way to efficiently store the images locally. Downloading them doesn't take long, but unpacking/extracting does take a long time. So caching locally (which isn't hard) still takes a long time because the extraction into the local (fresh) docker instance does take time even if the download is fast.

@ayalon
Copy link

ayalon commented Oct 31, 2024

But isn't DDEV building a new docker image with docker compose?

Locally I can profit from the fact, that the layer are cached. I understand that downloading is as fast as geting them from the cache.

But I thought We could put the resulting image from docker compose which uses the DDEV docker images as a base could be pushed to a registry and reused.

Or is there another mechanism possibly speed up the process? Instead of running Docker-in-Docker, we build the DDEV final docker image, then push it to gitlab registry and in the next step we run the tests inside this prebuild DDEV image.

Maybe this is also the wrong approach. Do you have another idea? We are using kaniko to build and push docker images and I was imaging that this could be a way to save some resources in the pipeline.

@rfay
Copy link
Member

rfay commented Oct 31, 2024

DDEV adds a new layer to the image at start, but the key problem with testing is the (download and) extraction of the base image, especially ddev/ddev-webserver. The addition of the extra layers (for username, etc.) takes nearly no time. You can watch it yourself on a ddev start. The dots show the build time.

IMO the general problem is figuring out how to have the actual docker server persist state, so that images are ready there when they're needed.

@ayalon
Copy link

ayalon commented Oct 31, 2024

Ok I understand. You are absolutely right. Unfortunatly I lack the knowledge how to do that. I'm not even sure that it is technically possible.

But I agree that if the base image would be available, the process would be very fast.

@ochorocho
Copy link
Collaborator Author

If the images are stored in ddev itself and not in the DIND-Service image we could certainly extend the image to contain the images.
Just dunno if these images vary depending on the service version in use.

I'd like to keep this image small if possible.

ddev/ddev#4479

@rfay
Copy link
Member

rfay commented Oct 31, 2024

You point to

for some reason... but that was fixed ages ago so ddev debug download-images does not require a project.

@ochorocho
Copy link
Collaborator Author

👍 my intention was to use ddev debug download-images to download the images and ship this image with the images pre-downloaded.

@rfay
Copy link
Member

rfay commented Oct 31, 2024

Will be great to see how that comes out!

@ayalon
Copy link

ayalon commented Oct 31, 2024

Great idea! That make things faster for sure!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants