Refactored and fix docker deploy

This commit is contained in:
Ilya Bezrukov 2024-07-30 18:02:46 +03:00
parent c309d4975e
commit b3a1ea1309
4 changed files with 31 additions and 12 deletions

1
.gitignore vendored
View File

@ -3,5 +3,6 @@ __pycache__/
venv/
.venv/
logs/
data/
*.env
*.db

View File

@ -19,20 +19,21 @@ RUN --mount=type=cache,target=/root/.cache/pip \
--mount=type=bind,source=requirements.txt,target=requirements.txt \
pip install -r requirements.txt
# copy i18n files
COPY --chown=bot i18n.yaml /i18n/i18n.yaml
# copy sources
COPY --chown=bot --chmod=774 docker-entrypoint.sh /app/
COPY --chown=bot migrations /app/migrations
COPY --chown=bot mybot /app/mybot
COPY --chown=bot i18n.yaml /app/
# copy default configs
WORKDIR /app
COPY --chown=bot mybot mybot
# prepare environment
ENV I18N_PATH=/data/i18n.yaml
ENV DB_URL=sqlite:////data/bot.db
# preapre environment
ENV SS_TYPE=memory
ENV I18N_PATH=/i18n/i18n.yaml
RUN mkdir -p /data
RUN chown bot:bot /data
VOLUME /data
# set user
USER bot
WORKDIR /app
CMD ["python3", "-m", "mybot"]
VOLUME i18n/
ENTRYPOINT ["./docker-entrypoint.sh"]

17
docker-entrypoint.sh Normal file
View File

@ -0,0 +1,17 @@
#!/bin/sh
if [ ! -f /i18n/i18n.yaml ]; then
cp i18n.yaml ${I18N_PATH}
fi
alembic -c migrations/alembic.ini upgrade head
if [ $# -eq 0 ]; then
if [ -z "${USE_WEBHOOK}" ]; then
exec python3 -m mybot
else
exec gunicorn -b 0.0.0.0:8080 "mybot:main()"
fi
else
exec $1
fi