feat: add Docker Compose setup with Dockerfiles for all services

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
2026-04-02 13:39:21 +08:00
parent c3f8b598af
commit f5907892bf
8 changed files with 229 additions and 0 deletions

3
.gitignore vendored
View File

@@ -3,3 +3,6 @@ dist/
.env
*.log
.DS_Store
# Docker
docker-compose.override.yml

45
docker-compose.dev.yml Normal file
View File

@@ -0,0 +1,45 @@
services:
postgres:
ports:
- "5432:5432"
server:
build:
target: deps
command: sh -c "npx prisma generate --schema=prisma/schema.prisma && pnpm --filter @agent-fox/server dev"
volumes:
- ./packages/shared/src:/app/packages/shared/src
- ./packages/server/src:/app/packages/server/src
- ./prisma:/app/prisma
- ./tsconfig.base.json:/app/tsconfig.base.json
environment:
DATABASE_URL: postgresql://agentfox:agentfox@postgres:5432/agentfox
JWT_SECRET: dev-secret
JWT_REFRESH_SECRET: dev-refresh-secret
SERVER_PORT: "3000"
NODE_ENV: development
mcp:
build:
target: deps
command: sh -c "npx prisma generate --schema=prisma/schema.prisma && pnpm --filter @agent-fox/mcp dev"
volumes:
- ./packages/shared/src:/app/packages/shared/src
- ./packages/mcp/src:/app/packages/mcp/src
- ./prisma:/app/prisma
- ./tsconfig.base.json:/app/tsconfig.base.json
environment:
DATABASE_URL: postgresql://agentfox:agentfox@postgres:5432/agentfox
MCP_PORT: "3001"
NODE_ENV: development
web:
image: node:20-alpine
working_dir: /app
command: sh -c "corepack enable && corepack prepare pnpm@latest --activate && pnpm install && pnpm --filter @agent-fox/web dev -- --host 0.0.0.0"
volumes:
- .:/app
ports:
- "5173:5173"
environment:
NODE_ENV: development

57
docker-compose.yml Normal file
View File

@@ -0,0 +1,57 @@
services:
postgres:
image: postgres:16-alpine
environment:
POSTGRES_USER: agentfox
POSTGRES_PASSWORD: agentfox
POSTGRES_DB: agentfox
volumes:
- pgdata:/var/lib/postgresql/data
ports:
- "5432:5432"
healthcheck:
test: ["CMD-SHELL", "pg_isready -U agentfox"]
interval: 5s
timeout: 5s
retries: 5
server:
build:
context: .
dockerfile: packages/server/Dockerfile
environment:
DATABASE_URL: postgresql://agentfox:agentfox@postgres:5432/agentfox
JWT_SECRET: ${JWT_SECRET:-change-me-in-production}
JWT_REFRESH_SECRET: ${JWT_REFRESH_SECRET:-change-me-refresh-in-production}
SERVER_PORT: "3000"
ports:
- "3000:3000"
depends_on:
postgres:
condition: service_healthy
mcp:
build:
context: .
dockerfile: packages/mcp/Dockerfile
environment:
DATABASE_URL: postgresql://agentfox:agentfox@postgres:5432/agentfox
MCP_PORT: "3001"
ports:
- "3001:3001"
depends_on:
postgres:
condition: service_healthy
web:
build:
context: .
dockerfile: packages/web/Dockerfile
ports:
- "80:80"
depends_on:
- server
- mcp
volumes:
pgdata:

35
packages/mcp/Dockerfile Normal file
View File

@@ -0,0 +1,35 @@
FROM node:20-alpine AS base
RUN corepack enable && corepack prepare pnpm@latest --activate
WORKDIR /app
FROM base AS deps
COPY pnpm-lock.yaml pnpm-workspace.yaml package.json ./
COPY packages/shared/package.json packages/shared/
COPY packages/mcp/package.json packages/mcp/
COPY prisma/ prisma/
RUN pnpm install --frozen-lockfile
FROM base AS build
COPY --from=deps /app/ ./
COPY packages/shared/ packages/shared/
COPY packages/mcp/ packages/mcp/
COPY prisma/ prisma/
COPY tsconfig.base.json ./
RUN npx prisma generate --schema=prisma/schema.prisma
RUN pnpm --filter @agent-fox/shared build
RUN pnpm --filter @agent-fox/mcp build
FROM node:20-alpine AS runtime
WORKDIR /app
COPY --from=build /app/node_modules ./node_modules
COPY --from=build /app/packages/shared/dist ./packages/shared/dist
COPY --from=build /app/packages/shared/node_modules ./packages/shared/node_modules
COPY --from=build /app/packages/shared/package.json ./packages/shared/
COPY --from=build /app/packages/mcp/dist ./packages/mcp/dist
COPY --from=build /app/packages/mcp/node_modules ./packages/mcp/node_modules
COPY --from=build /app/packages/mcp/package.json ./packages/mcp/
COPY --from=build /app/prisma ./prisma
WORKDIR /app/packages/mcp
EXPOSE 3001
CMD ["node", "dist/index.js"]

View File

@@ -0,0 +1,38 @@
FROM node:20-alpine AS base
RUN corepack enable && corepack prepare pnpm@latest --activate
WORKDIR /app
FROM base AS deps
COPY pnpm-lock.yaml pnpm-workspace.yaml package.json ./
COPY packages/shared/package.json packages/shared/
COPY packages/server/package.json packages/server/
COPY prisma/ prisma/
RUN pnpm install --frozen-lockfile
FROM base AS build
COPY --from=deps /app/ ./
COPY packages/shared/ packages/shared/
COPY packages/server/ packages/server/
COPY prisma/ prisma/
COPY tsconfig.base.json ./
RUN npx prisma generate --schema=prisma/schema.prisma
RUN pnpm --filter @agent-fox/shared build
RUN pnpm --filter @agent-fox/server build
FROM node:20-alpine AS runtime
WORKDIR /app
COPY --from=build /app/node_modules ./node_modules
COPY --from=build /app/packages/shared/dist ./packages/shared/dist
COPY --from=build /app/packages/shared/node_modules ./packages/shared/node_modules
COPY --from=build /app/packages/shared/package.json ./packages/shared/
COPY --from=build /app/packages/server/dist ./packages/server/dist
COPY --from=build /app/packages/server/node_modules ./packages/server/node_modules
COPY --from=build /app/packages/server/package.json ./packages/server/
COPY --from=build /app/prisma ./prisma
COPY scripts/migrate-and-start.sh ./scripts/
RUN chmod +x scripts/migrate-and-start.sh
RUN npm install -g prisma@6
EXPOSE 3000
CMD ["sh", "scripts/migrate-and-start.sh"]

17
packages/web/Dockerfile Normal file
View File

@@ -0,0 +1,17 @@
FROM node:20-alpine AS build
RUN corepack enable && corepack prepare pnpm@latest --activate
WORKDIR /app
COPY pnpm-lock.yaml pnpm-workspace.yaml package.json ./
COPY packages/web/package.json packages/web/
RUN pnpm install --frozen-lockfile --filter @agent-fox/web...
COPY packages/web/ packages/web/
COPY tsconfig.base.json ./
RUN pnpm --filter @agent-fox/web build
FROM nginx:alpine
COPY --from=build /app/packages/web/dist /usr/share/nginx/html
COPY packages/web/nginx.conf /etc/nginx/conf.d/default.conf
EXPOSE 80
CMD ["nginx", "-g", "daemon off;"]

25
packages/web/nginx.conf Normal file
View File

@@ -0,0 +1,25 @@
server {
listen 80;
root /usr/share/nginx/html;
index index.html;
location /api/ {
proxy_pass http://server:3000;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
}
location /mcp/ {
proxy_pass http://mcp:3001;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_http_version 1.1;
proxy_set_header Connection '';
proxy_buffering off;
proxy_cache off;
}
location / {
try_files $uri $uri/ /index.html;
}
}

9
scripts/migrate-and-start.sh Executable file
View File

@@ -0,0 +1,9 @@
#!/bin/sh
set -e
echo "Running database migrations..."
npx prisma migrate deploy --schema=prisma/schema.prisma
echo "Starting server..."
cd /app/packages/server
exec node dist/index.js