mirror of
https://github.com/isar/libmdbx.git
synced 2025-06-23 01:42:36 +08:00
mdbx-tests: поддержка опции --numa #
для привязки стохастического теста к NUMA-узлу.
This commit is contained in:
parent
4bce51e660
commit
8f0b783c93
@ -28,6 +28,7 @@ REPORT_DEPTH=no
|
|||||||
REPEAT=11
|
REPEAT=11
|
||||||
ROUNDS=1
|
ROUNDS=1
|
||||||
SMALL=no
|
SMALL=no
|
||||||
|
NUMABIND=
|
||||||
|
|
||||||
while [ -n "$1" ]
|
while [ -n "$1" ]
|
||||||
do
|
do
|
||||||
@ -51,6 +52,7 @@ do
|
|||||||
echo "--db-upto-gb NN --''--''--''--''--''--''--''--''-- NN gigabytes"
|
echo "--db-upto-gb NN --''--''--''--''--''--''--''--''-- NN gigabytes"
|
||||||
echo "--no-geometry-jitter Disable jitter for geometry upper-size"
|
echo "--no-geometry-jitter Disable jitter for geometry upper-size"
|
||||||
echo "--pagesize NN Use specified page size (256 is minimal and used by default)"
|
echo "--pagesize NN Use specified page size (256 is minimal and used by default)"
|
||||||
|
echo "--numa NODE Bind to the specified NUMA node"
|
||||||
echo "--dont-check-ram-size Don't check available RAM"
|
echo "--dont-check-ram-size Don't check available RAM"
|
||||||
echo "--extra Iterate extra modes/flags"
|
echo "--extra Iterate extra modes/flags"
|
||||||
echo "--taillog Dump tail of test log on failure"
|
echo "--taillog Dump tail of test log on failure"
|
||||||
@ -209,6 +211,15 @@ do
|
|||||||
--small)
|
--small)
|
||||||
SMALL=yes
|
SMALL=yes
|
||||||
;;
|
;;
|
||||||
|
--numa)
|
||||||
|
NUMANODE=$2
|
||||||
|
if [[ ! $NUMANODE =~ ^[0-9]+$ ]]; then
|
||||||
|
echo "Invalid value '$NUMANODE' for --numa option, expect an integer of NUMA-node"
|
||||||
|
exit -2
|
||||||
|
fi
|
||||||
|
NUMABIND="numactl --membind ${NUMANODE} --cpunodebind ${NUMANODE}"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
*)
|
*)
|
||||||
echo "Unknown option '$1'"
|
echo "Unknown option '$1'"
|
||||||
exit -2
|
exit -2
|
||||||
@ -504,9 +515,9 @@ function probe {
|
|||||||
else
|
else
|
||||||
exec {LFD}> >(logger)
|
exec {LFD}> >(logger)
|
||||||
fi
|
fi
|
||||||
${MONITOR} ./mdbx_test ${speculum} --random-writemap=no --ignore-dbfull --repeat=${REPEAT} --pathname=${TESTDB_DIR}/long.db --cleanup-after=no --geometry-jitter=${GEOMETRY_JITTER} "$@" $case >&${LFD} \
|
${NUMABIND} ${MONITOR} ./mdbx_test ${speculum} --random-writemap=no --ignore-dbfull --repeat=${REPEAT} --pathname=${TESTDB_DIR}/long.db --cleanup-after=no --geometry-jitter=${GEOMETRY_JITTER} "$@" $case >&${LFD} \
|
||||||
&& ${MONITOR} ./mdbx_chk -q ${TESTDB_DIR}/long.db | tee ${TESTDB_DIR}/long-chk.log \
|
&& ${NUMABIND} ${MONITOR} ./mdbx_chk -q ${TESTDB_DIR}/long.db | tee ${TESTDB_DIR}/long-chk.log \
|
||||||
&& ([ ! -e ${TESTDB_DIR}/long.db-copy ] || ${MONITOR} ./mdbx_chk -q ${TESTDB_DIR}/long.db-copy | tee ${TESTDB_DIR}/long-chk-copy.log) \
|
&& ([ ! -e ${TESTDB_DIR}/long.db-copy ] || ${NUMABIND} ${MONITOR} ./mdbx_chk -q ${TESTDB_DIR}/long.db-copy | tee ${TESTDB_DIR}/long-chk-copy.log) \
|
||||||
|| failed
|
|| failed
|
||||||
if [ ${LFD} -ne 0 ]; then
|
if [ ${LFD} -ne 0 ]; then
|
||||||
echo "@@@ END-OF-LOG/ITERATION" >&${LFD}
|
echo "@@@ END-OF-LOG/ITERATION" >&${LFD}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user