Advanced

Deployment

Deploy Routecraft as a Node.js process or a Docker container.

Node.js server

Routecraft runs on any provider that supports Node.js. Add a start script to your package.json:

{
  "scripts": {
    "start": "craft run ./capabilities/index.ts"
  }
}

Run npm run start to launch.

Docker

Use a two-stage image to keep the runtime image small:

# 1) Dependencies
FROM node:22-alpine AS deps
WORKDIR /app
RUN corepack enable
COPY package.json pnpm-lock.yaml ./
RUN pnpm install --frozen-lockfile --prod

# 2) Production runtime
FROM node:22-alpine
WORKDIR /app
RUN corepack enable
ENV NODE_ENV=production
COPY --from=deps /app/node_modules ./node_modules
COPY package.json ./
COPY capabilities ./capabilities

CMD ["pnpm", "craft", "run", "./capabilities/index.ts"]

CLI reference

All craft CLI commands including run and build.

Previous
Testing