PatchMon Docker
Overview
PatchMon is a containerised application that monitors system patches and updates. The application consists of three main services:
- Database: PostgreSQL 17
- Backend: Node.js API server
- Frontend: React application served via Nginx
Images
- Backend: ghcr.io/9technologygroup/patchmon-backend:latest
- Frontend: ghcr.io/9technologygroup/patchmon-frontend:latest
Version tags are also available (e.g. 1.2.3
) for both of these images.
Quick Start
Production Deployment
- Download the Docker Compose file
- Set a database password in the file where it says:
environment: POSTGRES_PASSWORD: # CREATE A STRONG PASSWORD AND PUT IT HERE
- Update the corresponding
DATABASE_URL
with your password in the backend service where it says:environment: DATABASE_URL: postgresql://patchmon_user:REPLACE_YOUR_POSTGRES_PASSWORD_HERE@database:5432/patchmon_db
- Generate a strong JWT secret. You can do this like so:
openssl rand -hex 64
- Set a JWT secret in the backend service where it says:
environment: JWT_SECRET: # CREATE A STRONG SECRET AND PUT IT HERE
- Configure environment variables (see Configuration section)
- Start the application:
docker compose up -d
- Access the application at
http://localhost:3000
Updating
By default, the compose file uses the latest
tag for both backend and frontend images.
This means you can update PatchMon to the latest version as easily as:
docker compose up -d --pull
This command will:
- Pull the latest images from the registry
- Recreate containers with updated images
- Maintain your data and configuration
Version-Specific Updates
If you'd like to pin your Docker deployment of PatchMon to a specific version, you can do this in the compose file.
When you do this, updating to a new version requires manually updating the image tags in the compose file yourself:
-
Update the image tags in
docker-compose.yml
. For example:services: backend: image: ghcr.io/9technologygroup/patchmon-backend:1.2.3 # Update version here ... frontend: image: ghcr.io/9technologygroup/patchmon-frontend:1.2.3 # Update version here ...
-
Then run the update command:
docker compose up -d --pull
Tip
Check the releases page for version-specific changes and migration notes.
Configuration
Environment Variables
Database Service
Variable | Description | Default |
---|---|---|
POSTGRES_DB |
Database name | patchmon_db |
POSTGRES_USER |
Database user | patchmon_user |
POSTGRES_PASSWORD |
Database password | MUST BE SET! |
Backend Service
Database Configuration
Variable | Description | Default |
---|---|---|
DATABASE_URL |
PostgreSQL connection string | MUST BE UPDATED WITH YOUR POSTGRES_PASSWORD! |
PM_DB_CONN_MAX_ATTEMPTS |
Maximum database connection attempts | 30 |
PM_DB_CONN_WAIT_INTERVAL |
Wait interval between connection attempts in seconds | 2 |
Authentication & Security
Variable | Description | Default |
---|---|---|
JWT_SECRET |
JWT signing secret - Generate with openssl rand -hex 64 |
MUST BE SET! |
JWT_EXPIRES_IN |
JWT token expiration time | 1h |
JWT_REFRESH_EXPIRES_IN |
JWT refresh token expiration time | 7d |
SESSION_INACTIVITY_TIMEOUT_MINUTES |
Session inactivity timeout in minutes | 30 |
DEFAULT_USER_ROLE |
Default role for new users | user |
Server & Network Configuration
Variable | Description | Default |
---|---|---|
PORT |
Backend API port | 3001 |
SERVER_PROTOCOL |
Frontend server protocol (http or https ) |
http |
SERVER_HOST |
Frontend server host | localhost |
SERVER_PORT |
Frontend server port | 3000 |
CORS_ORIGIN |
CORS origin URL | http://localhost:3000 |
ENABLE_HSTS |
Enable HTTP Strict Transport Security | true |
TRUST_PROXY |
Trust proxy headers - See Express.js docs | true |
Rate Limiting
Variable | Description | Default |
---|---|---|
RATE_LIMIT_WINDOW_MS |
Rate limiting window in milliseconds | 900000 |
RATE_LIMIT_MAX |
Maximum requests per window | 5000 |
AUTH_RATE_LIMIT_WINDOW_MS |
Authentication rate limiting window in milliseconds | 600000 |
AUTH_RATE_LIMIT_MAX |
Maximum authentication requests per window | 500 |
AGENT_RATE_LIMIT_WINDOW_MS |
Agent API rate limiting window in milliseconds | 60000 |
AGENT_RATE_LIMIT_MAX |
Maximum agent requests per window | 1000 |
Logging
Variable | Description | Default |
---|---|---|
LOG_LEVEL |
Logging level (debug , info , warn , error ) |
info |
ENABLE_LOGGING |
Enable application logging | true |
Frontend Service
Variable | Description | Default |
---|---|---|
BACKEND_HOST |
Backend service hostname | backend |
BACKEND_PORT |
Backend service port | 3001 |
Volumes
The compose file creates two Docker volumes:
postgres_data
: PostgreSQL's data directory.agent_files
: PatchMon's agent files.
If you wish to bind either if their respective container paths to a host path rather than a Docker volume, you can do so in the Docker Compose file.
Tip
The backend container runs as user & group ID 1000. If you plan to re-bind the agent files directory, ensure that the same user and/or group ID has permission to write to the host path to which it's bound.
Development
This section is for developers who want to contribute to PatchMon or run it in development mode.
Development Setup
For development with live reload and source code mounting:
-
Clone the repository:
git clone https://github.com/PatchMon/PatchMon.git cd patchmon.net
-
Start development environment:
docker compose -f docker/docker-compose.dev.yml up
See Development Commands for more options.
-
Access the application:
- Frontend:
http://localhost:3000
- Backend API:
http://localhost:3001
- Database:
localhost:5432
- Frontend:
Development Docker Compose
The development compose file (docker/docker-compose.dev.yml
):
- Builds images locally from source using development targets
- Enables hot reload with Docker Compose watch functionality
- Exposes database and backend ports for testing and development
- Mounts source code directly into containers for live development
- Supports debugging with enhanced logging
Building Images Locally
Both Dockerfiles use multi-stage builds with separate development and production targets:
# Build development images
docker build -f docker/backend.Dockerfile --target development -t patchmon-backend:dev .
docker build -f docker/frontend.Dockerfile --target development -t patchmon-frontend:dev .
# Build production images (default target)
docker build -f docker/backend.Dockerfile -t patchmon-backend:latest .
docker build -f docker/frontend.Dockerfile -t patchmon-frontend:latest .
Development Commands
Hot Reload Development
# Attached, live log output, services stopped on Ctrl+C
docker compose -f docker/docker-compose.dev.yml up
# Attached with Docker Compose watch for hot reload
docker compose -f docker/docker-compose.dev.yml up --watch
# Detached
docker compose -f docker/docker-compose.dev.yml up -d
# Quiet, no log output, with Docker Compose watch for hot reload
docker compose -f docker/docker-compose.dev.yml watch
Rebuild Services
# Rebuild specific service
docker compose -f docker/docker-compose.dev.yml up -d --build backend
# Rebuild all services
docker compose -f docker/docker-compose.dev.yml up -d --build
Development Ports
The development setup exposes additional ports for debugging:
- Database:
5432
- Direct PostgreSQL access - Backend:
3001
- API server with development features - Frontend:
3000
- React development server with hot reload
Development Workflow
-
Initial Setup: Clone repository and start development environment
git clone https://github.com/PatchMon/PatchMon.git cd patchmon.net docker compose -f docker/docker-compose.dev.yml up -d --build
-
Hot Reload Development: Use Docker Compose watch for automatic reload
docker compose -f docker/docker-compose.dev.yml up --watch --build
-
Code Changes:
- Frontend/Backend Source: Files are synced automatically with watch mode
- Package.json Changes: Triggers automatic service rebuild
- Prisma Schema Changes: Backend service restarts automatically
-
Database Access: Connect database client directly to
localhost:5432
-
Debug: If started with
docker compose [...] up -d
ordocker compose [...] watch
, check logs manually:docker compose -f docker/docker-compose.dev.yml logs -f
Otherwise logs are shown automatically in attached modes (
up
,up --watch
).
Features in Development Mode
- Hot Reload: Automatic code synchronization and service restarts
- Enhanced Logging: Detailed logs for debugging
- Direct Access: Exposed ports for database and API debugging
- Health Checks: Built-in health monitoring for services
- Volume Persistence: Development data persists between restarts