Compare commits

...

2 Commits

Author SHA1 Message Date
Nikolai Rodionov
9ca9af0ab3
test buildah in actions 2023-06-20 10:07:30 +02:00
Nikolai Rodionov
0f5c7a81a2
test buildah in actions 2023-06-20 10:06:54 +02:00
4 changed files with 52 additions and 56 deletions

48
.github/workflows/build-container.yaml vendored Normal file
View File

@ -0,0 +1,48 @@
---
name: "Build container"
on:
push:
jobs:
containerization:
runs-on: ubuntu-latest
permissions:
packages: write
strategy:
fail-fast: false
matrix:
include:
- arch: amd64
- arch: arm64
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Install buildah
run: sudo apt update && sudo apt install -y podman buildah qemu-user-static
- name: Set version tag (only if triggered by pushing a tag)
if: startsWith(github.ref, 'refs/tags/v')
run: echo "TAG=${GITHUB_REF##*/}" >> $GITHUB_ENV
- name: Set latest tag (only if triggered by pushing to the main branch)
if: github.ref == 'main'
run: echo "TAG=latest" >> $GITHUB_ENV
- name: Set action link variable
run: echo "LINK=$GITHUB_SERVER_URL/$GITHUB_REPOSITORY/actions/runs/$GITHUB_RUN_ID" >> $GITHUB_ENV
- name: Login in gchr registry
run: buildah login --username ${{ github.repository_owner }} --password ${{ secrets.GITHUB_TOKEN }} ghcr.io
- name: Build an image
run: |
buildah bud -t ghcr.io/${{ github.repository }}:${{ github.sha }}-${{ matrix.arch }} \
--label action_id=${{ github.action }} \
--label action_link=${{ env.LINK }} \
--label actor=${{ github.actor }} \
--label sha=${{ github.sha }} \
--label ref=${{ github.ref }} \
.

View File

@ -1,52 +0,0 @@
---
name: "Latest container"
on:
push:
branches:
- main
jobs:
containerization:
runs-on: ubuntu-latest
permissions:
packages: write
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Set action link variable
run: echo "LINK=$GITHUB_SERVER_URL/$GITHUB_REPOSITORY/actions/runs/$GITHUB_RUN_ID" >> $GITHUB_ENV
- name: Set up QEMU
uses: docker/setup-qemu-action@master
with:
platforms: all
- name: Set up Docker Buildx
id: buildx
uses: docker/setup-buildx-action@master
- name: Login to GitHub Container Registry
uses: docker/login-action@v2
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Build
uses: docker/build-push-action@v3
with:
builder: ${{ steps.buildx.outputs.name }}
context: .
file: ./Dockerfile
platforms: linux/amd64,linux/arm64
push: true
tags: |
ghcr.io/${{ github.repository }}:latest
labels: |
action_id=${{ github.action }}
action_link=${{ env.LINK }}
actor=${{ github.actor }}
sha=${{ github.sha }}
ref=${{ github.ref }}

View File

@ -1,4 +1,4 @@
FROM rust:1.70.0-slim-bookworm as builder FROM registry.hub.docker.com/library/rust:1.70.0-slim-bookworm as builder
WORKDIR /src WORKDIR /src
RUN apt-get update &&\ RUN apt-get update &&\
apt-get install -y libssl-dev gcc musl pkg-config apt-get install -y libssl-dev gcc musl pkg-config
@ -9,9 +9,9 @@ RUN cargo build --release --jobs 2 -Z sparse-registry
FROM debian:stable FROM debian:stable
COPY --from=builder /src/target/release/dudo /bin/dudo COPY --from=builder /src/target/release/dudo /bin/dudo
RUN apt-get update &&\ RUN apt-get update -y &&\
apt-get install openssl ca-certificates &&\ apt-get install openssl ca-certificates -y &&\
apt-get clean apt-get clean -y
RUN chmod +x /bin/dudo RUN chmod +x /bin/dudo
WORKDIR /workdir WORKDIR /workdir
ENTRYPOINT ["/bin/dudo"] ENTRYPOINT ["/bin/dudo"]