-
Notifications
You must be signed in to change notification settings - Fork 17
68 lines (60 loc) · 2.11 KB
/
mirror.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
name: Cache Docker Image
on:
workflow_dispatch:
inputs:
image_name:
description: 'Docker image name'
default: 'alpine'
required: true
version:
description: 'Docker image version'
default: 'latest'
required: true
architecture:
description: 'Docker image architecture'
default: 'linux/arm64'
required: true
# schedule:
# - cron: '0 23 * * *'
run-name: Cache ${{ github.event.inputs.architecture }} Docker Image for ${{ github.event.inputs.image_name }}:${{ github.event.inputs.version }}
# concurrency:
# group: ${{ github.workflow }}-${{ github.ref }}
# cancel-in-progress: true
jobs:
update_cache:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set input parameters
id: params
run: |
echo "IMAGE_NAME=${{ github.event.inputs.image_name }}" >> $GITHUB_ENV
echo "VERSION=${{ github.event.inputs.version }}" >> $GITHUB_ENV
echo "ARCHITECTURE=${{ github.event.inputs.architecture }}" >> $GITHUB_ENV
- name: Pull Docker image
run: |
docker pull --platform $ARCHITECTURE $IMAGE_NAME:$VERSION
- name: Save Docker image
run: |
SHA512=$(echo -n "$IMAGE_NAME:$VERSION-$ARCHITECTURE" | sha512sum | awk '{print $1}')
echo "SHA512=${SHA512}" >> $GITHUB_ENV
docker save $IMAGE_NAME:$VERSION -o ${SHA512}.tar
- name: compress Docker image
run: |
tar -cJf ${SHA512}.tar.xz ${SHA512}.tar
rm ${SHA512}.tar
echo "Compressed to ${SHA512}.tar.xz"
- name: Upload to Release
uses: ncipollo/release-action@main
with:
tag: mirror
artifacts: "*.tar.xz"
allowUpdates: true
removeArtifacts: false
replacesArtifacts: true
makeLatest: false
token: ${{ secrets.GITHUB_TOKEN }}
body: |
Docker images cache mirror. don't forget to enable longpath. git config --global core.longpaths true
https://github.com/feicong/ebpf-course