WIP: add cms compose #1

Draft
joao.dubas wants to merge 8 commits from jpd-add-compose into main
3 changed files with 87 additions and 73 deletions
Showing only changes of commit 65c76f225b - Show all commits

View File

@ -4,3 +4,4 @@ name: ${CMS_PROJECT_NAME:-cms}
include: include:
- services/database/compose.yml - services/database/compose.yml
- services/directus/compose.yml - services/directus/compose.yml
- services/strapi/compose.yml

View File

@ -1,49 +1,66 @@
FROM node:18-alpine3.18 AS development ARG BASE_IMAGE=node:18.20.7-alpine3.21
# Installing libvips-dev for sharp Compatibility
RUN apk update && apk add --no-cache build-base gcc autoconf automake zlib-dev libpng-dev nasm bash vips-dev git FROM ${BASE_IMAGE} AS development
RUN apk update \
&& apk add --no-cache \
autoconf \
automake \
bash \
build-base \
gcc \
git \
libpng-dev \
nasm \
vips-dev \
zlib-dev
ARG NODE_ENV=development ARG NODE_ENV=development
ENV NODE_ENV=${NODE_ENV} ENV NODE_ENV=${NODE_ENV}
WORKDIR /opt/ WORKDIR /opt/
COPY package.json yarn.lock ./ COPY ./cms/package.json ./cms/yarn.lock ./
RUN yarn global add node-gyp RUN yarn global add node-gyp \
RUN yarn config set network-timeout 600000 -g && yarn install && yarn config set network-timeout 600000 -g \
&& yarn install
ENV PATH /opt/node_modules/.bin:$PATH ENV PATH /opt/node_modules/.bin:$PATH
WORKDIR /opt/app WORKDIR /opt/app
COPY . . COPY ./cms .
RUN chown -R node:node /opt/app RUN chown -R node:node /opt/app
USER node USER node
RUN ["yarn", "build"] RUN ["yarn", "build"]
EXPOSE 1337 EXPOSE 1337
CMD ["yarn", "develop"] CMD ["yarn", "develop"]
# Creating multi-stage build for production FROM ${BASE_IMAGE} AS build
FROM node:18-alpine as build RUN apk update \
RUN apk update && apk add --no-cache build-base gcc autoconf automake zlib-dev libpng-dev vips-dev git > /dev/null 2>&1 && apk add --no-cache \
ENV NODE_ENV=production autoconf \
automake \
build-base \
gcc \
git \
libpng-dev \
vips-dev \
zlib-dev > /dev/null 2>&1
ARG NODE_ENV=production
ENV NODE_ENV=${NODE_ENV} ENV NODE_ENV=${NODE_ENV}
WORKDIR /opt/ WORKDIR /opt/
COPY package.json yarn.lock ./ COPY ./cms/package.json ./cms/yarn.lock ./
RUN yarn global add node-gyp RUN yarn global add node-gyp \
RUN yarn config set network-timeout 600000 -g && yarn install --production && yarn config set network-timeout 600000 -g \
&& yarn install --production
ENV PATH /opt/node_modules/.bin:$PATH ENV PATH /opt/node_modules/.bin:$PATH
WORKDIR /opt/app WORKDIR /opt/app
COPY . . COPY . .
RUN yarn build RUN yarn build
# Creating final production image FROM ${BASE_IMAGE} AS production
FROM node:18-alpine
RUN apk add --no-cache vips-dev RUN apk add --no-cache vips-dev
ENV NODE_ENV=production ARG NODE_ENV=production
ENV NODE_ENV=${NODE_ENV} ENV NODE_ENV=${NODE_ENV}
WORKDIR /opt/ WORKDIR /opt/
COPY --from=build /opt/node_modules ./node_modules COPY --from=build /opt/node_modules ./node_modules
WORKDIR /opt/app WORKDIR /opt/app
COPY --from=build /opt/app ./ COPY --from=build /opt/app ./
ENV PATH /opt/node_modules/.bin:$PATH ENV PATH /opt/node_modules/.bin:$PATH
RUN chown -R node:node /opt/app RUN chown -R node:node /opt/app
USER node USER node
EXPOSE 1337 EXPOSE 1337

View File

@ -1,59 +1,55 @@
--- ---
services: services:
strapi: strapi_development:
container_name: strapi build:
build: . context: .
image: strapi:latest target: development
args:
NODE_ENV: development
pull_policy: never
image: 'strapi:${CMS_STRAPI_TAG:-dev}'
restart: unless-stopped restart: unless-stopped
env_file: .env hostname: strapi_development
environment: environment: &strapi_env
DATABASE_CLIENT: ${DATABASE_CLIENT} DATABASE_CLIENT: postgres
DATABASE_HOST: strapiDB DATABASE_HOST: ${CMS_POSTGRES_HOST:-postgres}
DATABASE_PORT: ${DATABASE_PORT} DATABASE_PORT: ${CMS_POSTGRES_PORT:-5432}
DATABASE_NAME: ${DATABASE_NAME} DATABASE_NAME: strapi_development
DATABASE_USERNAME: ${DATABASE_USERNAME} DATABASE_USERNAME: ${CMS_POSTGRES_USER:-postgres}
DATABASE_PASSWORD: ${DATABASE_PASSWORD} DATABASE_PASSWORD: ${CMS_POSTGRES_PASSWORD:-postgres}
JWT_SECRET: ${JWT_SECRET} JWT_SECRET: ${CMS_STRAPI_JWT_SECRET:-replace-with-random-value}
ADMIN_JWT_SECRET: ${ADMIN_JWT_SECRET} ADMIN_JWT_SECRET: ${CMS_STRAPI_ADMIN_JWT_SECRET:-replace-with-random-value}
APP_KEYS: ${APP_KEYS} APP_KEYS: ${CMS_STRAPI_APP_KEYS:-replace-with-random-value}
NODE_ENV: ${NODE_ENV} NODE_ENV: development
volumes:
- ./config:/opt/app/config
- ./src:/opt/app/src
- ./package.json:/opt/package.json
- ./yarn.lock:/opt/yarn.lock
- ./.env:/opt/app/.env
- ./public/uploads:/opt/app/public/uploads
ports:
- "1337:1337"
networks:
- strapi
depends_on: depends_on:
- strapiDB postgres:
condition: service_healthy
strapiDB:
container_name: strapiDB
platform: linux/amd64 #for platform error on Apple M1 chips
restart: unless-stopped
env_file: .env
image: postgres:12.0-alpine
environment:
POSTGRES_USER: ${DATABASE_USERNAME}
POSTGRES_PASSWORD: ${DATABASE_PASSWORD}
POSTGRES_DB: ${DATABASE_NAME}
volumes: volumes:
- strapi-data:/var/lib/postgresql/data/ #using a volume - ./cms/package.json:/opt/package.json
#- ./data:/var/lib/postgresql/data/ # if you want to use a bind folder - ./cms/yarn.lock:/opt/yarn.lock
- ./cms/src:/opt/app/src
- ./cms/config:/opt/app/config
- ./cms/public/uploads:/opt/app/public/uploads
ports: ports:
- "5432:5432" - ${CMS_STRAPI_PORTS:-1337:1337}
networks:
- strapi
volumes: strapi_production:
strapi-data: build:
context: .
networks: target: production
strapi: args:
name: Strapi NODE_ENV: production
driver: bridge pull_policy: never
image: 'strapi:${CMS_STRAPI_PRODUCTION_TAG:-prod}'
restart: unless-stopped
hostname: strapi_production
profiles:
- production
environment:
<<: *strapi_env
NODE_ENV: production
depends_on:
postgres:
condition: service_healthy
ports:
- ${CMS_STRAPI_PRODUCTION_PORTS:-1338:1337}