21 Commits

Author SHA1 Message Date
4d2e79fef7 Обновлен файл .gitignore для игнорирования директории var/*, изменена конфигурация сервиса sqlite_backup в docker-compose.yml для сборки из Dockerfile, обновлен базовый образ в Dockerfile с alpine:latest на alpine:3.19, изменена команда загрузки rclone с curl на wget, а также изменен вывод скрипта backup.sh в entrypoint.sh для записи логов.
All checks were successful
docker-build / Build image (push) Successful in 23m28s
2025-08-31 21:15:11 +07:00
63f6f969cc Обновлен скрипт entrypoint.sh: добавлены права доступа для crontab, улучшен вывод при запуске crond с отладочной информацией.
All checks were successful
docker-build / Build image (push) Successful in 35s
2025-08-31 20:34:12 +07:00
03fa82b223 Исправлены пути в выводе и командах rclone в скрипте minio_uploader.sh для использования переменной MINIO_PATH.
All checks were successful
docker-build / Build image (push) Successful in 32s
2025-08-31 20:26:09 +07:00
235b1a10d8 Упрощена команда rclone в скрипте minio_uploader.sh, убраны лишние ссылки на myminio.
All checks were successful
docker-build / Build image (push) Successful in 39s
2025-08-31 20:21:56 +07:00
1a01c67759 Исправлена команда rclone в скрипте minio_uploader.sh для корректного копирования файлов без указания целевого пути.
All checks were successful
docker-build / Build image (push) Successful in 1m0s
2025-08-31 20:18:53 +07:00
a45b2cfc60 Добавлен параметр no_check_bucket в скрипт minio_uploader.sh и изменена команда rclone для копирования файлов без пропуска существующих.
All checks were successful
docker-build / Build image (push) Successful in 28s
2025-08-31 20:09:15 +07:00
2b47398f95 Добавлен параметр TAG для указания версии образа в скрипте docker-build.sh и изменена команда rclone в minio_uploader.sh для пропуска существующих файлов.
All checks were successful
docker-build / Build image (push) Successful in 37s
2025-08-31 19:59:44 +07:00
f04c1ec1b9 Изменен адрес образа для сервиса sqlite_backup в docker-compose.yml и обновлена конфигурация crontab в скрипте entrypoint.sh.
All checks were successful
docker-build / Build image (push) Successful in 33s
2025-08-31 19:48:53 +07:00
ca72a0c8f9 Обновлен образ для сервиса sqlite_backup в README.md и изменена конфигурация rclone для работы с Minio в скрипте minio_uploader.sh.
All checks were successful
docker-build / Build image (push) Successful in 31s
2025-08-31 19:39:49 +07:00
7219caa4ff Добавлены переменные окружения REGISTRY и IMAGE_NAME для упрощения конфигурации docker-build.yml.
All checks were successful
docker-build / Build image (push) Successful in 27s
2025-08-27 17:18:40 +07:00
2cd46e37ef Обновлены теги для сборки Docker образа в конфигурации docker-build.yml на использование переменной gitea.registry_name.
Some checks failed
docker-build / Build image (push) Failing after 13s
2025-08-27 17:15:00 +07:00
7c8bfad01f Обновлены теги для сборки Docker образа в конфигурации docker-build.yml на использование переменной gitea.instance.
Some checks failed
docker-build / Build image (push) Failing after 13s
2025-08-27 17:11:31 +07:00
4821316ee9 Обновлены теги для сборки Docker образа в конфигурации docker-build.yml на использование переменной gitea.ref_name.
Some checks failed
docker-build / Build image (push) Failing after 43s
2025-08-27 17:09:43 +07:00
798cd355b2 Исправлены теги для сборки и пуша Docker образа в конфигурации docker-build.yml на использование переменной gitea.repository.
Some checks failed
docker-build / Build image (push) Failing after 14s
2025-08-27 16:54:36 +07:00
eab152e928 Добавлен контейнер catthehacker/ubuntu:act-latest для сборки в конфигурации docker-build.yml.
Some checks failed
docker-build / Build image (push) Failing after 20s
2025-08-27 16:52:13 +07:00
60e7136bcd Упрощена конфигурация docker-build.yml: удалены шаги для извлечения метаданных, изменены теги для сборки и пуша Docker образа.
Some checks failed
docker-build / Build image (push) Failing after 12s
2025-08-27 16:47:23 +07:00
99b5401c38 Изменен адрес реестра контейнеров на git.realmanual.ru в конфигурации docker-build.yml.
Some checks failed
docker-build / Build image (push) Failing after 17s
2025-08-27 16:41:41 +07:00
b6c133bb54 Изменен тип окружения сборки на ubuntu-22.04 в конфигурации docker-build.yml.
Some checks failed
docker-build / Build image (push) Failing after 2m29s
2025-08-27 16:35:01 +07:00
58a1a8ee2f Изменен контейнер для сборки в конфигурации docker-build.yml на git.realmanual.ru/pub/docker-build.
Some checks failed
docker-build / Build image (push) Failing after 37s
2025-08-27 16:31:59 +07:00
bbeebda027 Обновлена конфигурация docker-build.yml: добавлены шаги для извлечения метаданных, изменены действия для логина и сборки образа, улучшен процесс пуша образов.
Some checks failed
docker-build / Build image (push) Failing after 1m17s
2025-08-27 16:20:41 +07:00
267ec22c6f Упрощена конфигурация docker-build.yml: заменены шаги на стандартные действия GitHub Actions, удалены лишние команды и добавлены шаги для логина и сборки Docker образа.
Some checks failed
docker-build / build (push) Failing after 13s
2025-08-27 15:58:59 +07:00
8 changed files with 74 additions and 71 deletions

View File

@@ -11,60 +11,29 @@ permissions:
jobs:
build:
runs-on: dind
services:
docker:
image: docker:dind
env:
DOCKER_TLS_CERTDIR: ""
container:
image: docker:24-git
env:
DOCKER_HOST: tcp://docker:2375
DOCKER_TLS_CERTDIR: ""
name: Build image
runs-on: ubuntu-22.04
container: catthehacker/ubuntu:act-latest
env:
REGISTRY: hub.realmanual.ru
IMAGE_NAME: pub/sqlite-backup/backup
REGISTRY: git.realmanual.ru
IMAGE_NAME: ${{ gitea.repository }}
steps:
- name: Checkout (git)
shell: sh
env:
TOKEN: ${{ secrets.GITEA_TOKEN }}
run: |
set -eu
: "${GITHUB_SERVER_URL:?}"
: "${GITHUB_REPOSITORY:?}"
: "${GITHUB_SHA:?}"
git init .
git remote add origin "${GITHUB_SERVER_URL}/${GITHUB_REPOSITORY}.git"
git -c http.extraHeader="Authorization: Bearer ${TOKEN}" fetch --no-tags --depth=1 origin "${GITHUB_SHA}"
git checkout --detach "${GITHUB_SHA}"
- name: Checkout repository
uses: actions/checkout@v4
- name: Extract tag
id: vars
shell: sh
run: |
TAG_REF="${GITHUB_REF#refs/tags/}"
echo "tag=$TAG_REF" >> "$GITHUB_OUTPUT"
- name: Log in to the Container registry
uses: docker/login-action@v3
with:
registry: ${{ env.REGISTRY }}
username: ${{ gitea.actor }}
password: ${{ secrets.PUSH_TOKEN }}
- name: Docker login
shell: sh
run: |
set -eu
echo "${{ secrets.GITEA_TOKEN }}" | docker login "${{ env.REGISTRY }}" --username "${{ github.actor }}" --password-stdin
- name: Build image
shell: sh
run: |
set -eu
docker build \
-t "${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ steps.vars.outputs.tag }}" \
-t "${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:latest" \
.
- name: Push images
shell: sh
run: |
set -eu
docker push "${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ steps.vars.outputs.tag }}"
docker push "${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:latest"
- name: Build and push Docker image
id: push
uses: docker/build-push-action@v6
with:
context: .
push: true
tags: |
${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ gitea.ref_name }}
${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:latest

1
.gitignore vendored
View File

@@ -1,2 +1,3 @@
.idea
.env
var/*

View File

@@ -1,17 +1,18 @@
FROM alpine:latest
FROM alpine:3.19
ENV TZ=UTC
LABEL maintainer="Vassiliy Yegorov <vasyakrg@gmail.com>"
RUN apk add --no-cache \
sqlite \
curl \
wget \
bash \
tzdata \
openssl
openssl \
&& rm -rf /var/cache/apk/*
RUN curl -O https://downloads.rclone.org/rclone-current-linux-amd64.zip && \
unzip rclone-current-linux-amd64.zip && \
RUN wget https://github.com/rclone/rclone/releases/download/v1.71.0/rclone-v1.71.0-linux-amd64.zip && \
unzip rclone-v1.71.0-linux-amd64.zip && \
cd rclone-*-linux-amd64 && \
cp rclone /usr/bin/ && \
chown root:root /usr/bin/rclone && \

View File

@@ -3,7 +3,7 @@
```yaml
services:
sqlite_backup:
image: hub.realmanual.ru/pub/sqlite-backup/backup:latest
image: git.realmanual.ru/pub/sqlite-backup-s3
container_name: sqlite_backup
restart: always
volumes:

View File

@@ -1,6 +1,9 @@
#!/bin/bash
DOCKER_BASEIMAGE=alpine:latest
TAG=$1
docker buildx build --platform linux/amd64,linux/arm64 --push -t hub.realmanual.ru/pub/sqlite-backup \
--build-arg DOCKER_BASEIMAGE=${DOCKER_BASEIMAGE} .
if [ -z "$TAG" ]; then
TAG=latest
fi
docker buildx build --platform linux/amd64,linux/arm64 --push -t git.realmanual.ru/pub/sqlite-backup:${TAG} .

View File

@@ -1,6 +1,9 @@
services:
sqlite_backup:
image: hub.realmanual.ru/pub/sqlite-backup/backup:latest
# image: git.realmanual.ru/pub/sqlite-backup/backup:latest
build:
context: .
dockerfile: Dockerfile
container_name: sqlite_backup
restart: always
volumes:

View File

@@ -1,6 +1,17 @@
#!/bin/sh
echo "${CRONTAB} /scripts/backup.sh" > /etc/crontabs/root
# Create crontab in a writable location and set proper permissions
mkdir -p /tmp/crontabs
echo "${CRONTAB:-"0 * * * *"} /scripts/backup.sh >> /proc/1/fd/1 2>&1" > /tmp/crontabs/root
chmod 644 /tmp/crontabs/root
/scripts/backup.sh
exec crond -f
# Run initial backup
# /scripts/backup.sh
# Start crond with debug output
echo "Starting crond with config:"
cat /tmp/crontabs/root
echo "---"
# Start crond in foreground with debug output
exec crond -f -c /tmp/crontabs -d 8

View File

@@ -1,6 +1,21 @@
#!/bin/bash
rclone config create myminio s3 provider Minio access_key_id $MINIO_ACCOUNT_ID secret_access_key $MINIO_APPLICATION_KEY endpoint $MINIO_ENDPOINT region $MINIO_LOCATION acl private
# Create rclone config on-the-fly in a writable location
RCLONE_CONFIG_DIR="/tmp/rclone"
mkdir -p "$RCLONE_CONFIG_DIR"
export RCLONE_CONFIG="$RCLONE_CONFIG_DIR/rclone.conf"
cat > "$RCLONE_CONFIG" << EOF
[myminio]
type = s3
provider = Minio
access_key_id = $MINIO_ACCOUNT_ID
secret_access_key = $MINIO_APPLICATION_KEY
endpoint = $MINIO_ENDPOINT
region = $MINIO_LOCATION
acl = private
no_check_bucket = true
EOF
case $1 in
copy)
@@ -8,11 +23,11 @@ case $1 in
rclone copy --progress $2 $3
;;
list)
echo "list $2"
rclone ls $2
echo "list ${MINIO_PATH}/$2"
rclone ls ${MINIO_PATH}/$2
;;
delete)
echo "delete $2"
rclone delete $2
echo "delete ${MINIO_PATH}/$2"
rclone delete ${MINIO_PATH}/$2
;;
esac