mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 13:36:27 +00:00 
			
		
		
		
	Merge #3566
3566: Improve docker cache r=curquiza a=inductor # Pull Request ## Related issue Fixes #<issue_number> ## What does this PR do? - Use `--mount=type=cache` and GHA build cache for faster build - `=> => transferring context: 75.37MB` to `=> => transferring context: 19.21MB` with `.dockerignore` ## PR checklist Please check if your PR fulfills the following requirements: - [ ] Does this PR fix an existing issue, or have you listed the changes applied in the PR description (and why they are needed)? - [x] Have you read the contributing guidelines? - [x] Have you made sure that the title is accurate and descriptive of the changes? Thank you so much for contributing to Meilisearch! Co-authored-by: inductor <kela@inductor.me> Co-authored-by: Clémentine Urquizar - curqui <clementine@meilisearch.com>
This commit is contained in:
		| @@ -2,3 +2,4 @@ target | |||||||
| Dockerfile | Dockerfile | ||||||
| .dockerignore | .dockerignore | ||||||
| .gitignore | .gitignore | ||||||
|  | **/.git | ||||||
|   | |||||||
							
								
								
									
										7
									
								
								.github/workflows/publish-docker-images.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								.github/workflows/publish-docker-images.yml
									
									
									
									
										vendored
									
									
								
							| @@ -58,9 +58,13 @@ jobs: | |||||||
|  |  | ||||||
|       - name: Set up QEMU |       - name: Set up QEMU | ||||||
|         uses: docker/setup-qemu-action@v2 |         uses: docker/setup-qemu-action@v2 | ||||||
|  |         with: | ||||||
|  |           platforms: linux/amd64,linux/arm64 | ||||||
|  |  | ||||||
|       - name: Set up Docker Buildx |       - name: Set up Docker Buildx | ||||||
|         uses: docker/setup-buildx-action@v2 |         uses: docker/setup-buildx-action@v2 | ||||||
|  |         with: | ||||||
|  |           platforms: linux/amd64,linux/arm64 | ||||||
|  |  | ||||||
|       - name: Login to Docker Hub |       - name: Login to Docker Hub | ||||||
|         uses: docker/login-action@v2 |         uses: docker/login-action@v2 | ||||||
| @@ -88,10 +92,13 @@ jobs: | |||||||
|           push: true |           push: true | ||||||
|           platforms: linux/amd64,linux/arm64 |           platforms: linux/amd64,linux/arm64 | ||||||
|           tags: ${{ steps.meta.outputs.tags }} |           tags: ${{ steps.meta.outputs.tags }} | ||||||
|  |           builder: ${{ steps.buildx.outputs.name }} | ||||||
|           build-args: | |           build-args: | | ||||||
|             COMMIT_SHA=${{ github.sha }} |             COMMIT_SHA=${{ github.sha }} | ||||||
|             COMMIT_DATE=${{ steps.build-metadata.outputs.date }} |             COMMIT_DATE=${{ steps.build-metadata.outputs.date }} | ||||||
|             GIT_TAG=${{ github.ref_name }} |             GIT_TAG=${{ github.ref_name }} | ||||||
|  |           cache-from: type=gha | ||||||
|  |           cache-to: type=gha,mode=max | ||||||
|  |  | ||||||
|       # /!\ Don't touch this without checking with Cloud team |       # /!\ Don't touch this without checking with Cloud team | ||||||
|       - name: Send CI information to Cloud team |       - name: Send CI information to Cloud team | ||||||
|   | |||||||
| @@ -1,3 +1,4 @@ | |||||||
|  | # syntax=docker/dockerfile:1.4 | ||||||
| # Compile | # Compile | ||||||
| FROM    rust:alpine3.16 AS compiler | FROM    rust:alpine3.16 AS compiler | ||||||
|  |  | ||||||
| @@ -11,7 +12,7 @@ ARG     GIT_TAG | |||||||
| ENV     VERGEN_GIT_SHA=${COMMIT_SHA} VERGEN_GIT_COMMIT_TIMESTAMP=${COMMIT_DATE} VERGEN_GIT_SEMVER_LIGHTWEIGHT=${GIT_TAG} | ENV     VERGEN_GIT_SHA=${COMMIT_SHA} VERGEN_GIT_COMMIT_TIMESTAMP=${COMMIT_DATE} VERGEN_GIT_SEMVER_LIGHTWEIGHT=${GIT_TAG} | ||||||
| ENV     RUSTFLAGS="-C target-feature=-crt-static" | ENV     RUSTFLAGS="-C target-feature=-crt-static" | ||||||
|  |  | ||||||
| COPY    . . | COPY    --link . . | ||||||
| RUN     set -eux; \ | RUN     set -eux; \ | ||||||
|         apkArch="$(apk --print-arch)"; \ |         apkArch="$(apk --print-arch)"; \ | ||||||
|         if [ "$apkArch" = "aarch64" ]; then \ |         if [ "$apkArch" = "aarch64" ]; then \ | ||||||
| @@ -30,7 +31,7 @@ RUN     apk update --quiet \ | |||||||
|  |  | ||||||
| # add meilisearch to the `/bin` so you can run it from anywhere and it's easy | # add meilisearch to the `/bin` so you can run it from anywhere and it's easy | ||||||
| # to find. | # to find. | ||||||
| COPY    --from=compiler /meilisearch/target/release/meilisearch /bin/meilisearch | COPY    --from=compiler --link /meilisearch/target/release/meilisearch /bin/meilisearch | ||||||
| # To stay compatible with the older version of the container (pre v0.27.0) we're | # To stay compatible with the older version of the container (pre v0.27.0) we're | ||||||
| # going to symlink the meilisearch binary in the path to `/meilisearch` | # going to symlink the meilisearch binary in the path to `/meilisearch` | ||||||
| RUN     ln -s /bin/meilisearch /meilisearch | RUN     ln -s /bin/meilisearch /meilisearch | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user