mirror of
https://github.com/MikroWizard/docker-compose-deployment.git
synced 2025-12-06 01:59:29 +00:00
feat: Initial commit 🎉
Set up the foundational structure for the MikroWizard deployment repository, including: - Docker Compose configuration for MikroFront, MikroMan, PostgreSQL, and Redis Stack. - `prepare.sh` script for host environment preparation. - Database initialization script (`init-db.sql`). - `.env` template for centralized configuration. This commit marks the beginning of a streamlined deployment process for MikroWizard!
This commit is contained in:
commit
a8f029ee38
80 changed files with 3429 additions and 0 deletions
66
mikroman/Dockerfile
Normal file
66
mikroman/Dockerfile
Normal file
|
|
@ -0,0 +1,66 @@
|
|||
|
||||
FROM python:3.11-slim-bullseye
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
RUN apt-get update
|
||||
RUN apt-get -y install cron
|
||||
RUN apt-get install -y iputils-ping
|
||||
RUN apt-get install -y net-tools
|
||||
RUN apt-get install -y git
|
||||
|
||||
RUN touch /var/log/cron.log
|
||||
RUN git clone https://github.com/MikroWizard/mikroman.git /app
|
||||
|
||||
RUN set -ex \
|
||||
&& buildDeps=' \
|
||||
build-essential \
|
||||
gcc \
|
||||
' \
|
||||
&& deps=' \
|
||||
htop \
|
||||
' \
|
||||
&& apt-get install -y $buildDeps git $deps --no-install-recommends && rm -rf /var/lib/apt/lists/* \
|
||||
&& pip install uWSGI==2.0.22 \
|
||||
&& pip install -r /app/reqs.txt
|
||||
|
||||
|
||||
RUN mkdir -p /conf
|
||||
RUN cp /app/conf/loginscript.sh /etc/profile
|
||||
COPY server-conf.json /conf/
|
||||
ARG AM_I_IN_A_DOCKER_CONTAINER=Yes
|
||||
COPY init.sh /app/
|
||||
COPY initpy.py /app/
|
||||
RUN chmod +x /app/init.sh
|
||||
|
||||
# background spooler dir
|
||||
RUN mkdir /tmp/pysrv_spooler
|
||||
|
||||
# we don't need this file with Docker but uwsgi looks for it
|
||||
RUN echo `date +%s` >/app/VERSION
|
||||
|
||||
EXPOSE 80
|
||||
|
||||
|
||||
# our server config file
|
||||
# - you should write your own config file and put OUTSIDE the repository
|
||||
# since the config file contains secrets
|
||||
# - here I use the sample template from repo
|
||||
# - it is also possible to override the config with env variables, either here
|
||||
# or in Amazon ECS or Kubernetes configuration
|
||||
#COPY /app/real-server-config.json /app/real-server-config.json
|
||||
# ENV PYSRV_DATABASE_HOST host.docker.internal
|
||||
# ENV PYSRV_REDIS_HOST host.docker.internal
|
||||
# ENV PYSRV_DATABASE_PASSWORD x
|
||||
|
||||
# build either a production or dev image
|
||||
|
||||
ARG BUILDMODE=production
|
||||
ENV ENVBUILDMODE=$BUILDMODE
|
||||
|
||||
RUN echo "BUILDMODE $ENVBUILDMODE"
|
||||
|
||||
# run in shell mode with ENV expansion
|
||||
RUN cd /app && bash init.sh
|
||||
|
||||
|
||||
Loading…
Add table
Add a link
Reference in a new issue