diff --git a/docker/main/ngen/ngen_cal_entrypoint.sh b/docker/main/ngen/ngen_cal_entrypoint.sh index 2483f9855..1a843f27f 100755 --- a/docker/main/ngen/ngen_cal_entrypoint.sh +++ b/docker/main/ngen/ngen_cal_entrypoint.sh @@ -39,6 +39,10 @@ while [ ${#} -gt 0 ]; do declare -x CALIBRATION_CONFIG_BASENAME="${2:?}" shift ;; + --primary-workers) + declare -x PRIMARY_WORKERS="${2:?}" + shift + ;; esac shift done @@ -101,6 +105,10 @@ start_calibration() { return ${NGEN_RETURN} } +# Run make_data_local Python functions to make necessary data local +# Called for every worker, but Python code will make sure only one worker per node makes a call that has effect +py_funcs make_data_local ${WORKER_INDEX:-0} ${PRIMARY_WORKERS:-0} + # We can allow worker index to not be supplied when executing serially if [ "${WORKER_INDEX:-0}" = "0" ]; then if [ "$(whoami)" = "${MPI_USER:?MPI user not defined}" ]; then diff --git a/docker/main/ngen/ngen_entrypoint.sh b/docker/main/ngen/ngen_entrypoint.sh index 0278fd640..0e43f02af 100755 --- a/docker/main/ngen/ngen_entrypoint.sh +++ b/docker/main/ngen/ngen_entrypoint.sh @@ -35,6 +35,10 @@ while [ ${#} -gt 0 ]; do declare -x WORKER_INDEX="${2:?}" shift ;; + --primary-workers) + declare -x PRIMARY_WORKERS="${2:?}" + shift + ;; esac shift done @@ -60,6 +64,10 @@ if [ ! -e /dmod/datasets/linked_job_output ]; then ln -s ${JOB_OUTPUT_WRITE_DIR} /dmod/datasets/linked_job_output fi +# Run make_data_local Python functions to make necessary data local +# Called for every worker, but Python code will make sure only one worker per node makes a call that has effect +py_funcs make_data_local ${WORKER_INDEX:-0} ${PRIMARY_WORKERS:-0} + # We can allow worker index to not be supplied when executing serially if [ "${WORKER_INDEX:-0}" = "0" ]; then if [ "$(whoami)" = "${MPI_USER:?MPI user not defined}" ]; then