| 
									
										
										
										
											2020-09-21 19:06:04 +00:00
										 |  |  | # Troubleshooting
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-23 20:51:59 +00:00
										 |  |  | * [Cannot push to a registry](#cannot-push-to-a-registry) | 
					
						
							| 
									
										
										
										
											2021-04-27 14:16:22 +00:00
										 |  |  |   * [BuildKit container logs](#buildkit-container-logs) | 
					
						
							|  |  |  |   * [With containerd](#with-containerd) | 
					
						
							| 
									
										
										
										
											2021-08-05 06:09:50 +00:00
										 |  |  | * [`repository name must be lowercase`](#repository-name-must-be-lowercase) | 
					
						
							| 
									
										
										
										
											2020-10-23 20:51:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | ## Cannot push to a registry
 | 
					
						
							| 
									
										
										
										
											2020-09-21 19:06:04 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | While pushing to a registry, you may encounter these kinds of issues: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | * `failed commit on ref "layer-sha256:...": invalid content digest in response: invalid checksum digest format` | 
					
						
							|  |  |  | * `failed commit on ref "layer-sha256:...": no response` | 
					
						
							| 
									
										
										
										
											2020-10-08 18:37:39 +00:00
										 |  |  | * `failed commit on ref "manifest-sha256:...": unexpected status: 400 Bad Request` | 
					
						
							| 
									
										
										
										
											2020-09-21 19:06:04 +00:00
										 |  |  | * `failed commit on ref "manifest-sha256:...": unexpected status: 401 Unauthorized` | 
					
						
							|  |  |  | * `unexpected response: 401 Unauthorized` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-05 06:09:50 +00:00
										 |  |  | These issues are not directly related to this action but are rather linked to | 
					
						
							|  |  |  | [buildx](https://github.com/docker/buildx), [buildkit](https://github.com/moby/buildkit), | 
					
						
							|  |  |  | [containerd](https://github.com/containerd/containerd) or the registry on which | 
					
						
							|  |  |  | you're pushing your image. The quality of error message depends on the registry | 
					
						
							|  |  |  | and are usually not very informative. | 
					
						
							| 
									
										
										
										
											2020-09-21 19:06:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-27 14:16:22 +00:00
										 |  |  | ### BuildKit container logs
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-23 21:34:43 +00:00
										 |  |  | To help you solve this, you have to [enable debugging in the setup-buildx](https://github.com/docker/setup-buildx-action#buildkit-container-logs) | 
					
						
							|  |  |  | action step and attach BuildKit container logs to your issue. | 
					
						
							| 
									
										
										
										
											2020-09-21 19:06:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-27 14:16:22 +00:00
										 |  |  | ### With containerd
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-05 06:09:50 +00:00
										 |  |  | Next you can test pushing with [containerd action](https://github.com/crazy-max/ghaction-setup-containerd) | 
					
						
							|  |  |  | using the following workflow. If it works then open an issue on [buildkit](https://github.com/moby/buildkit) | 
					
						
							|  |  |  | repository. | 
					
						
							| 
									
										
										
										
											2020-10-08 18:37:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | ```yaml | 
					
						
							|  |  |  | name: containerd | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | on: | 
					
						
							|  |  |  |   push: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | jobs: | 
					
						
							|  |  |  |   containerd: | 
					
						
							|  |  |  |     runs-on: ubuntu-latest | 
					
						
							|  |  |  |     steps: | 
					
						
							| 
									
										
										
										
											2020-10-23 20:51:59 +00:00
										 |  |  |       - | 
					
						
							| 
									
										
										
										
											2020-10-08 18:37:39 +00:00
										 |  |  |         name: Checkout | 
					
						
							|  |  |  |         uses: actions/checkout@v2 | 
					
						
							|  |  |  |       - | 
					
						
							|  |  |  |         name: Set up QEMU | 
					
						
							|  |  |  |         uses: docker/setup-qemu-action@v1 | 
					
						
							|  |  |  |       - | 
					
						
							|  |  |  |         name: Set up Docker Buildx | 
					
						
							|  |  |  |         uses: docker/setup-buildx-action@v1 | 
					
						
							|  |  |  |         with: | 
					
						
							|  |  |  |           buildkitd-flags: --debug | 
					
						
							|  |  |  |       - | 
					
						
							|  |  |  |         name: Set up containerd | 
					
						
							|  |  |  |         uses: crazy-max/ghaction-setup-containerd@v1 | 
					
						
							|  |  |  |       - | 
					
						
							|  |  |  |         name: Build Docker image | 
					
						
							|  |  |  |         uses: docker/build-push-action@v2 | 
					
						
							|  |  |  |         with: | 
					
						
							|  |  |  |           context: . | 
					
						
							| 
									
										
										
										
											2021-02-17 17:53:15 +00:00
										 |  |  |           platforms: linux/amd64,linux/arm64 | 
					
						
							| 
									
										
										
										
											2020-10-08 18:37:39 +00:00
										 |  |  |           tags: docker.io/user/app:latest | 
					
						
							|  |  |  |           outputs: type=oci,dest=/tmp/image.tar | 
					
						
							|  |  |  |       - | 
					
						
							|  |  |  |         name: Import image in containerd | 
					
						
							|  |  |  |         run: | | 
					
						
							|  |  |  |           sudo ctr i import --base-name docker.io/user/app --digests --all-platforms /tmp/image.tar | 
					
						
							|  |  |  |       - | 
					
						
							|  |  |  |         name: Push image with containerd | 
					
						
							|  |  |  |         run: | | 
					
						
							|  |  |  |           sudo ctr --debug i push --user "${{ secrets.DOCKER_USERNAME }}:${{ secrets.DOCKER_PASSWORD }}" docker.io/user/app:latest | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2021-08-05 06:09:50 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | ## `repository name must be lowercase`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | You may encounter this issue if you're using `github.repository` as a repo slug | 
					
						
							|  |  |  | in your tag: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | #6 exporting to image
 | 
					
						
							|  |  |  | #6 exporting layers
 | 
					
						
							|  |  |  | #6 exporting layers 1.2s done
 | 
					
						
							|  |  |  | #6 exporting manifest sha256:b47f7dfb97b89ccd5de553af3c8cd94c4795884cbe5693e93946b1d95a7b1d12 0.0s done
 | 
					
						
							|  |  |  | #6 exporting config sha256:995e93fab8196893192f08a38deea6769dc4d98f86cf705eccc24ec96a3e271c 0.0s done
 | 
					
						
							|  |  |  | #6 ERROR: invalid reference format: repository name must be lowercase
 | 
					
						
							|  |  |  | ------ | 
					
						
							|  |  |  |  > exporting to image:
 | 
					
						
							|  |  |  | ------ | 
					
						
							|  |  |  | error: failed to solve: invalid reference format: repository name must be lowercase | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | or a cache reference: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | #10 importing cache manifest from ghcr.io/My-Org/repo:main
 | 
					
						
							|  |  |  | #10 ERROR: invalid reference format: repository name must be lowercase
 | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | To fix this issue you can use our [metadata action](https://github.com/docker/metadata-action) | 
					
						
							| 
									
										
										
										
											2021-10-02 16:37:02 +00:00
										 |  |  | to generate sanitized tags: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ```yaml | 
					
						
							|  |  |  | - name: Docker meta | 
					
						
							|  |  |  |   id: meta | 
					
						
							|  |  |  |   uses: docker/metadata-action@v3 | 
					
						
							|  |  |  |   with: | 
					
						
							|  |  |  |     images: ghcr.io/${{ github.repository }} | 
					
						
							|  |  |  |     tags: latest | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - name: Build and push | 
					
						
							|  |  |  |   uses: docker/build-push-action@v2 | 
					
						
							|  |  |  |   with: | 
					
						
							|  |  |  |     context: . | 
					
						
							|  |  |  |     push: true | 
					
						
							|  |  |  |     tags: ${{ steps.meta.outputs.tags }} | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Or a dedicated step to sanitize the slug: | 
					
						
							| 
									
										
										
										
											2021-08-05 06:09:50 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | ```yaml | 
					
						
							|  |  |  | - name: Sanitize repo slug | 
					
						
							|  |  |  |   uses: actions/github-script@v4 | 
					
						
							|  |  |  |   id: repo_slug | 
					
						
							|  |  |  |   with: | 
					
						
							|  |  |  |     result-encoding: string | 
					
						
							| 
									
										
										
										
											2021-10-02 16:37:02 +00:00
										 |  |  |     script: return 'ghcr.io/${{ github.repository }}'.toLowerCase() | 
					
						
							| 
									
										
										
										
											2021-08-05 06:09:50 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | - name: Build and push | 
					
						
							|  |  |  |   uses: docker/build-push-action@v2 | 
					
						
							|  |  |  |   with: | 
					
						
							|  |  |  |     context: . | 
					
						
							|  |  |  |     push: true | 
					
						
							|  |  |  |     tags: ${{ steps.repo_slug.outputs.result }}:latest | 
					
						
							|  |  |  | ``` |