#!/bin/bash
WORKER_NUM=8
LOCAL_WORKER=8
MASTER_ADDR="127.0.0.1"
MASTER_PORT=8118
NODE_RANK=0
LOG_DIR="output/msrun_log"
JOIN="False"
CLUSTER_TIME_OUT=7200
MF_SCRIPTS_ROOT=$(realpath "$(dirname "$0")")
export PYTHONPATH=$MF_SCRIPTS_ROOT/../:$PYTHONPATH
if [ -z "${MF_LOG_SUFFIX+x}" ] || [ "$MF_LOG_SUFFIX" == "" ]
then
MF_LOG_SUFFIX=$MF_LOG_SUFFIX
else
MF_LOG_SUFFIX=_$MF_LOG_SUFFIX
fi
WORKSPACE_PATH=$(pwd)
if [ -z "${LOG_MF_PATH+x}" ] || [ "$LOG_MF_PATH" == "" ]
then
export LOG_MF_PATH=$WORKSPACE_PATH/output/log$MF_LOG_SUFFIX
fi
if [ -z "${PLOG_REDIRECT_TO_OUTPUT+x}" ] || [ $PLOG_REDIRECT_TO_OUTPUT == False ]
then
echo "No change the path of plog, the path of plog is /root/ascend"
else
export ASCEND_PROCESS_LOG_PATH=$WORKSPACE_PATH/output/plog$MF_LOG_SUFFIX
echo "PLOG_REDIRECT_TO_OUTPUT=$PLOG_REDIRECT_TO_OUTPUT, set the path of plog to $ASCEND_PROCESS_LOG_PATH"
fi
if [ $# != 1 ] && [ $# != 2 ] && [ $# != 6 ] && [ $# != 9 ]
then
echo "Usage Help: bash msrun_launcher.sh [EXECUTE_ORDER] For Default 8 Devices In Single Machine"
echo "Usage Help: bash msrun_launcher.sh [EXECUTE_ORDER] [WORKER_NUM] For Quick Start On Multiple Devices In Single Machine"
echo "Usage Help: bash msrun_launcher.sh [EXECUTE_ORDER] [WORKER_NUM] [MASTER_PORT] [LOG_DIR] [JOIN] [CLUSTER_TIME_OUT] For Multiple Devices In Single Machine"
echo "Usage Help: bash msrun_launcher.sh [EXECUTE_ORDER] [WORKER_NUM] [LOCAL_WORKER] [MASTER_ADDR] [MASTER_PORT] [NODE_RANK] [LOG_DIR] [JOIN] [CLUSTER_TIME_OUT] For Multiple Devices In Multiple Machines"
exit 1
fi
if [ $# == 1 ]
then
echo "No parameter is entered. Notice that the program will run on default 8 cards. "
SINGLE_NODE=true
else
WORKER_NUM=$2
fi
if [[ ! $WORKER_NUM =~ ^[0-9]+$ ]]; then
echo "error: worker_num=$WORKER_NUM is not a number"
exit 1
fi
if [ $# == 2 ]
then
LOCAL_WORKER=$WORKER_NUM
SINGLE_NODE=true
fi
if [ $# == 6 ]
then
LOCAL_WORKER=$WORKER_NUM
MASTER_PORT=$3
LOG_DIR=$4
JOIN=$5
CLUSTER_TIME_OUT=$6
SINGLE_NODE=true
fi
if [ $# == 9 ]
then
LOCAL_WORKER=$3
MASTER_ADDR=$4
MASTER_PORT=$5
NODE_RANK=$6
LOG_DIR=$7
JOIN=$8
CLUSTER_TIME_OUT=$9
if [ $WORKER_NUM == $LOCAL_WORKER ]
then
echo "worker_num is equal to local_worker, Notice that task will run on single node."
SINGLE_NODE=true
else
echo "worker_num=$WORKER_NUM, local_worker=$LOCAL_WORKER, \
Please run this script on other nodes with different node_rank."
SINGLE_NODE=false
fi
fi
LOG_DIR=${LOG_DIR}${MF_LOG_SUFFIX}
if [ $SINGLE_NODE == true ]
then
MSRUN_CMD="msrun --bind_core=True \
--worker_num=$WORKER_NUM \
--local_worker_num=$LOCAL_WORKER \
--master_port=$MASTER_PORT \
--log_dir=$LOG_DIR \
--join=$JOIN \
--cluster_time_out=$CLUSTER_TIME_OUT"
else
MSRUN_CMD="msrun --bind_core=True \
--worker_num=$WORKER_NUM \
--local_worker_num=$LOCAL_WORKER \
--master_addr=$MASTER_ADDR \
--master_port=$MASTER_PORT \
--node_rank=$NODE_RANK \
--log_dir=$LOG_DIR \
--join=$JOIN \
--cluster_time_out=$CLUSTER_TIME_OUT"
fi
if [ $WORKER_NUM == 1 ]
then
echo "You should use python instead of using msrun while running a single rank"
exit 0
fi
EXECUTE_ORDER="$MSRUN_CMD $1"
ulimit -u unlimited
echo "Running Command: $EXECUTE_ORDER"
echo "Please check log files in ${WORKSPACE_PATH}/${LOG_DIR}"
eval $EXECUTE_ORDER