X-Git-Url: https://git.teslayout.com/public/public/public/?a=blobdiff_plain;f=example%2Fdiameter%2Flauncher%2FDEPLOY.sh;h=7e19fffe2409325badc9ac8605f0700027cf191c;hb=9366377ca75fe1678f32b8e208022dab6163da16;hp=7f53a993281f1b5c61a6820b740af2a9c8e37aab;hpb=b8d9d3d86c425cf545bbee4fa48522157a55c3bd;p=anna.git diff --git a/example/diameter/launcher/DEPLOY.sh b/example/diameter/launcher/DEPLOY.sh index 7f53a99..7e19fff 100755 --- a/example/diameter/launcher/DEPLOY.sh +++ b/example/diameter/launcher/DEPLOY.sh @@ -3,162 +3,240 @@ ############# # VARIABLES # ############# -SETUPS_DIR=../../../source/diameter/stack/setups -MSGDTD=../../../include/anna/diameter/codec/message.dtd -DCTDTD=../../../include/anna/diameter/stack/dictionary.dtd -BASE_PROT=commands_baseProtocol.xml - -# Executables in priority order: -EXEC_installed=/opt/bin/anna/example_diameter_launcher -EXECS=( $EXEC_installed ./release/example_diameter_launcher ./debug/example_diameter_launcher ) +SCR_DIR=`readlink -f $(dirname $0)` +PROJECT_ROOT=$(readlink -f $SCR_DIR/../../..) +SETUPS_DIR=$PROJECT_ROOT/source/diameter/stack/setups +MSGDTD=$PROJECT_ROOT/include/anna/diameter/codec/message.dtd +DCTDTD=$PROJECT_ROOT/include/anna/diameter/stack/dictionary.dtd +SERVICES=$SCR_DIR/resources/services_examples +STACK_EXAMPLES=$SCR_DIR/resources/stack_examples +SRVDTD=$SERVICES/services.dtd +VARIANT= ############# # FUNCTIONS # ############# _exit () { - echo - echo $1 - echo - exit + echo -e "\n$1\n" + exit 1 } +usage () { + echo "Usage: $0 [deployment_type: a|b|f|s] [deployment_path]" + echo + echo " deployment_type:" + echo " a=advanced" + echo " b=basic" + echo " f=function test client" + echo " s=system test client" + echo " deployment_path:" + echo " non-existent path directory." + echo + echo " For example:" + echo " $0 b $HOME/ADML-basicServer" + echo " $0 b $HOME/ADML-MMSbalancer" + echo " $0 f $HOME/ADML-tester" + echo " $0 s $HOME/ADML-stress-client" + echo + exit 0 +} + # $1: deployment type createRunScript () { - # Basic launcher 'run.sh' will be created at deployment configuration: [ "$1" = "b" ] && return - [ "$1" = "a" ] && exe=ADL-launcher - [ "$1" = "f" ] && { exe=ADL-ftclient ; ln -s ADL-launcher $exe ; } + + local other= + [ "$1" = "a" ] && other="--httpServer \`grep -v ^# .httpServer\`" + [ "$1" = "f" ] && ln -s ADML-launcher $EXE + [ "$1" = "s" ] && { other="--disableLogs"; ln -s ADML-launcher $EXE ; } + + echo "Creating 'run.sh' script ..." cat << EOF > run.sh #!/bin/bash cd \`dirname \$0\` -EXE=$exe -STARTED=\`pgrep \$EXE 2>/dev/null\` +EXE=$EXE +STARTED=\`pgrep \$EXE$ 2>/dev/null\` [ \$? -eq 0 ] && { echo "Already started!"; echo "\$STARTED" ; exit 1 ; } ./pre-start.sh -0> launcher.traces -rm -f counters/* +0> launcher.trace +rm -f counters/* test-reports/* # Execution line: -./\$EXE -cntDir counters $(for i in `cat args.txt | grep -v "^#"`; do echo -n "$i "; done)& +export LD_LIBRARY_PATH=\$PWD/dynlibs +./\$EXE --services services.xml --cntDir counters --tmDir test-reports $other & echo \$! > .pid EOF chmod a+x run.sh - rm args.txt -} - -createDictionaryPaths () { - for i in stacks/*commands*xml - do - stacks/dependence.sh $i >/dev/null - stack=`basename $i` - if test "$stack" != "$BASE_PROT" - then - > .dictionary__${stack} - for j in `cat ${i}.dep` - do - echo -n "${j}," >> .dictionary__${stack} - done - echo "stacks/$BASE_PROT,stacks/${stack}" >> .dictionary__${stack} - fi - done - - # Default: - ln -s .dictionary__commands_qosControl.xml .dictionary - - # Remove deps: - rm -f stacks/*.dep } ############# # EXECUTION # ############# -cd `dirname $0` +cd $SCR_DIR echo echo "---------------------------------------" -echo "Anna Diameter Launcher (ADL) deployment" +echo "Anna Diameter Launcher (ADML) deployment" echo "---------------------------------------" +[ "$1" = "--help" -o "$1" = "-h" ] && usage +echo " (--help or -h for more info)" echo echo "Basic checkings ..." -available= -for EXEC in ${EXECS[@]}; do - echo -n "Looking executable at '$EXEC' ... " - [ -x $EXEC ] && { available=yes ; echo "available !" ; break ; } - echo "not found" -done -[ -z "$available" ] && _exit "Anna Diameter Launcher (ADL) is not installed neither linked. See README.md (Install section)." + +# Get variant and main executables: +[ -f $SCR_DIR/release/example_diameter_launcher ] && VARIANT=release +[ -f $SCR_DIR/debug/example_diameter_launcher ] && VARIANT=debug +[ -z "$VARIANT" ] && _exit "Cannot locate neither 'release' nor 'debug' variant !" +echo "Variant: $VARIANT" +ADML_EXEC=$SCR_DIR/$VARIANT/example_diameter_launcher +STACKMGMT_EXEC=$(readlink -f $SCR_DIR/../stackManagement/$VARIANT/example_diameter_stackManagement) + [ ! -d $SETUPS_DIR ] && _exit "Diameter stacks not found ($SETUPS_DIR)." echo -echo "Deploy one of these versions:" -echo -echo " (a)dvanced version: includes burst management script and templates for different scenarios. Automatic configuration during start." -echo " (b)asic version: 4 types of launcher (client, server, balancer, dummy), lightly configured and managed through SIGURS2 method." -echo " (f)unction test client: special client with regexp scheduler script based on splitted traffic logs." -echo -echo "Input option [b]:" -read option -[ "$option" = "" ] && option=b +if [ "$1" = "" ] +then + echo + echo "Deploy one of these versions:" + echo + echo " (a)dvanced version: includes burst management script and templates for different scenarios. Automatic configuration during start." + echo " (b)asic version: 4 types of launcher (client, server, balancer, dummy), lightly configured and managed through SIGURS2 method." + echo " (f)unction test client: special client with regexp scheduler script based on splitted traffic logs. Requires a server to perform the tests." + echo " (s)ystem test client: special client for stress testing. Requires a server/s to perform the tests." + echo + echo "Input option [b]:" + read option + [ "$option" = "" ] && option=b +else + option=$1 +fi + case $option in a) + echo "Advanced deployment" DEPLOYMENTS_DIR=deployments/advanced - DPATH_dflt=$HOME/ADL-advanced + DPATH_dflt=$HOME/ADML-advanced ;; b) + echo "Basic deployment" DEPLOYMENTS_DIR=deployments/basic - DPATH_dflt=$HOME/ADL-basic + DPATH_dflt=$HOME/ADML-basic ;; f) + echo "FT deployment" DEPLOYMENTS_DIR=deployments/ft-client - DPATH_dflt=$HOME/ADL-ft-client + DPATH_dflt=$HOME/ADML-ft-client + ;; + + s) + echo "ST deployment" + DEPLOYMENTS_DIR=deployments/st-client + DPATH_dflt=$HOME/ADML-st-client ;; *) - _exit "Unknown option !!" + _exit "Invalid deployment type '$option' !!" ;; esac echo -echo "Input deployment path [$DPATH_dflt]:" -read DPATH -[ "$DPATH" = "" ] && DPATH=$DPATH_dflt -[ -d $DPATH ] && _exit "The path '$DPATH' already exists. Remove it before continue..." +if [ "$2" = "" ] +then + echo "Input deployment path [$DPATH_dflt]:" + read DPATH + [ "$DPATH" = "" ] && DPATH=$DPATH_dflt +else + DPATH=$2 +fi + +[ -d $DPATH ] && _exit "The installation path '$DPATH' must not exists." +EXE=`basename $DPATH` -echo "Copying ..." +echo "Copying to '$DPATH' ..." mkdir -p $DPATH mkdir -p $DPATH/stacks mkdir -p $DPATH/DTDs mkdir -p $DPATH/counters -mkdir -p $DPATH/resources -if [ "$EXEC" = "$EXEC_installed" ] -then - ln -s $EXEC_installed $DPATH/ADL-launcher -else - cp $EXEC $DPATH/ADL-launcher -fi +mkdir -p $DPATH/test-reports + +# Dynamic libs: +mkdir -p $DPATH/dynlibs +DYNLIBS=( $(find $PROJECT_ROOT -name "*.so" | grep -w $VARIANT) ) + +for dynlib in ${DYNLIBS[@]} +do + dynlib_bn=$(basename $dynlib) + if [ "$dynlib_bn" != "libanna_dynamicLauncherProcedure.so" ] + then + cp $dynlib $DPATH/dynlibs + else + ########## ADML Dynamic libs system ########## + # Create structure from $PROJECT_ROOT/dynamic/launcher + suffix_path=$(echo $dynlib | awk -F"$PROJECT_ROOT/dynamic/launcher/" '{ print $2 }') + target=$(dirname $DPATH/dynlibs/$(dirname $suffix_path)) + mkdir -p $target + cp $dynlib $target + + # Additional resources + dynlib_dn=$(dirname $dynlib) + dynlib_dn_dn=$(dirname $dynlib_dn) + cp $dynlib_dn_dn/*.xml $target 2>/dev/null + cp $dynlib_dn_dn/dynamic.suffix $target 2>/dev/null + cp -r $dynlib_dn_dn/services $target 2>/dev/null + fi +done + +# ADML dynamic libs selection script: +cp $SCR_DIR/resources/scripts/select_dynlib.sh $DPATH/dynlibs/select.sh + +# Default dynamic library: +cd $DPATH/dynlibs +ln -s default/libanna_dynamicLauncherProcedure.so +cd - >/dev/null + +# Basic setup: +[ "$option" = "b" ] && mkdir -p $DPATH/services + +# Copy executables: +cp $ADML_EXEC $DPATH/ADML-launcher +[ ! -f $DPATH/stacks/stack-mgmt ] && cp $STACKMGMT_EXEC $DPATH/stacks/stack-mgmt + +# Copy resources: cp -rL $DEPLOYMENTS_DIR/* $DPATH -cp resources/* $DPATH/resources cp $SETUPS_DIR/*xml $DPATH/stacks cp $SETUPS_DIR/*sh $DPATH/stacks cp $SETUPS_DIR/readme.txt $DPATH/stacks +mkdir $DPATH/stacks/other_examples +cp $STACK_EXAMPLES/* $DPATH/stacks/other_examples cp $MSGDTD $DPATH/DTDs cp $DCTDTD $DPATH/DTDs +cp $SRVDTD $DPATH/DTDs +[ "$option" = "b" ] && cp $SERVICES/* $DPATH/services echo "Preparing ..." cd $DPATH createRunScript $option -createDictionaryPaths +stacks/makeAutonomous.sh commands_qosControl.xml stacks/stack-mgmt >/dev/null +ln -s stacks/autonomous.commands_qosControl.xml dictionary.xml cd - >/dev/null +if [ "$option" = "s" ] +then + cd $DPATH + ln -s services_example services + mv run.sh .run-one.sh + mv run_all.sh run.sh + mv operation.sh .operation-one.sh + mv operation_all.sh operation.sh + rm dictionary.xml + cd - >/dev/null +fi + # Help: +echo "Done !" +echo "(see README at '$DPATH')" echo -echo "Go to '$DPATH' and see README file" -echo -echo "Done!" -echo -echo -