-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathstart_service_debug.sh
More file actions
66 lines (59 loc) · 3.25 KB
/
start_service_debug.sh
File metadata and controls
66 lines (59 loc) · 3.25 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
#!/bin/bash
# set default config values
if [[ -f ./env/ocr_service.env ]]; then
set -a
echo "Reading env vars from ./env/ocr_service.env"
# shellcheck disable=SC1091
source ./env/ocr_service.env
set +a
else
echo "Env file ./env/ocr_service.env not found. Using built-in defaults."
fi
export OCR_SERVICE_HOST="${OCR_SERVICE_HOST:-0.0.0.0}"
export OCR_SERVICE_PORT="${OCR_SERVICE_PORT:-8090}"
export OCR_SERVICE_WORKER_CLASS="${OCR_SERVICE_WORKER_CLASS:-sync}"
export OCR_WEB_SERVICE_WORKERS="${OCR_WEB_SERVICE_WORKERS:-1}"
export OCR_SERVICE_LOG_LEVEL="${OCR_SERVICE_LOG_LEVEL:-20}"
export OCR_SERVICE_GUNICORN_LOG_FILE_PATH="${OCR_SERVICE_GUNICORN_LOG_FILE_PATH:--}"
export OCR_SERVICE_GUNICORN_LOG_LEVEL="${OCR_SERVICE_GUNICORN_LOG_LEVEL:-info}"
export OCR_SERVICE_GUNICORN_MAX_REQUESTS_JITTER="${OCR_SERVICE_GUNICORN_MAX_REQUESTS_JITTER:-5000}"
export OCR_SERVICE_GUNICORN_MAX_REQUESTS="${OCR_SERVICE_GUNICORN_MAX_REQUESTS:-50000}"
export OCR_SERVICE_GUNICORN_TIMEOUT="${OCR_SERVICE_GUNICORN_TIMEOUT:-300}"
export OCR_SERVICE_GUNICORN_GRACEFUL_TIMEOUT="${OCR_SERVICE_GUNICORN_GRACEFUL_TIMEOUT:-30}"
# start the OCR_SERVICE
echo "Starting up OCR app using gunicorn OCR_SERVICE ..."
echo "====================================== OCR Service Configuration =============================="
echo "OCR_SERVICE_HOST: $OCR_SERVICE_HOST"
echo "OCR_SERVICE_PORT: $OCR_SERVICE_PORT"
echo "OCR_SERVICE_WORKER_CLASS: $OCR_SERVICE_WORKER_CLASS"
echo "OCR_WEB_SERVICE_WORKERS: $OCR_WEB_SERVICE_WORKERS"
echo "OCR_SERVICE_LOG_LEVEL: $OCR_SERVICE_LOG_LEVEL"
echo "OCR_SERVICE_GUNICORN_LOG_FILE_PATH: $OCR_SERVICE_GUNICORN_LOG_FILE_PATH"
echo "OCR_SERVICE_GUNICORN_LOG_LEVEL: $OCR_SERVICE_GUNICORN_LOG_LEVEL"
echo "OCR_SERVICE_GUNICORN_MAX_REQUESTS_JITTER: $OCR_SERVICE_GUNICORN_MAX_REQUESTS_JITTER"
echo "OCR_SERVICE_GUNICORN_MAX_REQUESTS: $OCR_SERVICE_GUNICORN_MAX_REQUESTS"
echo "OCR_SERVICE_GUNICORN_TIMEOUT: $OCR_SERVICE_GUNICORN_TIMEOUT"
echo "OCR_SERVICE_GUNICORN_GRACEFUL_TIMEOUT: $OCR_SERVICE_GUNICORN_GRACEFUL_TIMEOUT"
echo "==============================================================================================="
python_version=python3
if command -v python3.11 &>/dev/null; then
python_version=python3.11
elif command -v python3.12 &>/dev/null; then
python_version=python3.12
elif command -v python3.13 &>/dev/null; then
python_version=python3.13
else
echo "Python 3.11, 3.12, or 3.13 is required. Please install one of them."
exit 1
fi
gunicorn_cmd=("$python_version" "-m" "gunicorn")
exec "${gunicorn_cmd[@]}" wsgi:app --worker-class "$OCR_SERVICE_WORKER_CLASS" \
--bind "$OCR_SERVICE_HOST:$OCR_SERVICE_PORT" \
--threads "1" \
--workers "$OCR_WEB_SERVICE_WORKERS" \
--access-logfile "$OCR_SERVICE_GUNICORN_LOG_FILE_PATH" \
--reload --log-level "debug" \
--max-requests "$OCR_SERVICE_GUNICORN_MAX_REQUESTS" \
--max-requests-jitter "$OCR_SERVICE_GUNICORN_MAX_REQUESTS_JITTER" \
--timeout "$OCR_SERVICE_GUNICORN_TIMEOUT" \
--graceful-timeout "$OCR_SERVICE_GUNICORN_GRACEFUL_TIMEOUT"