| #!/bin/bash |
| |
| |
|
|
| set -e |
|
|
| echo "============================================================" |
| echo "HonestAI Production Startup Script" |
| echo "============================================================" |
|
|
| |
| if [ -z "$HF_TOKEN" ]; then |
| echo "ERROR: HF_TOKEN environment variable is not set" |
| echo "Please set HF_TOKEN in Space Settings β Repository secrets" |
| exit 1 |
| fi |
| echo "β HF_TOKEN is set" |
|
|
| |
| if [ -z "$OMP_NUM_THREADS" ]; then |
| echo "WARNING: OMP_NUM_THREADS not set, defaulting to 4" |
| export OMP_NUM_THREADS=4 |
| elif ! [[ "$OMP_NUM_THREADS" =~ ^[0-9]+$ ]] || [ "$OMP_NUM_THREADS" -le 0 ]; then |
| echo "WARNING: Invalid OMP_NUM_THREADS='$OMP_NUM_THREADS', setting to 4" |
| export OMP_NUM_THREADS=4 |
| fi |
| export MKL_NUM_THREADS=$OMP_NUM_THREADS |
| echo "β OMP_NUM_THREADS set to $OMP_NUM_THREADS" |
|
|
| |
| if [ -z "$MKL_NUM_THREADS" ]; then |
| export MKL_NUM_THREADS=$OMP_NUM_THREADS |
| fi |
| echo "β MKL_NUM_THREADS set to $MKL_NUM_THREADS" |
|
|
| |
| LOG_DIR=${LOG_DIR:-/tmp/logs} |
| mkdir -p "$LOG_DIR" |
| chmod 700 "$LOG_DIR" 2>/dev/null || echo "Warning: Could not set log directory permissions" |
| echo "β Log directory: $LOG_DIR" |
|
|
| |
| PORT=${PORT:-7860} |
| echo "β Port: $PORT" |
|
|
| |
| WORKERS=${GUNICORN_WORKERS:-4} |
| echo "β Gunicorn workers: $WORKERS" |
|
|
| |
| RATE_LIMIT_ENABLED=${RATE_LIMIT_ENABLED:-true} |
| echo "β Rate limiting: $RATE_LIMIT_ENABLED" |
|
|
| echo "============================================================" |
| echo "Starting Gunicorn production server..." |
| echo "============================================================" |
|
|
| |
| exec gunicorn \ |
| --bind "0.0.0.0:$PORT" \ |
| --workers "$WORKERS" \ |
| --threads 2 \ |
| --timeout 120 \ |
| --keep-alive 5 \ |
| --access-logfile - \ |
| --error-logfile - \ |
| --log-level info \ |
| --capture-output \ |
| flask_api_standalone:app |
|
|
|
|