feat: split dev and prod compose workflows
This commit is contained in:
parent
304a6290c8
commit
534dea7317
4 changed files with 207 additions and 12 deletions
|
|
@ -38,3 +38,10 @@ VITE_PROXYSCOTCH_ACCESS_TOKEN=
|
||||||
|
|
||||||
# Set to `true` for subpath based access
|
# Set to `true` for subpath based access
|
||||||
ENABLE_SUBPATH_BASED_ACCESS=false
|
ENABLE_SUBPATH_BASED_ACCESS=false
|
||||||
|
|
||||||
|
#-----------------------Docker Image Config-------------------------#
|
||||||
|
# Used by docker-compose.prod.yml and Makefile image targets.
|
||||||
|
API_CLIENT_REGISTRY=forge.lclr.dev
|
||||||
|
API_CLIENT_NAMESPACE=thibaud-lclr
|
||||||
|
API_CLIENT_IMAGE_PREFIX=api-client
|
||||||
|
API_CLIENT_TAG=latest
|
||||||
|
|
|
||||||
54
Makefile
54
Makefile
|
|
@ -1,20 +1,64 @@
|
||||||
COMPOSE := docker compose
|
COMPOSE := docker compose
|
||||||
ENV_FILE := .env
|
ENV_FILE := .env
|
||||||
ENV_EXAMPLE := .env.example
|
ENV_EXAMPLE := .env.example
|
||||||
|
PROD_COMPOSE := docker-compose.prod.yml
|
||||||
|
|
||||||
.PHONY: up down logs ps ensure-env
|
REGISTRY ?= forge.lclr.dev
|
||||||
|
NAMESPACE ?= thibaud-lclr
|
||||||
|
IMAGE_PREFIX ?= api-client
|
||||||
|
TAG ?= latest
|
||||||
|
|
||||||
up: ensure-env
|
BACKEND_IMAGE := $(REGISTRY)/$(NAMESPACE)/$(IMAGE_PREFIX)-backend:$(TAG)
|
||||||
|
APP_IMAGE := $(REGISTRY)/$(NAMESPACE)/$(IMAGE_PREFIX)-app:$(TAG)
|
||||||
|
SH_ADMIN_IMAGE := $(REGISTRY)/$(NAMESPACE)/$(IMAGE_PREFIX)-sh-admin:$(TAG)
|
||||||
|
|
||||||
|
PROD_ENV := API_CLIENT_REGISTRY=$(REGISTRY) API_CLIENT_NAMESPACE=$(NAMESPACE) API_CLIENT_IMAGE_PREFIX=$(IMAGE_PREFIX) API_CLIENT_TAG=$(TAG)
|
||||||
|
|
||||||
|
.PHONY: up dev-up prod-up down dev-down prod-down logs dev-logs prod-logs ps dev-ps prod-ps ensure-env docker-build-images docker-push-images docker-build-push-images
|
||||||
|
|
||||||
|
up: dev-up
|
||||||
|
|
||||||
|
dev-up: ensure-env
|
||||||
$(COMPOSE) up -d --build
|
$(COMPOSE) up -d --build
|
||||||
|
|
||||||
down:
|
prod-up: ensure-env
|
||||||
|
$(PROD_ENV) $(COMPOSE) -f $(PROD_COMPOSE) up -d
|
||||||
|
|
||||||
|
down: dev-down
|
||||||
|
|
||||||
|
dev-down:
|
||||||
$(COMPOSE) down
|
$(COMPOSE) down
|
||||||
|
|
||||||
logs:
|
prod-down:
|
||||||
|
$(PROD_ENV) $(COMPOSE) -f $(PROD_COMPOSE) down
|
||||||
|
|
||||||
|
logs: dev-logs
|
||||||
|
|
||||||
|
dev-logs:
|
||||||
$(COMPOSE) logs -f
|
$(COMPOSE) logs -f
|
||||||
|
|
||||||
ps:
|
prod-logs:
|
||||||
|
$(PROD_ENV) $(COMPOSE) -f $(PROD_COMPOSE) logs -f
|
||||||
|
|
||||||
|
ps: dev-ps
|
||||||
|
|
||||||
|
dev-ps:
|
||||||
$(COMPOSE) ps
|
$(COMPOSE) ps
|
||||||
|
|
||||||
|
prod-ps:
|
||||||
|
$(PROD_ENV) $(COMPOSE) -f $(PROD_COMPOSE) ps
|
||||||
|
|
||||||
ensure-env:
|
ensure-env:
|
||||||
@test -f $(ENV_FILE) || cp $(ENV_EXAMPLE) $(ENV_FILE)
|
@test -f $(ENV_FILE) || cp $(ENV_EXAMPLE) $(ENV_FILE)
|
||||||
|
|
||||||
|
docker-build-images:
|
||||||
|
docker build --file prod.Dockerfile --target backend --tag $(BACKEND_IMAGE) .
|
||||||
|
docker build --file prod.Dockerfile --target app --tag $(APP_IMAGE) .
|
||||||
|
docker build --file prod.Dockerfile --target sh_admin --tag $(SH_ADMIN_IMAGE) .
|
||||||
|
|
||||||
|
docker-push-images:
|
||||||
|
docker push $(BACKEND_IMAGE)
|
||||||
|
docker push $(APP_IMAGE)
|
||||||
|
docker push $(SH_ADMIN_IMAGE)
|
||||||
|
|
||||||
|
docker-build-push-images: docker-build-images docker-push-images
|
||||||
|
|
|
||||||
67
docker-compose.prod.yml
Normal file
67
docker-compose.prod.yml
Normal file
|
|
@ -0,0 +1,67 @@
|
||||||
|
services:
|
||||||
|
hoppscotch-db:
|
||||||
|
image: postgres:15
|
||||||
|
user: postgres
|
||||||
|
environment:
|
||||||
|
POSTGRES_USER: postgres
|
||||||
|
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD:-testpass}
|
||||||
|
POSTGRES_DB: ${POSTGRES_DB:-hoppscotch}
|
||||||
|
volumes:
|
||||||
|
- hoppscotch-db:/var/lib/postgresql/data
|
||||||
|
healthcheck:
|
||||||
|
test:
|
||||||
|
[
|
||||||
|
"CMD-SHELL",
|
||||||
|
"sh -c 'pg_isready -U $${POSTGRES_USER} -d $${POSTGRES_DB}'",
|
||||||
|
]
|
||||||
|
interval: 5s
|
||||||
|
timeout: 5s
|
||||||
|
retries: 10
|
||||||
|
|
||||||
|
hoppscotch-backend:
|
||||||
|
container_name: hoppscotch-backend
|
||||||
|
restart: unless-stopped
|
||||||
|
image: ${API_CLIENT_REGISTRY:-forge.lclr.dev}/${API_CLIENT_NAMESPACE:-thibaud-lclr}/${API_CLIENT_IMAGE_PREFIX:-api-client}-backend:${API_CLIENT_TAG:-latest}
|
||||||
|
env_file:
|
||||||
|
- ./.env
|
||||||
|
environment:
|
||||||
|
DATABASE_URL: postgresql://postgres:${POSTGRES_PASSWORD:-testpass}@hoppscotch-db:5432/${POSTGRES_DB:-hoppscotch}
|
||||||
|
depends_on:
|
||||||
|
hoppscotch-db:
|
||||||
|
condition: service_healthy
|
||||||
|
command:
|
||||||
|
[
|
||||||
|
"sh",
|
||||||
|
"-c",
|
||||||
|
"pnpm exec prisma migrate deploy && node prod_run.mjs",
|
||||||
|
]
|
||||||
|
ports:
|
||||||
|
- "3170:3170"
|
||||||
|
|
||||||
|
hoppscotch-app:
|
||||||
|
container_name: hoppscotch-app
|
||||||
|
restart: unless-stopped
|
||||||
|
image: ${API_CLIENT_REGISTRY:-forge.lclr.dev}/${API_CLIENT_NAMESPACE:-thibaud-lclr}/${API_CLIENT_IMAGE_PREFIX:-api-client}-app:${API_CLIENT_TAG:-latest}
|
||||||
|
env_file:
|
||||||
|
- ./.env
|
||||||
|
depends_on:
|
||||||
|
hoppscotch-backend:
|
||||||
|
condition: service_started
|
||||||
|
ports:
|
||||||
|
- "3000:3000"
|
||||||
|
- "3200:3200"
|
||||||
|
|
||||||
|
hoppscotch-sh-admin:
|
||||||
|
container_name: hoppscotch-sh-admin
|
||||||
|
restart: unless-stopped
|
||||||
|
image: ${API_CLIENT_REGISTRY:-forge.lclr.dev}/${API_CLIENT_NAMESPACE:-thibaud-lclr}/${API_CLIENT_IMAGE_PREFIX:-api-client}-sh-admin:${API_CLIENT_TAG:-latest}
|
||||||
|
env_file:
|
||||||
|
- ./.env
|
||||||
|
depends_on:
|
||||||
|
hoppscotch-backend:
|
||||||
|
condition: service_started
|
||||||
|
ports:
|
||||||
|
- "3100:3100"
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
hoppscotch-db:
|
||||||
|
|
@ -18,13 +18,29 @@ services:
|
||||||
timeout: 5s
|
timeout: 5s
|
||||||
retries: 10
|
retries: 10
|
||||||
|
|
||||||
hoppscotch-aio:
|
hoppscotch-dev-deps:
|
||||||
container_name: hoppscotch-aio
|
build:
|
||||||
|
dockerfile: prod.Dockerfile
|
||||||
|
context: .
|
||||||
|
target: base_builder
|
||||||
|
env_file:
|
||||||
|
- ./.env
|
||||||
|
environment:
|
||||||
|
DATABASE_URL: postgresql://postgres:${POSTGRES_PASSWORD:-testpass}@hoppscotch-db:5432/${POSTGRES_DB:-hoppscotch}
|
||||||
|
working_dir: /usr/src/app
|
||||||
|
command: ["pnpm", "install", "-f", "--prefer-offline"]
|
||||||
|
volumes:
|
||||||
|
- .:/usr/src/app
|
||||||
|
- hoppscotch-node-modules:/usr/src/app/node_modules
|
||||||
|
- hoppscotch-pnpm-store:/root/.local/share/pnpm/store/v10
|
||||||
|
|
||||||
|
hoppscotch-backend:
|
||||||
|
container_name: hoppscotch-backend-dev
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
build:
|
build:
|
||||||
dockerfile: prod.Dockerfile
|
dockerfile: prod.Dockerfile
|
||||||
context: .
|
context: .
|
||||||
target: aio
|
target: base_builder
|
||||||
env_file:
|
env_file:
|
||||||
- ./.env
|
- ./.env
|
||||||
environment:
|
environment:
|
||||||
|
|
@ -32,18 +48,79 @@ services:
|
||||||
depends_on:
|
depends_on:
|
||||||
hoppscotch-db:
|
hoppscotch-db:
|
||||||
condition: service_healthy
|
condition: service_healthy
|
||||||
|
hoppscotch-dev-deps:
|
||||||
|
condition: service_completed_successfully
|
||||||
|
working_dir: /usr/src/app/packages/hoppscotch-backend
|
||||||
command:
|
command:
|
||||||
[
|
[
|
||||||
"sh",
|
"sh",
|
||||||
"-c",
|
"-c",
|
||||||
"pnpm exec prisma migrate deploy && node /usr/src/app/aio_run.mjs",
|
"pnpm exec prisma migrate deploy && pnpm run start:dev",
|
||||||
]
|
]
|
||||||
|
volumes:
|
||||||
|
- .:/usr/src/app
|
||||||
|
- hoppscotch-node-modules:/usr/src/app/node_modules
|
||||||
|
- hoppscotch-pnpm-store:/root/.local/share/pnpm/store/v10
|
||||||
|
ports:
|
||||||
|
- "3170:3170"
|
||||||
|
|
||||||
|
hoppscotch-app:
|
||||||
|
container_name: hoppscotch-app-dev
|
||||||
|
restart: unless-stopped
|
||||||
|
build:
|
||||||
|
dockerfile: prod.Dockerfile
|
||||||
|
context: .
|
||||||
|
target: base_builder
|
||||||
|
env_file:
|
||||||
|
- ./.env
|
||||||
|
depends_on:
|
||||||
|
hoppscotch-dev-deps:
|
||||||
|
condition: service_completed_successfully
|
||||||
|
hoppscotch-backend:
|
||||||
|
condition: service_started
|
||||||
|
working_dir: /usr/src/app/packages/hoppscotch-selfhost-web
|
||||||
|
command:
|
||||||
|
[
|
||||||
|
"sh",
|
||||||
|
"-c",
|
||||||
|
"pnpm run dev:gql-codegen & pnpm exec vite --host 0.0.0.0 --port 3000",
|
||||||
|
]
|
||||||
|
volumes:
|
||||||
|
- .:/usr/src/app
|
||||||
|
- hoppscotch-node-modules:/usr/src/app/node_modules
|
||||||
|
- hoppscotch-pnpm-store:/root/.local/share/pnpm/store/v10
|
||||||
ports:
|
ports:
|
||||||
- "3000:3000"
|
- "3000:3000"
|
||||||
|
|
||||||
|
hoppscotch-sh-admin:
|
||||||
|
container_name: hoppscotch-sh-admin-dev
|
||||||
|
restart: unless-stopped
|
||||||
|
build:
|
||||||
|
dockerfile: prod.Dockerfile
|
||||||
|
context: .
|
||||||
|
target: base_builder
|
||||||
|
env_file:
|
||||||
|
- ./.env
|
||||||
|
depends_on:
|
||||||
|
hoppscotch-dev-deps:
|
||||||
|
condition: service_completed_successfully
|
||||||
|
hoppscotch-backend:
|
||||||
|
condition: service_started
|
||||||
|
working_dir: /usr/src/app/packages/hoppscotch-sh-admin
|
||||||
|
command:
|
||||||
|
[
|
||||||
|
"sh",
|
||||||
|
"-c",
|
||||||
|
"pnpm run dev:gql-codegen & pnpm exec vite --host 0.0.0.0 --port 3100",
|
||||||
|
]
|
||||||
|
volumes:
|
||||||
|
- .:/usr/src/app
|
||||||
|
- hoppscotch-node-modules:/usr/src/app/node_modules
|
||||||
|
- hoppscotch-pnpm-store:/root/.local/share/pnpm/store/v10
|
||||||
|
ports:
|
||||||
- "3100:3100"
|
- "3100:3100"
|
||||||
- "3170:3170"
|
|
||||||
- "3200:3200"
|
|
||||||
- "3080:80"
|
|
||||||
|
|
||||||
volumes:
|
volumes:
|
||||||
hoppscotch-db:
|
hoppscotch-db:
|
||||||
|
hoppscotch-node-modules:
|
||||||
|
hoppscotch-pnpm-store:
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue