I have a problem updating running in production mode VueJS app. Every time instead of just running
docker-compose up --build
I should do
docker-compose down
docker volume rm mkstat_frontend_dist
docker-compose up --build
And there is a lot of downtime during this, so I want to solve this problem. I understanding that this is because of volume, but don't know how to solve this. I've tried just remove this volume but then nginx responding with
directory index of "/app/dist/" is forbidden
This is my app structure:
.
├── docker/
├── docker-compose.back.yml
├── docker-compose.dev.yml
├── docker-compose.yml
├── fresh_dump.sql
├── init-letsencrypt.sh
├── mkstat_backend/
├── mkstat_frontend/
├── redis.conf
This is my prod docker-compose file:
docker-compose.yml
version: "3.8"
services:
backend:
container_name: backend
restart: always
build:
context: ./mkstat_backend
dockerfile: Dockerfile.prod
volumes:
- static:/app/static
- media:/app/media
env_file:
- ./mkstat_backend/.env.prod
depends_on:
- db
db:
container_name: db
restart: always
build:
context: ./docker/postgres
dockerfile: Dockerfile
volumes:
- pgdata:/var/lib/postgresql/data/
ports:
- "5432:5432"
env_file:
- ./mkstat_backend/.env.prod
frontend:
container_name: frontend
build:
context: ./mkstat_frontend
dockerfile: Dockerfile.prod
volumes:
- frontend_dist:/app/dist
depends_on:
- backend
nginx:
image: nginx:alpine
restart: unless-stopped
command: '/bin/sh -c ''while :; do sleep 6h & wait $${!}; nginx -s reload; done & nginx -g "daemon off;"'''
container_name: nginx
ports:
- "80:80"
- "443:443"
volumes:
- ./docker/nginx/nginx.conf:/etc/nginx/conf.d/default.conf
- ./docker/certbot/conf:/etc/letsencrypt
- ./docker/certbot/www:/var/www/certbot
- static:/var/html/static
- media:/var/html/media
- frontend_dist:/app/dist
depends_on:
- backend
- frontend
certbot:
container_name: certbot
image: certbot/certbot
restart: unless-stopped
entrypoint: "/bin/sh -c 'trap exit TERM; while :; do certbot renew; sleep 12h & wait $${!}; done;'"
volumes:
- ./docker/certbot/conf:/etc/letsencrypt
- ./docker/certbot/www:/var/www/certbot
redis:
image: redis:latest
restart: always
container_name: redis
command: [
"bash",
"-c",
"
redis-server
--requirepass $${REDIS_PASS}
",
]
volumes:
- redis:/var/lib/redis/data
- ./redis.conf:/usr/local/etc/redis/redis.conf
ports:
- "6379"
env_file:
- ./mkstat_backend/.env.prod
worker:
build:
context: ./mkstat_backend
command: celery -A mkstat worker -B -l info -s /tmp/celerybeat-schedule
restart: always
container_name: celery
depends_on:
- db
- redis
- backend
volumes:
- ./mkstat_backend:/app
env_file:
- ./mkstat_backend/.env.prod
volumes:
pgdata:
static:
media:
frontend_dist:
redis:
Vue Dockerfile:
FROM node:lts-alpine as build
WORKDIR /app
ENV PATH /app/node_modules/.bin:$PATH
COPY package.json /app/package.json
RUN npm install --silent
RUN npm install @vue/cli@4.5.13 -g
COPY . /app
RUN npm run build