#!/bin/bash export GLOG_v=1 export DEVICE_ID=1 MINDSPORE_INSTALL_PATH=$1 ENV_DEVICE_ID=$DEVICE_ID CURRPATH=$(cd "$(dirname $0)" || exit; pwd) CURRUSER=$(whoami) PROJECT_PATH=${CURRPATH}/../../../ echo "MINDSPORE_INSTALL_PATH:" ${MINDSPORE_INSTALL_PATH} echo "ENV_DEVICE_ID:" ${ENV_DEVICE_ID} echo "CURRPATH:" ${CURRPATH} echo "CURRUSER:" ${CURRUSER} echo "PROJECT_PATH:" ${PROJECT_PATH} export LD_LIBRARY_PATH=${MINDSPORE_INSTALL_PATH}/lib:${LD_LIBRARY_PATH} #export PYTHONPATH=${MINDSPORE_INSTALL_PATH}/:${PYTHONPATH} echo "LD_LIBRARY_PATH: " ${LD_LIBRARY_PATH} echo "PYTHONPATH: " ${PYTHONPATH} echo "-------------show MINDSPORE_INSTALL_PATH----------------" ls -l ${MINDSPORE_INSTALL_PATH} echo "------------------show /usr/lib64/----------------------" ls -l /usr/local/python/python375/lib/ clean_master_pid() { ps aux | grep 'master.py' | grep ${CURRUSER} | grep -v grep if [ $? -eq 0 ] then ps aux | grep 'master.py' | grep ${CURRUSER} | grep -v grep | awk '{print $2}' | xargs kill -15 if [ $? -ne 0 ] then echo "clean master pip failed" fi sleep 6 ps aux | grep 'master.py' | grep ${CURRUSER} | grep -v grep if [ $? -eq 0 ] then ps aux | grep 'master.py' | grep ${CURRUSER} | grep -v grep | awk '{print $2}' | xargs kill -9 echo "### master pid exist, clean master pip failed ###" & exit 1 fi ps aux | grep 'worker.py' | grep ${CURRUSER} | grep -v grep if [ $? -eq 0 ] then ps aux | grep 'worker.py' | grep ${CURRUSER} | grep -v grep | awk '{print $2}' | xargs kill -9 echo "### master pid is killed but worker pid exist ###" & exit 1 fi fi } clean_worker_pid() { ps aux | grep 'worker.py' | grep ${CURRUSER} | grep -v grep if [ $? -eq 0 ] then ps aux | grep 'worker.py' | grep ${CURRUSER} | grep -v grep | awk '{print $2}' | xargs kill -9 if [ $? -eq 0 ] then echo "clean work pid failed" fi fi } prepare_model() { echo "### begin to generate mode for serving test ###" cd export_model python3 add_model.py &> add_model.log echo "### end to generate mode for serving test ###" result=`find . -name tensor_add.mindir | wc -l` if [ ${result} -ne 1 ] then cat add_model.log echo "### generate model for serving test failed ###" && exit 1 clean_master_pid clean_worker_pid cd - fi cd - } start_service() { echo "### start serving service ###" unset http_proxy https_proxy python3 master.py > start_master.log 2>&1 & if [ $? -ne 0 ] then echo "master server failed to start." && exit 1 fi result=`grep -E 'Serving gRPC server start success, listening on 127.0.0.1:5500' start_master.log | wc -l` count=0 while [[ ${result} -ne 1 && ${count} -lt 150 ]] do sleep 1 count=$(($count+1)) result=`grep -E 'Serving gRPC server start success, listening on 127.0.0.1:5500' start_master.log | wc -l` done if [ ${count} -eq 150 ] then clean_master_pid cat service.log echo "start serving service failed!" && exit 1 fi echo "### start serving service end ###" python3 worker.py > start_worker.log 2>&1 & if [ $? -ne 0 ] then echo "worker server failed to start." && exit 1 fi result=`grep -E 'gRPC server start success, listening on 127.0.0.1:6600' start_worker.log | wc -l` count=0 while [[ ${result} -ne 1 && ${count} -lt 150 ]] do sleep 1 count=$(($count+1)) result=`grep -E 'gRPC server start success, listening on 127.0.0.1:6600' start_worker.log | wc -l` done if [ ${count} -eq 150 ] then clean_master_pid clean_worker_pid cat start_worker.log echo "start worker service failed!" && exit 1 fi echo "### start worker service end ###" } pytest_serving() { unset http_proxy https_proxy echo "### client start ###" python3 client_mul_process.py > client_mul_process.log 2>&1 if [ $? -ne 0 ] then clean_master_pid clean_worker_pid cat client_mul_process.log echo "client failed to start." && exit 1 fi echo "### client end ###" } test_add_model() { start_service pytest_serving cat client_mul_process.log clean_master_pid clean_worker_pid } echo "-----serving start-----" rm -rf serving *.log *.mindir *.dat ${CURRPATH}/add ${CURRPATH}/kernel_meta rm -rf add client.py client_mul_process.py export_model master.py worker.py master_with_worker.py cp -r ../../../example/add/* . prepare_model test_add_model