Compare commits
9 Commits
2.0
...
2.6-runner
| Author | SHA1 | Date | |
|---|---|---|---|
| df42190f94 | |||
| 35cbac9328 | |||
| 3245bac439 | |||
| a2fc48b06b | |||
| 57991727fa | |||
| 4cbb470ff5 | |||
| 9bac7be2b6 | |||
| 33995326a8 | |||
| 9e3c20e751 |
@@ -1,66 +0,0 @@
|
|||||||
name: ci/cd to build and push docker image in private registry
|
|
||||||
|
|
||||||
#https://docs.docker.com/build/ci/github-actions/push-multi-registries/
|
|
||||||
#https://www.devsync.se/ci/cd/docker/2023/10/27/gitea-runner-build-docker-containers.html
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
tags:
|
|
||||||
- '*'
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build-push-docker-image:
|
|
||||||
# see on runner /data/.runner to add label (test => test:docker://debian:bullseye)
|
|
||||||
runs-on: test
|
|
||||||
container: debian:bullseye
|
|
||||||
# runs-on: ubuntu-latest
|
|
||||||
# container: node:16-bullseye
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: Print version and repository
|
|
||||||
run: echo "Runner working on repository ${{ gitea.repository }} and on tag ${{ gitea.ref_name }}"
|
|
||||||
|
|
||||||
- name: Install nodejs and dnsutils and git for github action
|
|
||||||
run: |
|
|
||||||
apt-get update
|
|
||||||
apt-get -y install nodejs dnsutils git
|
|
||||||
|
|
||||||
- name: Git clone private repo
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
with:
|
|
||||||
repository: ${{ gitea.repository }}
|
|
||||||
token: ${{ secrets.ACCESS_TOKEN_GIT }}
|
|
||||||
|
|
||||||
- name: Install Docker
|
|
||||||
run: |
|
|
||||||
apt-get update
|
|
||||||
apt-get -y install ca-certificates curl gnupg
|
|
||||||
install -m 0755 -d /etc/apt/keyrings
|
|
||||||
curl -fsSL https://download.docker.com/linux/debian/gpg | gpg --dearmor -o /etc/apt/keyrings/docker.gpg
|
|
||||||
chmod a+r /etc/apt/keyrings/docker.gpg
|
|
||||||
echo "deb [arch="$(dpkg --print-architecture)" signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/debian "$(. /etc/os-release && echo "$VERSION_CODENAME")" stable" | tee /etc/apt/sources.list.d/docker.list > /dev/null
|
|
||||||
apt-get update
|
|
||||||
apt-get -y install docker-ce docker-ce-cli containerd.io docker-buildx-plugin
|
|
||||||
|
|
||||||
# - name: Git clone private repo
|
|
||||||
# uses: actions/checkout@v4
|
|
||||||
# with:
|
|
||||||
# repository: ${{ gitea.repository }}
|
|
||||||
# token: ${{ secrets.ACCESS_TOKEN_GIT }}
|
|
||||||
|
|
||||||
- name: Login to docker private registry
|
|
||||||
uses: docker/login-action@v3
|
|
||||||
with:
|
|
||||||
registry: ${{ vars.REGISTRY_DOCKER }}
|
|
||||||
username: ${{ secrets.REGISTRY_DOCKER_USER }}
|
|
||||||
password: ${{ secrets.REGISTRY_DOCKER_PASS }}
|
|
||||||
|
|
||||||
- name: Build and push image in registry
|
|
||||||
uses: docker/build-push-action@v5
|
|
||||||
with:
|
|
||||||
context: .
|
|
||||||
push: true
|
|
||||||
tags: ${{ vars.REGISTRY_DOCKER }}/${{ vars.DOCKER_IMAGE_NAME }}:latest,${{ vars.REGISTRY_DOCKER }}/${{ vars.DOCKER_IMAGE_NAME }}:${{ gitea.ref_name }}
|
|
||||||
|
|
||||||
- name: Show docker images
|
|
||||||
run: docker images
|
|
||||||
51
.gitea/workflows/build_image_debian_runner.yml
Normal file
51
.gitea/workflows/build_image_debian_runner.yml
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
name: ci/cd to build and push docker image in private registry
|
||||||
|
|
||||||
|
#https://docs.docker.com/build/ci/github-actions/push-multi-registries/
|
||||||
|
#https://www.devsync.se/ci/cd/docker/2023/10/27/gitea-runner-build-docker-containers.html
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
tags:
|
||||||
|
- '*-runner'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build-and-push-debian-runner:
|
||||||
|
# see on runner /data/.runner to add label (test => test:docker://debian:bullseye)
|
||||||
|
# runs-on: test
|
||||||
|
# container: debian:bullseye
|
||||||
|
# runs-on: ubuntu-latest
|
||||||
|
# container: node:16-bullseye
|
||||||
|
runs-on: debian-runner
|
||||||
|
container:
|
||||||
|
image: ${{ vars.REGISTRY_DOCKER }}/${{ vars.DOCKER_IMAGE_NAME }}:latest
|
||||||
|
credentials:
|
||||||
|
username: ${{ secrets.REGISTRY_DOCKER_USER }}
|
||||||
|
password: ${{ secrets.REGISTRY_DOCKER_PASS }}
|
||||||
|
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Show Information
|
||||||
|
run: echo "Runner ${{ runner.os }} working on repository ${{ gitea.repository }} and on tag ${{ gitea.ref_name }}"
|
||||||
|
|
||||||
|
- name: Git clone private repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
repository: ${{ gitea.repository }}
|
||||||
|
token: ${{ secrets.ACCESS_TOKEN_GIT }}
|
||||||
|
|
||||||
|
- name: Login to docker private registry
|
||||||
|
uses: docker/login-action@v3
|
||||||
|
with:
|
||||||
|
registry: ${{ vars.REGISTRY_DOCKER }}
|
||||||
|
username: ${{ secrets.REGISTRY_DOCKER_USER }}
|
||||||
|
password: ${{ secrets.REGISTRY_DOCKER_PASS }}
|
||||||
|
|
||||||
|
- name: Build and push image in registry
|
||||||
|
uses: docker/build-push-action@v5
|
||||||
|
with:
|
||||||
|
context: .
|
||||||
|
push: true
|
||||||
|
tags: ${{ vars.REGISTRY_DOCKER }}/${{ vars.DOCKER_IMAGE_NAME }}:latest,${{ vars.REGISTRY_DOCKER }}/${{ vars.DOCKER_IMAGE_NAME }}:${{ gitea.ref_name }}
|
||||||
|
|
||||||
|
- name: Output
|
||||||
|
run: echo "Push on ${{ vars.REGISTRY_DOCKER }} image ${{ vars.DOCKER_IMAGE_NAME }} tag ${{ gitea.ref_name }}"
|
||||||
38
.gitea/workflows/build_package_deb.yml
Normal file
38
.gitea/workflows/build_package_deb.yml
Normal file
@@ -0,0 +1,38 @@
|
|||||||
|
name: build_package_deb
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
tags:
|
||||||
|
- 'v*.*.*'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Git clone private repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
repository: ${{ gitea.repository }}
|
||||||
|
token: ${{ secrets.ACCESS_TOKEN_GIT }}
|
||||||
|
|
||||||
|
- name: create sample script
|
||||||
|
run: |
|
||||||
|
mkdir -p .debpkg/usr/bin
|
||||||
|
mkdir -p .debpkg/usr/lib/samplescript
|
||||||
|
echo -e "echo sample" > .debpkg/usr/bin/samplescript
|
||||||
|
chmod +x .debpkg/usr/bin/samplescript
|
||||||
|
echo -e "a=1" > .debpkg/usr/lib/samplescript/samplescript.conf
|
||||||
|
|
||||||
|
# create DEBIAN directory if you want to add other pre/post scripts
|
||||||
|
mkdir -p .debpkg/DEBIAN
|
||||||
|
echo -e "echo postinst" > .debpkg/DEBIAN/postinst
|
||||||
|
chmod +x .debpkg/DEBIAN/postinst
|
||||||
|
- uses: jiro4989/build-deb-action@v3
|
||||||
|
with:
|
||||||
|
package: samplescript
|
||||||
|
package_root: .debpkg
|
||||||
|
maintainer: jingoh
|
||||||
|
version: ${{ gitea.ref_name }} # refs/tags/v*.*.*
|
||||||
|
arch: 'amd64'
|
||||||
|
depends: 'libc6 (>= 2.2.1), git'
|
||||||
|
desc: 'this is sample package.'
|
||||||
31
Dockerfile
31
Dockerfile
@@ -1,9 +1,30 @@
|
|||||||
|
|
||||||
# Container image that runs your code
|
# Container image that runs your code
|
||||||
FROM alpine:3.10
|
FROM debian:bullseye
|
||||||
|
|
||||||
# Copies your code file from your action repository to the filesystem path `/` of the container
|
ENV NODE_MAJOR 16
|
||||||
COPY entrypoint.sh /entrypoint.sh
|
|
||||||
|
|
||||||
# Code file to execute when the docker container starts up (`entrypoint.sh`)
|
# install dependancies packages
|
||||||
ENTRYPOINT ["/entrypoint.sh"]
|
RUN apt-get update \
|
||||||
|
&& apt-get install -y curl \
|
||||||
|
dnsutils \
|
||||||
|
git \
|
||||||
|
ca-certificates \
|
||||||
|
gnupg
|
||||||
|
|
||||||
|
# NODE
|
||||||
|
RUN install -m 0755 -d /etc/apt/keyrings
|
||||||
|
RUN curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg
|
||||||
|
RUN echo "deb [signed-by=/etc/apt/keyrings/nodesource.gpg] https://deb.nodesource.com/node_$NODE_MAJOR.x nodistro main" | tee /etc/apt/sources.list.d/nodesource.list
|
||||||
|
|
||||||
|
# DOCKER
|
||||||
|
RUN curl -fsSL https://download.docker.com/linux/debian/gpg | gpg --dearmor -o /etc/apt/keyrings/docker.gpg
|
||||||
|
RUN chmod a+r /etc/apt/keyrings/docker.gpg
|
||||||
|
RUN echo "deb [arch="$(dpkg --print-architecture)" signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/debian "$(. /etc/os-release && echo "$VERSION_CODENAME")" stable" | tee /etc/apt/sources.list.d/docker.list > /dev/null
|
||||||
|
|
||||||
|
RUN apt-get update \
|
||||||
|
&& apt-get install -y nodejs \
|
||||||
|
docker-ce \
|
||||||
|
docker-ce-cli \
|
||||||
|
containerd.io \
|
||||||
|
docker-buildx-plugin
|
||||||
14
README.md
14
README.md
@@ -1,13 +1 @@
|
|||||||
Création d'un nouveau dépôt en ligne de commande
|
# Docker debian runner (node and docker)
|
||||||
|
|
||||||
touch README.md
|
|
||||||
git init
|
|
||||||
git checkout -b main
|
|
||||||
git add README.md
|
|
||||||
git commit -m "first commit"
|
|
||||||
git remote add origin ssh://git@gitea.jingoh.fr:443/staffadmin/gitea-runner.git
|
|
||||||
git push -u origin main
|
|
||||||
Soumission d'un dépôt existant par ligne de commande
|
|
||||||
|
|
||||||
git remote add origin ssh://git@gitea.jingoh.fr:443/staffadmin/gitea-runner.git
|
|
||||||
git push -u origin main
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
#!/bin/sh -l
|
|
||||||
|
|
||||||
echo "Hello $1"
|
|
||||||
time=$(date)
|
|
||||||
echo "time=$time" >> $GITHUB_OUTPUT
|
|
||||||
Reference in New Issue
Block a user