Unify quickstart: bring up complete stack (frontend + backend + database) in one command
- Add frontend service to docker-compose.yml (port 4200) - Simplify quickstart scripts to start all services together - Remove need for separate dev-start scripts and proxy config - Frontend now accessible at http://localhost:4200 with nginx proxying API requests
This commit is contained in:
@@ -3,7 +3,7 @@
|
||||
set -e
|
||||
|
||||
echo "========================================="
|
||||
echo "Test Artifact Data Lake - Quick Start"
|
||||
echo "Obsidian - Quick Start"
|
||||
echo "========================================="
|
||||
echo ""
|
||||
|
||||
@@ -26,8 +26,6 @@ fi
|
||||
|
||||
# Parse command line arguments
|
||||
REBUILD=false
|
||||
FULL_STACK=false
|
||||
DEV_MODE=false
|
||||
|
||||
while [[ $# -gt 0 ]]; do
|
||||
case $1 in
|
||||
@@ -35,24 +33,14 @@ while [[ $# -gt 0 ]]; do
|
||||
REBUILD=true
|
||||
shift
|
||||
;;
|
||||
--full-stack)
|
||||
FULL_STACK=true
|
||||
shift
|
||||
;;
|
||||
--dev)
|
||||
DEV_MODE=true
|
||||
shift
|
||||
;;
|
||||
--help)
|
||||
echo "Usage: $0 [OPTIONS]"
|
||||
echo ""
|
||||
echo "Options:"
|
||||
echo " --rebuild Force rebuild of all containers"
|
||||
echo " --full-stack Start complete stack including frontend (production build)"
|
||||
echo " --dev Start backend only, use separate dev server for frontend"
|
||||
echo " --help Show this help message"
|
||||
echo ""
|
||||
echo "Default: Starts backend services only (recommended for development)"
|
||||
echo "Brings up the complete stack: database, backend API, and frontend"
|
||||
echo ""
|
||||
exit 0
|
||||
;;
|
||||
@@ -80,79 +68,33 @@ if [ "$REBUILD" = true ]; then
|
||||
echo "🔄 Rebuilding containers..."
|
||||
echo "Stopping existing containers..."
|
||||
$COMPOSE_CMD down
|
||||
|
||||
if [ "$FULL_STACK" = true ]; then
|
||||
echo "Removing existing images for full rebuild..."
|
||||
$COMPOSE_CMD -f docker-compose.production.yml down --rmi local 2>/dev/null || true
|
||||
echo "Building and starting full stack..."
|
||||
$COMPOSE_CMD -f docker-compose.production.yml up -d --build
|
||||
else
|
||||
echo "Removing existing backend images for rebuild..."
|
||||
$COMPOSE_CMD down --rmi local 2>/dev/null || true
|
||||
echo "Building and starting backend services..."
|
||||
$COMPOSE_CMD up -d --build
|
||||
fi
|
||||
echo "Removing existing images for rebuild..."
|
||||
$COMPOSE_CMD down --rmi local 2>/dev/null || true
|
||||
echo "Building and starting all services..."
|
||||
$COMPOSE_CMD up -d --build
|
||||
else
|
||||
# Regular startup
|
||||
if [ "$FULL_STACK" = true ]; then
|
||||
echo "Starting full production stack (backend + frontend)..."
|
||||
$COMPOSE_CMD -f docker-compose.production.yml up -d
|
||||
else
|
||||
echo "Starting backend services..."
|
||||
$COMPOSE_CMD up -d
|
||||
fi
|
||||
echo "Starting all services..."
|
||||
$COMPOSE_CMD up -d
|
||||
fi
|
||||
|
||||
echo ""
|
||||
echo "Waiting for services to be ready..."
|
||||
sleep 15
|
||||
sleep 20
|
||||
|
||||
echo ""
|
||||
echo "========================================="
|
||||
if [ "$FULL_STACK" = true ]; then
|
||||
echo "Complete Stack is running! 🚀"
|
||||
else
|
||||
echo "Backend Services are running!"
|
||||
fi
|
||||
echo "Complete Stack is running! 🚀"
|
||||
echo "========================================="
|
||||
echo ""
|
||||
echo "Frontend: http://localhost:4200"
|
||||
echo "API: http://localhost:8000"
|
||||
echo "API Docs: http://localhost:8000/docs"
|
||||
echo "MinIO Console: http://localhost:9001"
|
||||
echo " Username: minioadmin"
|
||||
echo " Password: minioadmin"
|
||||
echo ""
|
||||
|
||||
if [ "$FULL_STACK" = true ]; then
|
||||
echo "Frontend: http://localhost:80"
|
||||
echo " (Production build with Nginx)"
|
||||
echo ""
|
||||
echo "To view logs: $COMPOSE_CMD -f docker-compose.production.yml logs -f"
|
||||
echo "To stop: $COMPOSE_CMD -f docker-compose.production.yml down"
|
||||
else
|
||||
echo "To view logs: $COMPOSE_CMD logs -f"
|
||||
echo "To stop: $COMPOSE_CMD down"
|
||||
echo ""
|
||||
echo "========================================="
|
||||
echo "Frontend Options:"
|
||||
echo "========================================="
|
||||
echo ""
|
||||
echo "Development (with hot reload):"
|
||||
echo " ./dev-start.sh"
|
||||
echo " Frontend will be available at: http://localhost:4200"
|
||||
echo ""
|
||||
echo "Or start full production stack:"
|
||||
echo " ./quickstart.sh --full-stack"
|
||||
echo " Complete stack at: http://localhost:80"
|
||||
fi
|
||||
|
||||
echo ""
|
||||
echo "========================================="
|
||||
echo "Rebuild Options:"
|
||||
echo "========================================="
|
||||
echo ""
|
||||
echo "Force rebuild backend: ./quickstart.sh --rebuild"
|
||||
echo "Force rebuild full stack: ./quickstart.sh --rebuild --full-stack"
|
||||
echo "To view logs: $COMPOSE_CMD logs -f"
|
||||
echo "To stop: $COMPOSE_CMD down"
|
||||
echo ""
|
||||
echo "========================================="
|
||||
echo "Testing the API..."
|
||||
@@ -166,11 +108,8 @@ sleep 5
|
||||
if curl -s http://localhost:8000/health | grep -q "healthy"; then
|
||||
echo "✓ API is healthy!"
|
||||
echo ""
|
||||
if [ "$FULL_STACK" = false ]; then
|
||||
echo "🎯 Ready for development!"
|
||||
echo "Run './dev-start.sh' to start the frontend with hot reload"
|
||||
echo ""
|
||||
fi
|
||||
echo "🎯 All services are ready!"
|
||||
echo ""
|
||||
echo "Example: Upload a test file"
|
||||
echo "----------------------------"
|
||||
echo 'echo "test,data" > test.csv'
|
||||
@@ -186,4 +125,5 @@ fi
|
||||
|
||||
echo "========================================="
|
||||
echo "Setup complete! 🚀"
|
||||
echo "Open http://localhost:4200 in your browser"
|
||||
echo "========================================="
|
||||
|
||||
Reference in New Issue
Block a user