22 Commits

Author SHA1 Message Date
49e777ece1 Упрощен скрипт entrypoint.sh: изменен путь для crontab, улучшен вывод при запуске crond, добавлена обработка ошибок.
All checks were successful
docker-build / Build image (push) Successful in 1m59s
2025-09-08 12:17:21 +07:00
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 68 additions and 70 deletions

View File

@@ -11,60 +11,29 @@ permissions:
jobs: jobs:
build: build:
runs-on: dind name: Build image
services: runs-on: ubuntu-22.04
docker: container: catthehacker/ubuntu:act-latest
image: docker:dind
env:
DOCKER_TLS_CERTDIR: ""
container:
image: docker:24-git
env:
DOCKER_HOST: tcp://docker:2375
DOCKER_TLS_CERTDIR: ""
env: env:
REGISTRY: hub.realmanual.ru REGISTRY: git.realmanual.ru
IMAGE_NAME: pub/sqlite-backup/backup IMAGE_NAME: ${{ gitea.repository }}
steps: steps:
- name: Checkout (git) - name: Checkout repository
shell: sh uses: actions/checkout@v4
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: Extract tag - name: Log in to the Container registry
id: vars uses: docker/login-action@v3
shell: sh with:
run: | registry: ${{ env.REGISTRY }}
TAG_REF="${GITHUB_REF#refs/tags/}" username: ${{ gitea.actor }}
echo "tag=$TAG_REF" >> "$GITHUB_OUTPUT" password: ${{ secrets.PUSH_TOKEN }}
- name: Docker login - name: Build and push Docker image
shell: sh id: push
run: | uses: docker/build-push-action@v6
set -eu with:
echo "${{ secrets.GITEA_TOKEN }}" | docker login "${{ env.REGISTRY }}" --username "${{ github.actor }}" --password-stdin context: .
push: true
- name: Build image tags: |
shell: sh ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ gitea.ref_name }}
run: | ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:latest
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"

1
.gitignore vendored
View File

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

View File

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

View File

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

View File

@@ -1,6 +1,9 @@
#!/bin/bash #!/bin/bash
DOCKER_BASEIMAGE=alpine:latest TAG=$1
docker buildx build --platform linux/amd64,linux/arm64 --push -t hub.realmanual.ru/pub/sqlite-backup \ if [ -z "$TAG" ]; then
--build-arg DOCKER_BASEIMAGE=${DOCKER_BASEIMAGE} . 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: services:
sqlite_backup: 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 container_name: sqlite_backup
restart: always restart: always
volumes: volumes:

View File

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

View File

@@ -1,6 +1,21 @@
#!/bin/bash #!/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 case $1 in
copy) copy)
@@ -8,11 +23,11 @@ case $1 in
rclone copy --progress $2 $3 rclone copy --progress $2 $3
;; ;;
list) list)
echo "list $2" echo "list ${MINIO_PATH}/$2"
rclone ls $2 rclone ls ${MINIO_PATH}/$2
;; ;;
delete) delete)
echo "delete $2" echo "delete ${MINIO_PATH}/$2"
rclone delete $2 rclone delete ${MINIO_PATH}/$2
;; ;;
esac esac