mirror of
https://github.com/jkaninda/mysql-bkup.git
synced 2025-12-06 21:49:40 +01:00
84 lines
2.2 KiB
Docker
84 lines
2.2 KiB
Docker
FROM golang:1.22.5 AS build
|
|
WORKDIR /app
|
|
|
|
# Copy the source code.
|
|
COPY . .
|
|
# Installs Go dependencies
|
|
RUN go mod download
|
|
|
|
# Build
|
|
RUN CGO_ENABLED=0 GOOS=linux go build -o /app/mysql-bkup
|
|
|
|
FROM ubuntu:24.04
|
|
ENV DB_HOST="localhost"
|
|
ENV DB_NAME=""
|
|
ENV DB_USERNAME=""
|
|
ENV DB_PASSWORD=""
|
|
ENV DB_PORT=3306
|
|
ENV STORAGE=local
|
|
ENV AWS_S3_ENDPOINT=""
|
|
ENV AWS_S3_BUCKET_NAME=""
|
|
ENV AWS_ACCESS_KEY=""
|
|
ENV AWS_SECRET_KEY=""
|
|
ENV AWS_REGION="us-west-2"
|
|
ENV AWS_S3_PATH=""
|
|
ENV AWS_DISABLE_SSL="false"
|
|
ENV GPG_PASSPHRASE=""
|
|
ENV SSH_USER=""
|
|
ENV SSH_REMOTE_PATH=""
|
|
ENV SSH_PASSWORD=""
|
|
ENV SSH_HOST_NAME=""
|
|
ENV SSH_IDENTIFY_FILE=""
|
|
ENV SSH_PORT="22"
|
|
ENV TARGET_DB_HOST=""
|
|
ENV TARGET_DB_PORT=3306
|
|
ENV TARGET_DB_NAME="localhost"
|
|
ENV TARGET_DB_USERNAME=""
|
|
ENV TARGET_DB_PASSWORD=""
|
|
ARG DEBIAN_FRONTEND=noninteractive
|
|
ENV VERSION="v1.2.8"
|
|
ENV BACKUP_CRON_EXPRESSION=""
|
|
ENV TG_TOKEN=""
|
|
ENV TG_CHAT_ID=""
|
|
ARG WORKDIR="/config"
|
|
ARG BACKUPDIR="/backup"
|
|
ARG BACKUP_TMP_DIR="/tmp/backup"
|
|
ARG BACKUP_CRON="/etc/cron.d/backup_cron"
|
|
ARG BACKUP_CRON_SCRIPT="/usr/local/bin/backup_cron.sh"
|
|
LABEL author="Jonas Kaninda"
|
|
|
|
RUN apt-get update -qq
|
|
RUN apt install mysql-client cron gnupg -y
|
|
|
|
# Clear cache
|
|
RUN apt-get clean && rm -rf /var/lib/apt/lists/*
|
|
|
|
RUN mkdir $WORKDIR
|
|
RUN mkdir $BACKUPDIR
|
|
RUN mkdir -p $BACKUP_TMP_DIR
|
|
RUN chmod 777 $WORKDIR
|
|
RUN chmod 777 $BACKUPDIR
|
|
RUN chmod 777 $BACKUP_TMP_DIR
|
|
RUN touch $BACKUP_CRON && \
|
|
touch $BACKUP_CRON_SCRIPT && \
|
|
chmod 777 $BACKUP_CRON && \
|
|
chmod 777 $BACKUP_CRON_SCRIPT
|
|
|
|
COPY --from=build /app/mysql-bkup /usr/local/bin/mysql-bkup
|
|
RUN chmod +x /usr/local/bin/mysql-bkup
|
|
|
|
RUN ln -s /usr/local/bin/mysql-bkup /usr/local/bin/bkup
|
|
|
|
# Create backup script and make it executable
|
|
RUN echo '#!/bin/sh\n/usr/local/bin/mysql-bkup backup "$@"' > /usr/local/bin/backup && \
|
|
chmod +x /usr/local/bin/backup
|
|
# Create restore script and make it executable
|
|
RUN echo '#!/bin/sh\n/usr/local/bin/mysql-bkup restore "$@"' > /usr/local/bin/restore && \
|
|
chmod +x /usr/local/bin/restore
|
|
# Create migrate script and make it executable
|
|
RUN echo '#!/bin/sh\n/usr/local/bin/mysql-bkup migrate "$@"' > /usr/local/bin/migrate && \
|
|
chmod +x /usr/local/bin/migrate
|
|
|
|
WORKDIR $WORKDIR
|
|
ENTRYPOINT ["/usr/local/bin/mysql-bkup"]
|