Skip to content

DYSLEVIUM/api-scheduler

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

API Scheduler

A distributed API scheduling system built with FastAPI, Temporal, and PostgreSQL.

Quick Start

# Start all services
podman compose up --build

Access Points

Service URL Credentials
API http://localhost:8000 -
Web UI http://localhost:3001 -
Grafana http://localhost:3000 admin/admin
Prometheus http://localhost:9090 -
Temporal UI http://localhost:8080 -
API Docs http://localhost:8000/docs -

Monitoring & Logs

Complete Observability Stack: Logs, metrics, and system monitoring in one place.

📊 What's Monitored

Application & Service Metrics

  • ✅ HTTP requests, latency, status codes
  • ✅ Database connections, queries, performance
  • ✅ All CRUD operations with timing
  • ✅ Errors, warnings, and stack traces

System & Container Metrics

  • ✅ CPU usage per container and host
  • ✅ Memory usage and limits
  • ✅ Network I/O (RX/TX bytes/sec)
  • ✅ Disk I/O (read/write bytes/sec)
  • ✅ Filesystem usage

Logs

  • ✅ Structured application logs
  • ✅ Database query logs
  • ✅ HTTP request/response logs
  • ✅ Container logs

🎯 Quick Access

# View dashboards in Grafana
open http://localhost:3000

📈 Grafana Dashboards

  • API Overview: Application metrics (requests, latency)
  • PostgreSQL: Database performance
  • System Metrics: CPU, memory, I/O for all services ⭐ NEW
  • Logs: Real-time structured logs

Development

Running Tests

cd services/api
uv run pytest

Architecture

  • API: FastAPI application
  • Worker: Temporal workflow engine
  • Database: PostgreSQL (app + temporal)
  • Monitoring: Prometheus + Grafana
  • Logging: Loki + Promtail
  • Frontend: React + Vite

Troubleshooting

# View all service status
podman compose ps

# Restart specific service
podman compose restart api

# View logs
podman compose logs -f api

# Rebuild and restart
podman compose up --build -d

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors