Portál AbcLinuxu, 18. listopadu 2025 03:13
function get_freemem() {
# "our" free memory = free RAM + buffers/cache - used swap
# minus "give way" (custom list of simple command names and
# amount of memory they might grow)
reserve=0
progs="`ps -eo comm | tail -n +2`"
for i in $@; do
cmd="`sed 's/=.*$//' <<< "$i"`"
res="`sed 's/^.*=//; s/[^0-9]//g' <<< "$i"`"
[ -z "$res" ] && continue
reserve=$(( $reserve + `grep "$cmd" <<< "$progs" | wc -l` * $res ))
done
f="`free`"
mem="`tail -n 2 <<< "$f" | head -n 1 | sed 's/^.* //'`"
swap="`tail -n 1 <<< "$f" | sed 's/ \+/ /g' | cut -d ' ' -f 3`"
echo $mem - $swap - $reserve | bc
}
function wait_freemem() {
counter=0
max_timeout=36000
timein_counter=0
timein_required=5
mem_needed=1048576
# we reserve additional 512M for each "java" we find in ps
reserves="java=524288"
while [ $counter -lt $max_timeout ]; do
mem="`get_freemem $reserves`"
[ $mem -gt $mem_needed ] && timein_counter=$(( $timein_counter + 1 )) || timein_counter=0
[ $timein_counter -ge $timein_required -a $(( $counter % $timein_required )) == 0 ] && return 0
sleep 1
timeout_counter=$(( $timeout_counter + 1 ))
done
return 1
}
Každopádně i přes tyto opatření pokud přijde hodně dotazů, je schopno se jich kvůli race condition dost pustit najednou (ono asi bych mohl zvednout timein_required na nějakou velkou hodnotu a pak prostě doufat, že to bude stačit, ale to taky prodlouží čekání jediného procesu pokud je stroj nečinný).
Tak bych se rád zeptal, jestli někdo neví o spolehlivé metodě, jak potenciálně velké množství procesů zesynchronizovat tak, aby se v případě dostatku paměti pustily paralelně, ale pokud je paměti míň, tak se většina z nich zablokovala a pouštěli se po jednom (dvou, třech, atd., podle volné paměti)? Ideálně v bashi, ale nebráním se jiným metodám.
Díky!
timeout_counter a counter jedna a ta samá proměnná, jde o mou nepozornost při úpravě
/tmp/muj_program_lock_0 až /tmp/muj_program_lock_X...
Tiskni
Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.