2024-07-24 22:47:53 +03:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
unset _NGX_WORKER_PROCESSES _NGX_WORKER_PRIORITY _NGX_WORKER_RLIMIT_NOFILE _NGX_WORKER_CONNECTIONS _NGX_WORKER_AIO_REQUESTS
|
|
|
|
## here should be SANE defaults (!)
|
|
|
|
_NGX_WORKER_PROCESSES=2
|
|
|
|
_NGX_WORKER_PRIORITY=0
|
|
|
|
_NGX_WORKER_RLIMIT_NOFILE=16384
|
|
|
|
_NGX_WORKER_CONNECTIONS=4096
|
|
|
|
_NGX_WORKER_AIO_REQUESTS=64
|
|
|
|
|
|
|
|
[ -n "${NGX_WORKER_PROCESSES:-}" ] || NGX_WORKER_PROCESSES=${_NGX_WORKER_PROCESSES}
|
|
|
|
case "${NGX_WORKER_PROCESSES}" in
|
|
|
|
## allow values within [1;999]
|
|
|
|
[1-9] | [1-9][0-9] | [1-9][0-9][0-9] ) ;;
|
|
|
|
[Aa][Uu][Tt][Oo] )
|
|
|
|
## adjust
|
|
|
|
NGX_WORKER_PROCESSES=auto
|
|
|
|
log_always "NGX_WORKER_PROCESSES: \"auto\" isn't supported by container yet"
|
|
|
|
log_always "offloading decision to Angie (this could be a problem!)"
|
|
|
|
;;
|
|
|
|
0 )
|
|
|
|
log_always "NGX_WORKER_PROCESSES: \"0\" isn't supported by container yet"
|
|
|
|
log_always "setting NGX_WORKER_PROCESSES=${_NGX_WORKER_PROCESSES}"
|
|
|
|
NGX_WORKER_PROCESSES=${_NGX_WORKER_PROCESSES}
|
|
|
|
;;
|
|
|
|
* )
|
|
|
|
log_always "NGX_WORKER_PROCESSES: unrecognized value: ${NGX_WORKER_PROCESSES}"
|
|
|
|
log_always "setting NGX_WORKER_PROCESSES=${_NGX_WORKER_PROCESSES}"
|
|
|
|
NGX_WORKER_PROCESSES=${_NGX_WORKER_PROCESSES}
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
export NGX_WORKER_PROCESSES
|
|
|
|
|
|
|
|
if [ -z "${NGX_WORKER_CPU_AFFINITY:-}" ] ; then
|
|
|
|
unset NGX_WORKER_CPU_AFFINITY
|
|
|
|
else
|
|
|
|
## offload handling to Angie
|
|
|
|
set -a
|
|
|
|
NGX_WORKER_CPU_AFFINITY=$(normalize_list "${NGX_WORKER_CPU_AFFINITY}")
|
|
|
|
set +a
|
|
|
|
fi
|
|
|
|
|
|
|
|
[ -n "${NGX_WORKER_CONNECTIONS:-}" ] || NGX_WORKER_CONNECTIONS=${_NGX_WORKER_CONNECTIONS}
|
|
|
|
case "${NGX_WORKER_CONNECTIONS}" in
|
|
|
|
[0-9] | [1-9][0-9] )
|
|
|
|
log_always "NGX_WORKER_CONNECTIONS: too low: ${NGX_WORKER_CONNECTIONS}"
|
|
|
|
log_always "setting NGX_WORKER_CONNECTIONS=${_NGX_WORKER_CONNECTIONS}"
|
|
|
|
NGX_WORKER_CONNECTIONS=${_NGX_WORKER_CONNECTIONS}
|
|
|
|
;;
|
|
|
|
## allow values within [100;9999999]
|
|
|
|
[1-9][0-9][0-9] ) ;;
|
|
|
|
[1-9][0-9][0-9][0-9] ) ;;
|
|
|
|
[1-9][0-9][0-9][0-9][0-9] ) ;;
|
|
|
|
[1-9][0-9][0-9][0-9][0-9][0-9] ) ;;
|
|
|
|
[1-9][0-9][0-9][0-9][0-9][0-9][0-9] ) ;;
|
|
|
|
* )
|
|
|
|
log_always "NGX_WORKER_CONNECTIONS: unrecognized value: ${NGX_WORKER_CONNECTIONS}"
|
|
|
|
log_always "setting NGX_WORKER_CONNECTIONS=${_NGX_WORKER_CONNECTIONS}"
|
|
|
|
NGX_WORKER_CONNECTIONS=${_NGX_WORKER_CONNECTIONS}
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
export NGX_WORKER_CONNECTIONS
|
|
|
|
|
|
|
|
if [ -z "${NGX_WORKER_PRIORITY:-}" ] ; then
|
|
|
|
unset NGX_WORKER_PRIORITY
|
|
|
|
else
|
|
|
|
case "${NGX_WORKER_PRIORITY}" in
|
|
|
|
-[1-9] | -1[0-9] | -20 ) ;;
|
|
|
|
[0-9] | 1[0-9] | 20 ) ;;
|
|
|
|
-0 )
|
|
|
|
log_always "NGX_WORKER_PRIORITY: likely an error: '-0'"
|
|
|
|
log_always "adjusting NGX_WORKER_PRIORITY=0"
|
|
|
|
NGX_WORKER_PRIORITY=0
|
|
|
|
;;
|
|
|
|
* )
|
|
|
|
log_always "NGX_WORKER_PRIORITY: unrecognized value: ${NGX_WORKER_PRIORITY}"
|
|
|
|
log_always "setting NGX_WORKER_PRIORITY=${_NGX_WORKER_PRIORITY}"
|
|
|
|
NGX_WORKER_PRIORITY=${_NGX_WORKER_PRIORITY}
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
export NGX_WORKER_PRIORITY
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -z "${NGX_WORKER_RLIMIT_NOFILE:-}" ] ; then
|
|
|
|
unset NGX_WORKER_RLIMIT_NOFILE
|
|
|
|
else
|
|
|
|
case "${NGX_WORKER_RLIMIT_NOFILE}" in
|
|
|
|
[0-9] | [1-9][0-9] )
|
|
|
|
log_always "NGX_WORKER_RLIMIT_NOFILE: too low: ${NGX_WORKER_RLIMIT_NOFILE}"
|
|
|
|
log_always "setting NGX_WORKER_RLIMIT_NOFILE=${_NGX_WORKER_RLIMIT_NOFILE}"
|
|
|
|
NGX_WORKER_RLIMIT_NOFILE=${_NGX_WORKER_RLIMIT_NOFILE}
|
|
|
|
;;
|
|
|
|
## allow values within [100;9999999]
|
|
|
|
[1-9][0-9][0-9] ) ;;
|
|
|
|
[1-9][0-9][0-9][0-9] ) ;;
|
|
|
|
[1-9][0-9][0-9][0-9][0-9] ) ;;
|
|
|
|
[1-9][0-9][0-9][0-9][0-9][0-9] ) ;;
|
|
|
|
[1-9][0-9][0-9][0-9][0-9][0-9][0-9] ) ;;
|
|
|
|
* )
|
|
|
|
log_always "NGX_WORKER_RLIMIT_NOFILE: unrecognized value: ${NGX_WORKER_RLIMIT_NOFILE}"
|
|
|
|
log_always "setting NGX_WORKER_RLIMIT_NOFILE=${_NGX_WORKER_RLIMIT_NOFILE}"
|
|
|
|
NGX_WORKER_RLIMIT_NOFILE=${_NGX_WORKER_RLIMIT_NOFILE}
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
export NGX_WORKER_RLIMIT_NOFILE
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -z "${NGX_WORKER_AIO_REQUESTS:-}" ] ; then
|
|
|
|
unset NGX_WORKER_AIO_REQUESTS
|
|
|
|
else
|
|
|
|
case "${NGX_WORKER_AIO_REQUESTS}" in
|
|
|
|
[0-9] )
|
|
|
|
log_always "NGX_WORKER_AIO_REQUESTS: too low: ${NGX_WORKER_AIO_REQUESTS}"
|
|
|
|
log_always "setting NGX_WORKER_AIO_REQUESTS=${_NGX_WORKER_AIO_REQUESTS}"
|
|
|
|
NGX_WORKER_AIO_REQUESTS=${_NGX_WORKER_AIO_REQUESTS}
|
|
|
|
;;
|
|
|
|
## allow values within [10;99999]
|
|
|
|
[1-9][0-9] ) ;;
|
|
|
|
[1-9][0-9][0-9] ) ;;
|
|
|
|
[1-9][0-9][0-9][0-9] ) ;;
|
|
|
|
[1-9][0-9][0-9][0-9][0-9] ) ;;
|
|
|
|
* )
|
|
|
|
log_always "NGX_WORKER_AIO_REQUESTS: unrecognized value: ${NGX_WORKER_AIO_REQUESTS}"
|
|
|
|
log_always "setting NGX_WORKER_AIO_REQUESTS=${_NGX_WORKER_AIO_REQUESTS}"
|
|
|
|
NGX_WORKER_AIO_REQUESTS=${_NGX_WORKER_AIO_REQUESTS}
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
export NGX_WORKER_AIO_REQUESTS
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -n "${NGX_WORKER_RLIMIT_NOFILE:-}" ] ; then
|
|
|
|
nofile_soft=$(ulimit -Sn)
|
|
|
|
nofile_hard=$(ulimit -Hn)
|
|
|
|
|
|
|
|
if [ "${nofile_hard}" = unlimited ] ; then
|
|
|
|
## minor hack (if applicable) :)
|
|
|
|
nofile_hard=$((NGX_WORKER_RLIMIT_NOFILE + 1))
|
|
|
|
fi
|
|
|
|
|
|
|
|
nofile_ok=0
|
|
|
|
while : ; do
|
|
|
|
[ ${nofile_hard} -ge ${NGX_WORKER_RLIMIT_NOFILE} ] || break
|
|
|
|
[ ${nofile_soft} -ge ${NGX_WORKER_RLIMIT_NOFILE} ] || break
|
|
|
|
|
|
|
|
nofile_ok=1
|
|
|
|
break ; done
|
|
|
|
|
|
|
|
if [ ${nofile_ok} = 0 ] ; then
|
|
|
|
log_always "adjusting 'nofile' limits"
|
|
|
|
|
|
|
|
log_always "Limits before:"
|
|
|
|
sed -En '1p;/open files/p' < /proc/$$/limits >&2
|
|
|
|
|
|
|
|
if [ ${nofile_hard} -lt ${NGX_WORKER_RLIMIT_NOFILE} ] ; then
|
|
|
|
ulimit -Hn "${NGX_WORKER_RLIMIT_NOFILE}"
|
|
|
|
nofile_hard=$(ulimit -Hn)
|
|
|
|
fi
|
|
|
|
if [ ${nofile_hard} -lt ${NGX_WORKER_RLIMIT_NOFILE} ] ; then
|
|
|
|
log_always "lowering NGX_WORKER_RLIMIT_NOFILE to ${nofile_hard} due to hard limit"
|
|
|
|
NGX_WORKER_RLIMIT_NOFILE=${nofile_hard}
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ ${nofile_soft} -lt ${NGX_WORKER_RLIMIT_NOFILE} ] ; then
|
|
|
|
ulimit -Sn "${NGX_WORKER_RLIMIT_NOFILE}"
|
|
|
|
fi
|
|
|
|
|
|
|
|
log_always "Limits after:"
|
|
|
|
sed -En '1p;/open files/p' < /proc/$$/limits >&2
|
|
|
|
fi
|
|
|
|
unset nofile_soft nofile_hard nofile_ok
|
|
|
|
|
|
|
|
export NGX_WORKER_RLIMIT_NOFILE
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -z "${NGX_WORKER_RLIMIT_NOFILE:-}" ] ; then
|
|
|
|
nofile_limit=$(ulimit -Hn)
|
|
|
|
nofile_kind="'ulimit:nofile'"
|
|
|
|
else
|
|
|
|
nofile_limit=${NGX_WORKER_RLIMIT_NOFILE}
|
|
|
|
nofile_kind='NGX_WORKER_RLIMIT_NOFILE'
|
|
|
|
fi
|
|
|
|
if [ ${nofile_limit} -lt ${NGX_WORKER_CONNECTIONS} ] ; then
|
|
|
|
log_always "WARNING: ${nofile_kind} is less than NGX_WORKER_CONNECTIONS (${nofile_limit} < ${NGX_WORKER_CONNECTIONS})"
|
|
|
|
else
|
2024-07-26 01:18:59 +03:00
|
|
|
ratio=$(float_div "${nofile_limit}" "${NGX_WORKER_CONNECTIONS}")
|
2024-07-24 22:47:53 +03:00
|
|
|
case "${ratio}" in
|
|
|
|
1 | 1.* )
|
|
|
|
log_always "WARNING: \"${nofile_kind}/NGX_WORKER_CONNECTIONS\" ratio is too low (=${ratio})"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
unset ratio
|
|
|
|
fi
|
|
|
|
unset nofile_limit nofile_kind
|
|
|
|
|
|
|
|
unset _NGX_WORKER_PROCESSES _NGX_WORKER_PRIORITY _NGX_WORKER_RLIMIT_NOFILE _NGX_WORKER_CONNECTIONS _NGX_WORKER_AIO_REQUESTS
|