Getting Started2 min read
Installation Guide
Installation Guide
This guide covers the recommended ways to install OpsKnight and get a working instance quickly.
Before You Begin
- Docker Engine 20+ and Docker Compose 2+ (for container installs)
- PostgreSQL 14+ (required for any deployment)
- A stable base URL for production installs (used by auth callbacks)
Deployment Options
| Method | Best For |
|---|---|
| Docker Compose | Development and small deployments |
| Kubernetes | Production and scaling |
| Helm | Templated Kubernetes installs |
| Local Development | Contributing and testing |
Docker Compose
The fastest way to run OpsKnight locally or in a small environment.
Step 1: Clone and Configure
git clone https://github.com/dushyant-rahangdale/opsknight.git
cd opsknight
cp env.example .env
Step 2: Set Core Environment Variables
Edit .env and set the required values:
# Required
DATABASE_URL=postgresql://opsknight:your_password@postgres:5432/opsknight_db
NEXTAUTH_URL=http://localhost:3000
NEXTAUTH_SECRET=your-secret-key-here # Generate with: openssl rand -base64 32
# Optional - Configure via UI
# Optional - Configure via UI
# (No additional env vars required)
Note: In production, set
NEXTAUTH_URLto your public domain (HTTPS).
Step 3: Start Services
docker compose up -d
Step 4: Create Admin User
Open http://localhost:3000 in your browser. You'll be automatically redirected to /setup where you can create your admin account:
- Enter your Name
- Enter your Email
- Click Create Admin Account
- Important: Copy the generated password immediately — it's shown only once
After setup, log in with your email and the generated password.
Helm (Kubernetes)
Use the Helm chart for repeatable Kubernetes installs.
Follow the full guide here: Helm Deployment.
Local Development
For contributors and developers running the app directly.
Prerequisites
- Node.js 18+
- PostgreSQL 14+
- npm or yarn
Setup
# Install dependencies
npm install
# Set up database
npx prisma migrate deploy
npx prisma generate
# Start development server
npm run dev
Verify the Install
After installation, verify:
- Application loads at
http://localhost:3000 - You can log in with the admin account
- Dashboard displays without errors
- You can create a service successfully
Common Issues
Database Connection Issues
# Check PostgreSQL is running
docker compose logs postgres
# Reset database
docker compose down -v
docker compose up -d
Port Conflicts
If port 3000 is in use, modify docker-compose.yml:
ports:
- '3001:3000' # Use port 3001 instead
Login Redirects
If the login redirects unexpectedly:
- Confirm
NEXTAUTH_URLmatches your real base URL. - Regenerate
NEXTAUTH_SECRETif sessions fail to validate.
Last updated for v1
Edit this page on GitHub