mirror of
https://github.com/Memo-2023/mana-monorepo.git
synced 2026-05-14 20:21:09 +02:00
node:20-slim doesn't include wget or curl, which is required for the HEALTHCHECK commands in the Dockerfiles. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
71 lines
2.2 KiB
Docker
71 lines
2.2 KiB
Docker
# Build stage
|
|
FROM node:20-slim AS builder
|
|
|
|
WORKDIR /app
|
|
|
|
# Enable pnpm via corepack
|
|
RUN corepack enable && corepack prepare pnpm@9.15.0 --activate
|
|
|
|
# Copy workspace configuration
|
|
COPY pnpm-workspace.yaml package.json pnpm-lock.yaml ./
|
|
|
|
# Copy shared packages that this bot depends on
|
|
COPY packages/bot-services ./packages/bot-services
|
|
COPY packages/matrix-bot-common ./packages/matrix-bot-common
|
|
|
|
# Copy this bot
|
|
COPY services/matrix-ollama-bot ./services/matrix-ollama-bot
|
|
|
|
# Install all dependencies
|
|
RUN pnpm install --frozen-lockfile --ignore-scripts
|
|
|
|
# Build shared packages first (in dependency order)
|
|
RUN pnpm --filter @manacore/bot-services build
|
|
RUN pnpm --filter @manacore/matrix-bot-common build
|
|
|
|
# Build the bot
|
|
RUN pnpm --filter @manacore/matrix-ollama-bot build
|
|
|
|
# Production stage
|
|
FROM node:20-slim AS runner
|
|
|
|
WORKDIR /app
|
|
|
|
# Install wget for health checks and enable pnpm
|
|
RUN apt-get update && apt-get install -y wget && rm -rf /var/lib/apt/lists/* \
|
|
&& corepack enable && corepack prepare pnpm@9.15.0 --activate
|
|
|
|
# Copy workspace configuration
|
|
COPY pnpm-workspace.yaml package.json pnpm-lock.yaml ./
|
|
|
|
# Copy built shared packages
|
|
COPY --from=builder /app/packages/bot-services/dist ./packages/bot-services/dist
|
|
COPY --from=builder /app/packages/bot-services/package.json ./packages/bot-services/
|
|
COPY --from=builder /app/packages/matrix-bot-common/dist ./packages/matrix-bot-common/dist
|
|
COPY --from=builder /app/packages/matrix-bot-common/package.json ./packages/matrix-bot-common/
|
|
|
|
# Copy built bot
|
|
COPY --from=builder /app/services/matrix-ollama-bot/dist ./services/matrix-ollama-bot/dist
|
|
COPY --from=builder /app/services/matrix-ollama-bot/package.json ./services/matrix-ollama-bot/
|
|
|
|
# Install production dependencies only
|
|
RUN pnpm install --frozen-lockfile --prod --ignore-scripts
|
|
|
|
# Create data directory
|
|
RUN mkdir -p /app/data
|
|
|
|
# Create non-root user
|
|
RUN groupadd --system --gid 1001 nodejs && \
|
|
useradd --system --uid 1001 -g nodejs nestjs && \
|
|
chown -R nestjs:nodejs /app
|
|
|
|
USER nestjs
|
|
|
|
WORKDIR /app/services/matrix-ollama-bot
|
|
|
|
HEALTHCHECK --interval=30s --timeout=10s --start-period=30s --retries=3 \
|
|
CMD wget --no-verbose --tries=1 --spider http://localhost:4011/health || exit 1
|
|
|
|
EXPOSE 4011
|
|
|
|
CMD ["node", "dist/main.js"]
|