12 Commits
1.0.16 ... main

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
8 changed files with 52 additions and 20 deletions

View File

@@ -14,6 +14,9 @@ jobs:
name: Build image name: Build image
runs-on: ubuntu-22.04 runs-on: ubuntu-22.04
container: catthehacker/ubuntu:act-latest container: catthehacker/ubuntu:act-latest
env:
REGISTRY: git.realmanual.ru
IMAGE_NAME: ${{ gitea.repository }}
steps: steps:
- name: Checkout repository - name: Checkout repository
uses: actions/checkout@v4 uses: actions/checkout@v4
@@ -21,7 +24,7 @@ jobs:
- name: Log in to the Container registry - name: Log in to the Container registry
uses: docker/login-action@v3 uses: docker/login-action@v3
with: with:
registry: git.realmanual.ru registry: ${{ env.REGISTRY }}
username: ${{ gitea.actor }} username: ${{ gitea.actor }}
password: ${{ secrets.PUSH_TOKEN }} password: ${{ secrets.PUSH_TOKEN }}
@@ -32,5 +35,5 @@ jobs:
context: . context: .
push: true push: true
tags: | tags: |
${{ gitea.registry }}/${{ gitea.repository }}:${{ gitea.ref_name }} ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ gitea.ref_name }}
${{ gitea.registry }}/${{ gitea.repository }}:latest ${{ 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