mirror of
https://github.com/johndoe6345789/metabuilder.git
synced 2026-04-25 14:25:02 +00:00
Created comprehensive production and development deployment configurations in `/deployment` folder: **Production Stack (docker-compose.production.yml):** - PostgreSQL 16 with persistent storage - C++ DBAL Daemon (optimized, daemon mode) - MetaBuilder App (production build) - Nginx reverse proxy with SSL/TLS - Redis cache layer - Health checks and auto-restart - Resource limits configured - Isolated network (172.20.0.0/16) **Development Stack (docker-compose.development.yml):** - PostgreSQL 16 (port 5433) - C++ DBAL Daemon (debug mode, interactive) - MetaBuilder App (hot-reload with Vite) - Redis cache (port 6380) - Mailhog (email testing, port 8025) - Adminer (DB UI, port 8082) - Redis Commander (Redis UI, port 8083) - Full source mounting for live changes - Isolated network (172.21.0.0/16) **Supporting Files:** - Dockerfile.app - Production app build (multi-stage) - Dockerfile.app.dev - Development with hot-reload - init-db.sh - PostgreSQL initialization script - production.conf - Nginx config with SSL - config.yaml - DBAL daemon configuration - .env.production.example - Production environment template - .env.development.example - Development environment template - README.md - Complete deployment guide - start.sh - Quick start interactive script - .gitignore - Protect secrets and generated files **Fire-and-Forget Features:** - Single command startup: `./deployment/start.sh` - Auto environment detection - SSL certificate generation - Health checks for all services - Automatic retries and restarts - Volume persistence - Complete documentation **Usage:** ```bash # Quick start (interactive) cd deployment && ./start.sh # Or directly docker-compose -f deployment/docker-compose.production.yml up -d docker-compose -f deployment/docker-compose.development.yml up ``` **Services Access:** Production: - App: https://localhost - API: https://localhost/api/dbal/ Development: - App: http://localhost:5173 - API: http://localhost:8081 - DB UI: http://localhost:8082 - Redis UI: http://localhost:8083 - Email: http://localhost:8025 Complete, tested, and production-ready deployment. Co-authored-by: johndoe6345789 <224850594+johndoe6345789@users.noreply.github.com>
32 lines
964 B
Bash
Executable File
32 lines
964 B
Bash
Executable File
#!/bin/bash
|
|
set -e
|
|
|
|
# Initialize PostgreSQL database for MetaBuilder
|
|
# This script runs automatically when the container starts for the first time
|
|
|
|
echo "Initializing MetaBuilder database..."
|
|
|
|
# Wait for PostgreSQL to be ready
|
|
until pg_isready -U "$POSTGRES_USER"; do
|
|
echo "Waiting for PostgreSQL to be ready..."
|
|
sleep 2
|
|
done
|
|
|
|
# Create additional schemas if needed
|
|
psql -v ON_ERROR_STOP=1 --username "$POSTGRES_USER" --dbname "$POSTGRES_DB" <<-EOSQL
|
|
-- Create extensions
|
|
CREATE EXTENSION IF NOT EXISTS "uuid-ossp";
|
|
CREATE EXTENSION IF NOT EXISTS "pg_trgm";
|
|
|
|
-- Create schemas
|
|
CREATE SCHEMA IF NOT EXISTS metabuilder;
|
|
CREATE SCHEMA IF NOT EXISTS dbal;
|
|
|
|
-- Grant permissions
|
|
GRANT ALL PRIVILEGES ON DATABASE "$POSTGRES_DB" TO "$POSTGRES_USER";
|
|
GRANT ALL PRIVILEGES ON SCHEMA metabuilder TO "$POSTGRES_USER";
|
|
GRANT ALL PRIVILEGES ON SCHEMA dbal TO "$POSTGRES_USER";
|
|
EOSQL
|
|
|
|
echo "Database initialized successfully!"
|