website/src/content/docs/connect/gcp-cloud-run.mdx
gcloud CLI authenticated (gcloud auth login) and project set (gcloud config set project YOUR_PROJECT)Create a Dockerfile in your project root:
FROM node:20-alpine
WORKDIR /app
COPY package*.json ./
RUN npm ci --omit=dev
COPY . .
ENV PORT=8080
CMD ["node", "server.js"]
Use Cloud Build to build and push the image. Replace the region and repository with your own.
gcloud builds submit --tag us-central1-docker.pkg.dev/YOUR_PROJECT/rivetkit-app/rivetkit-app:latest
After creating your project on the Rivet dashboard, select Google Cloud Run as your provider. You'll be provided RIVET_ENDPOINT and RIVET_PUBLIC_ENDPOINT environment variables to use when deploying.
Deploy the service to Cloud Run, passing the Rivet environment variables. Adjust the region and image as needed.
gcloud run deploy rivetkit-app \
--image us-central1-docker.pkg.dev/YOUR_PROJECT/rivetkit-app/rivetkit-app:latest \
--region us-central1 \
--allow-unauthenticated \
--min-instances 1 \
--set-env-vars RIVET_ENDPOINT=<your-rivet-endpoint>,RIVET_PUBLIC_ENDPOINT=<your-rivet-public-endpoint>
https://rivetkit-app-xxxxx-uc.a.run.app)/api/rivet path into the connect form (e.g. https://rivetkit-app-xxxxx-uc.a.run.app/api/rivet)Confirm the service is running:
gcloud run services describe rivetkit-app --region us-central1 --format 'value(status.conditions[?type="Ready"].status)'
Your app should appear as connected on the Rivet dashboard once the service reports ready.
</Step> </Steps>