Update Dockerfile
This commit is contained in:
155
.dockerignore
Normal file
155
.dockerignore
Normal file
@ -0,0 +1,155 @@
|
|||||||
|
# Byte-compiled / optimized / DLL files
|
||||||
|
__pycache__/
|
||||||
|
*.py[cod]
|
||||||
|
*$py.class
|
||||||
|
|
||||||
|
# C extensions
|
||||||
|
*.so
|
||||||
|
|
||||||
|
# Distribution / packaging
|
||||||
|
.Python
|
||||||
|
build/
|
||||||
|
develop-eggs/
|
||||||
|
dist/
|
||||||
|
downloads/
|
||||||
|
eggs/
|
||||||
|
.eggs/
|
||||||
|
lib/
|
||||||
|
lib64/
|
||||||
|
parts/
|
||||||
|
sdist/
|
||||||
|
var/
|
||||||
|
wheels/
|
||||||
|
pip-wheel-metadata/
|
||||||
|
share/python-wheels/
|
||||||
|
*.egg-info/
|
||||||
|
.installed.cfg
|
||||||
|
*.egg
|
||||||
|
MANIFEST
|
||||||
|
|
||||||
|
# PyInstaller
|
||||||
|
# Usually these files are written by a python script from a template
|
||||||
|
# before PyInstaller builds the exe, so as to inject date/other infos into it.
|
||||||
|
*.manifest
|
||||||
|
*.spec
|
||||||
|
|
||||||
|
# Installer logs
|
||||||
|
pip-log.txt
|
||||||
|
pip-delete-this-directory.txt
|
||||||
|
|
||||||
|
# Unit test / coverage reports
|
||||||
|
htmlcov/
|
||||||
|
.tox/
|
||||||
|
.nox/
|
||||||
|
.coverage
|
||||||
|
.coverage.*
|
||||||
|
.cache
|
||||||
|
nosetests.xml
|
||||||
|
coverage.xml
|
||||||
|
*.cover
|
||||||
|
*.py,cover
|
||||||
|
.hypothesis/
|
||||||
|
.pytest_cache/
|
||||||
|
|
||||||
|
# Translations
|
||||||
|
*.mo
|
||||||
|
*.pot
|
||||||
|
|
||||||
|
# Django stuff:
|
||||||
|
*.log
|
||||||
|
local_settings.py
|
||||||
|
db.sqlite3
|
||||||
|
db.sqlite3-journal
|
||||||
|
|
||||||
|
# Flask stuff:
|
||||||
|
instance/
|
||||||
|
.webassets-cache
|
||||||
|
|
||||||
|
# Scrapy stuff:
|
||||||
|
.scrapy
|
||||||
|
|
||||||
|
# Sphinx documentation
|
||||||
|
docs/_build/
|
||||||
|
|
||||||
|
# PyBuilder
|
||||||
|
target/
|
||||||
|
|
||||||
|
# Jupyter Notebook
|
||||||
|
.ipynb_checkpoints
|
||||||
|
|
||||||
|
# IPython
|
||||||
|
profile_default/
|
||||||
|
ipython_config.py
|
||||||
|
|
||||||
|
# pyenv
|
||||||
|
.python-version
|
||||||
|
|
||||||
|
# pipenv
|
||||||
|
# According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control.
|
||||||
|
# However, in case of collaboration, if having platform-specific dependencies or dependencies
|
||||||
|
# having no cross-platform support, pipenv may install dependencies that don't work, or not
|
||||||
|
# install all needed dependencies.
|
||||||
|
Pipfile.lock
|
||||||
|
|
||||||
|
# PEP 582; used by e.g. github.com/David-OConnor/pyflow
|
||||||
|
__pypackages__/
|
||||||
|
|
||||||
|
# Celery stuff
|
||||||
|
celerybeat-schedule
|
||||||
|
celerybeat.pid
|
||||||
|
|
||||||
|
# SageMath parsed files
|
||||||
|
*.sage.py
|
||||||
|
|
||||||
|
# Environments
|
||||||
|
.env
|
||||||
|
.venv
|
||||||
|
env/
|
||||||
|
venv/
|
||||||
|
ENV/
|
||||||
|
env.bak/
|
||||||
|
venv.bak/
|
||||||
|
|
||||||
|
# Spyder project settings
|
||||||
|
.spyderproject
|
||||||
|
.spyproject
|
||||||
|
|
||||||
|
# Rope project settings
|
||||||
|
.ropeproject
|
||||||
|
|
||||||
|
# mkdocs documentation
|
||||||
|
/site
|
||||||
|
|
||||||
|
# mypy
|
||||||
|
.mypy_cache/
|
||||||
|
.dmypy.json
|
||||||
|
dmypy.json
|
||||||
|
|
||||||
|
# Pyre type checker
|
||||||
|
.pyre/
|
||||||
|
|
||||||
|
# Uploads folder
|
||||||
|
uploads/
|
||||||
|
|
||||||
|
# Tests folder
|
||||||
|
tests/
|
||||||
|
|
||||||
|
# GitHub Actions
|
||||||
|
.github/
|
||||||
|
|
||||||
|
# Visual Studio Code
|
||||||
|
.vscode/
|
||||||
|
|
||||||
|
# Renovate
|
||||||
|
# https://github.com/marketplace/renovate
|
||||||
|
renovate.json
|
||||||
|
|
||||||
|
# Other files not needed in the Docker image
|
||||||
|
.git/
|
||||||
|
README.md
|
||||||
|
pyproject.toml
|
||||||
|
poetry.lock
|
||||||
|
LICENSE
|
||||||
|
docker-compose.yml
|
||||||
|
Dockerfile
|
||||||
|
.gitignore
|
105
Dockerfile
105
Dockerfile
@ -1,52 +1,71 @@
|
|||||||
FROM python:3.10-slim
|
# We have two stages, one for making the virtual environment and
|
||||||
|
# installing the dependencies and another for running the uvicorn server.
|
||||||
|
# We use an virtual environment so we seperate the dependencies from the
|
||||||
|
# system-level dependencies.
|
||||||
|
FROM python:3.10-slim AS build-image
|
||||||
|
|
||||||
# We don't want apt-get to interact with us and we want the default answers to be used for all questions.
|
# Create virtual environment in /opt/venv, we will use this in the other
|
||||||
ARG DEBIAN_FRONTEND=noninteractive
|
# stage.
|
||||||
|
RUN python -m venv /opt/venv
|
||||||
|
|
||||||
|
# Make sure we use the virtualenv.
|
||||||
|
ENV PATH="/opt/venv/bin:$PATH"
|
||||||
|
|
||||||
|
# Copy requirements.txt to the container, it was generated with
|
||||||
|
# 'poetry export -f requirements.txt --without-hashes'
|
||||||
|
# Note that if we pipe the output of the commmand to requirements.txt in
|
||||||
|
# Windows, it will be UTF-16 LE encoded.
|
||||||
|
COPY requirements.txt .
|
||||||
|
|
||||||
|
# Install the requirements.
|
||||||
|
RUN pip install -r requirements.txt
|
||||||
|
|
||||||
|
# This is the stage where we will run the uvicorn server.
|
||||||
|
FROM python:3.10-slim AS run-image
|
||||||
|
|
||||||
|
# Copy the virtual environment to the run-image.
|
||||||
|
COPY --from=build-image /opt/venv /opt/venv
|
||||||
|
|
||||||
|
# Install ffmpeg, it is needed for finding the video resolution and
|
||||||
|
# making the video thumbnail.
|
||||||
|
RUN apt-get update
|
||||||
|
RUN apt-get install -y --no-install-recommends ffmpeg
|
||||||
|
|
||||||
|
# Create user so we don't run as root and make the needed directories
|
||||||
|
# Logs are stored in /var/log/discord-embed and uploaded files,
|
||||||
|
# thumbnails, and HTML are stored in /Uploads.
|
||||||
|
RUN useradd --create-home botuser && \
|
||||||
|
install --verbose --directory --mode=0755 --owner=botuser --group=botuser /var/log/discord-embed/ /Uploads
|
||||||
|
|
||||||
|
# Persist the uploaded files and files we have created.
|
||||||
|
VOLUME ["/Uploads"]
|
||||||
|
|
||||||
|
# Change to the user we created so we don't run as root.
|
||||||
|
USER botuser
|
||||||
|
|
||||||
|
# Change directory to where we will run the bot.
|
||||||
|
WORKDIR /home/botuser/discord-embed
|
||||||
|
|
||||||
|
# Add main.py and settings.py to the container.
|
||||||
|
ADD --chown=botuser:botuser . /home/botuser/discord-embed/
|
||||||
|
|
||||||
|
# Uvicorn runs on port 5000, we can't use any ports below 1024 due to
|
||||||
|
# not being root.
|
||||||
|
EXPOSE 5000
|
||||||
|
|
||||||
|
# Make sure we use the virtualenv.
|
||||||
|
ENV PATH="/opt/venv/bin:$PATH"
|
||||||
|
|
||||||
# Don't generate byte code (.pyc-files).
|
# Don't generate byte code (.pyc-files).
|
||||||
# These are only needed if we run the python-files several times.
|
# These are only needed if we run the python-files several times.
|
||||||
# Docker doesn't keep the data between runs so this adds nothing.
|
# Docker doesn't keep the data between runs so this adds nothing.
|
||||||
ENV PYTHONDONTWRITEBYTECODE 1
|
ENV PYTHONDONTWRITEBYTECODE 1
|
||||||
|
|
||||||
# Force the stdout and stderr streams to be unbuffered.
|
# Force the stdout and stderr streams to be unbuffered. This means that
|
||||||
# Will allow log messages to be immediately dumped instead of being buffered.
|
# the output will be printed immediately instead of being buffered. If
|
||||||
# This is useful when the bot crashes before writing messages stuck in the buffer.
|
# the Python application crashes, the output could be lost.
|
||||||
ENV PYTHONUNBUFFERED 1
|
ENV PYTHONUNBUFFERED 1
|
||||||
|
|
||||||
# Update packages and install needed packages to build our requirements.
|
# Run the server on all interfaces and on port 5000.
|
||||||
RUN apt-get update && apt-get install -y --no-install-recommends curl ffmpeg python-is-python3
|
# You should run a reverse proxy like nginx infront of this.
|
||||||
|
CMD ["uvicorn", "discord_embed.main:app", "--host", "0.0.0.0", "--port", "5000"]
|
||||||
# Create user so we don't run as root.
|
|
||||||
RUN useradd --create-home botuser
|
|
||||||
|
|
||||||
# Make log directory
|
|
||||||
RUN \
|
|
||||||
mkdir -p /var/log/discord-embed/ && chown -R botuser:botuser /var/log/discord-embed/ && \
|
|
||||||
mkdir /Uploads && chown -R botuser:botuser /Uploads
|
|
||||||
|
|
||||||
VOLUME ["/Uploads"]
|
|
||||||
|
|
||||||
# Change to the user we created.
|
|
||||||
USER botuser
|
|
||||||
|
|
||||||
# Install poetry.
|
|
||||||
RUN curl -sSL https://install.python-poetry.org | python -
|
|
||||||
|
|
||||||
# Add poetry to our path.
|
|
||||||
ENV PATH="/home/botuser/.local/bin/:${PATH}"
|
|
||||||
|
|
||||||
# Copy files from our repository to the container.
|
|
||||||
ADD --chown=botuser:botuser pyproject.toml poetry.lock README.md LICENSE /home/botuser/discord-embed/
|
|
||||||
|
|
||||||
# Change directory to where we will run the bot.
|
|
||||||
WORKDIR /home/botuser/discord-embed
|
|
||||||
|
|
||||||
# Install the requirements.
|
|
||||||
RUN poetry install --no-interaction --no-ansi --no-dev
|
|
||||||
|
|
||||||
# Add main.py and settings.py to the container.
|
|
||||||
ADD --chown=botuser:botuser discord_embed /home/botuser/discord-embed/discord_embed/
|
|
||||||
|
|
||||||
EXPOSE 5000
|
|
||||||
|
|
||||||
CMD ["poetry", "run", "uvicorn", "discord_embed.main:app", "--host", "0.0.0.0", "--port", "5000"]
|
|
||||||
|
29
requirements.txt
Normal file
29
requirements.txt
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
anyio==3.5.0; python_version >= "3.7" and python_full_version >= "3.6.2"
|
||||||
|
asgiref==3.5.0; python_version >= "3.7"
|
||||||
|
certifi==2021.10.8; python_version >= "2.7" and python_full_version < "3.0.0" or python_full_version >= "3.6.0"
|
||||||
|
charset-normalizer==2.0.12; python_full_version >= "3.6.0" and python_version >= "3"
|
||||||
|
click==8.1.2; python_version >= "3.7"
|
||||||
|
colorama==0.4.4; python_version >= "3.7" and python_full_version < "3.0.0" and sys_platform == "win32" and platform_system == "Windows" or sys_platform == "win32" and python_version >= "3.7" and python_full_version >= "3.5.0" and platform_system == "Windows"
|
||||||
|
discord-webhook==0.15.0
|
||||||
|
fastapi==0.75.2; python_full_version >= "3.6.1"
|
||||||
|
ffmpeg-python==0.2.0
|
||||||
|
future==0.18.2; python_version >= "2.6" and python_full_version < "3.0.0" or python_full_version >= "3.3.0"
|
||||||
|
h11==0.13.0; python_version >= "3.7"
|
||||||
|
httptools==0.4.0; python_version >= "3.7" and python_full_version >= "3.5.0"
|
||||||
|
idna==3.3; python_full_version >= "3.6.2" and python_version >= "3.7"
|
||||||
|
jinja2==3.1.1; python_version >= "3.7"
|
||||||
|
markupsafe==2.1.1; python_version >= "3.7"
|
||||||
|
pydantic==1.9.0; python_full_version >= "3.6.1"
|
||||||
|
python-dotenv==0.20.0; python_version >= "3.5"
|
||||||
|
python-multipart==0.0.5
|
||||||
|
pyyaml==6.0; python_version >= "3.7"
|
||||||
|
requests==2.27.1; python_version >= "2.7" and python_full_version < "3.0.0" or python_full_version >= "3.6.0"
|
||||||
|
six==1.16.0; python_version >= "2.7" and python_full_version < "3.0.0" or python_full_version >= "3.3.0"
|
||||||
|
sniffio==1.2.0; python_version >= "3.7" and python_full_version >= "3.6.2"
|
||||||
|
starlette==0.17.1; python_version >= "3.6" and python_full_version >= "3.6.1"
|
||||||
|
typing-extensions==4.2.0; python_version >= "3.7" and python_full_version >= "3.6.1"
|
||||||
|
urllib3==1.26.9; python_version >= "2.7" and python_full_version < "3.0.0" or python_full_version >= "3.6.0" and python_version < "4"
|
||||||
|
uvicorn==0.17.6; python_version >= "3.7"
|
||||||
|
uvloop==0.16.0; sys_platform != "win32" and sys_platform != "cygwin" and platform_python_implementation != "PyPy" and python_version >= "3.7"
|
||||||
|
watchgod==0.8.2; python_version >= "3.7"
|
||||||
|
websockets==10.3; python_version >= "3.7"
|
Reference in New Issue
Block a user