-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathrun.sh
executable file
·74 lines (62 loc) · 2.23 KB
/
run.sh
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
67
68
69
70
71
72
73
74
#!/bin/bash
test -f env_ext.sh && \
source env_ext.sh
get_cpu_limit()
{
cfs_quota_us=$(cat /sys/fs/cgroup/cpu/cpu.cfs_quota_us)
cfs_period_us=$(cat /sys/fs/cgroup/cpu/cpu.cfs_period_us)
cpu_limit=$(expr ${cfs_quota_us} / ${cfs_period_us})
if [[ ${cpu_limit} -ne 0 ]];then
export CPU_LIMIT=${cpu_limit}
else
export CPU_LIMIT=0
fi
}
export HOST=${flyer_host:-0.0.0.0}
export PORT=${flyer_port:-8080}
export BIND=${HOST}:${PORT}
export WORKER_CONNECTIONS=${flyer_worker_connections:-1000}
# 通过容器CPU限制计算worker数,可以被flyer_workers变量覆盖
get_cpu_limit
if [[ ! -z ${flyer_workers} ]];then
export WORKERS=${flyer_workers:-1}
elif [[ ${CPU_LIMIT} -ne 0 ]];then
export WORKERS=$(expr \( ${CPU_LIMIT} \* 2 \) + 1)
else
export WORKERS=1
fi
export THREADS=$(expr \( ${CPU_LIMIT} \* 4 \) + 1)
export max_requests=$(expr \( ${THREADS} \* 200 \) )
export max_requests=${flyer_max_requests:-${max_requests}}
export max_requests_jitter=${flyer_max_requests_jitter:-${max_requests}}
export GRACEFUL_TIMEOUT=${flyer_graceful_timeout:-10}
export TIMEOUT=${flyer_timeout:-10}
export THREADS=${flyer_threads:-${THREADS}}
export KEEPALIVE=${flyer_keepalive:-5}
export LOG_LEVEL=${flyer_log_level:-info}
if [[ "${flyer_access_log}" == "1" ]];then
# 访问日志默认记录到容器标准输出
export ACCESS_LOGFILE=${flyer_access_logfile:--}
export ACCESS_CONFIG="--access-logfile=${ACCESS_LOGFILE}"
fi
if [[ "${flyer_reload}" == "1" ]];then
export RELOAD="--reload"
fi
if [[ "${flyer_preload}" == "1" ]];then
export PRELOAD="--preload"
fi
if [[ "${flyer_enable_max_requests}" == "1" ]];then
export MAX_REQUESTS="--max-requests ${max_requests}"
export MAX_REQUESTS_JITTER="--max-requests-jitter ${max_requests_jitter}"
fi
exec gunicorn main:app \
--worker-class uvicorn.workers.UvicornWorker \
--workers ${WORKERS} \
--bind ${BIND} \
--graceful-timeout ${GRACEFUL_TIMEOUT} \
--timeout ${TIMEOUT} \
--threads ${THREADS} ${MAX_REQUESTS} ${MAX_REQUESTS_JITTER} \
--keep-alive ${KEEPALIVE} ${RELOAD} ${PRELOAD} \
--worker-connections=${WORKER_CONNECTIONS} \
--access-logformat="${ACCESS_LOGFORMAT}" ${ACCESS_CONFIG} \
--log-level=${LOG_LEVEL} $@