X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/093ec98e4a065acfc537ea22c08c337c115fe273..2efd88cf64130bb0ebb0549d30053b85baaae2f9:/tools/salt-install/installer.sh diff --git a/tools/salt-install/installer.sh b/tools/salt-install/installer.sh index 534ee629c7..79c85c89c1 100755 --- a/tools/salt-install/installer.sh +++ b/tools/salt-install/installer.sh @@ -9,50 +9,52 @@ set -e declare -A NODES sync() { - if test "$NODE" != localhost ; then - if ! ssh $NODE test -d arvados-setup ; then - ssh $NODE git init --bare arvados-setup.git - if ! git remote add $NODE $DEPLOY_USER@$NODE:arvados-setup.git ; then - git remote set-url $NODE $DEPLOY_USER@$NODE:arvados-setup.git + if [[ "$NODE" != localhost ]] ; then + if ! ssh $NODE test -d ${GITTARGET}.git ; then + ssh $NODE git init --bare ${GITTARGET}.git + if ! git remote add $NODE $DEPLOY_USER@$NODE:${GITTARGET}.git ; then + git remote set-url $NODE $DEPLOY_USER@$NODE:${GITTARGET}.git fi git push $NODE $BRANCH - ssh $NODE git clone arvados-setup.git arvados-setup + ssh $NODE git clone ${GITTARGET}.git ${GITTARGET} fi git push $NODE $BRANCH - ssh $NODE git -C arvados-setup checkout $BRANCH - ssh $NODE git -C arvados-setup pull + ssh $NODE git -C ${GITTARGET} checkout $BRANCH + ssh $NODE git -C ${GITTARGET} pull fi } deploynode() { - if test -z "${NODES[$NODE]}" ; then + if [[ -z "${NODES[$NODE]}" ]] ; then echo "No roles declared for '$NODE' in local.params" exit 1 fi - if test $NODE = localhost ; then + if [[ "$NODE" = localhost ]] ; then sudo ./provision.sh --config local.params --roles ${NODES[$NODE]} else - ssh $DEPLOY_USER@$NODE "cd arvados-setup && sudo ./provision.sh --config local.params --roles ${NODES[$NODE]}" + ssh $DEPLOY_USER@$NODE "cd ${GITTARGET} && sudo ./provision.sh --config local.params --roles ${NODES[$NODE]}" fi } loadconfig() { CONFIG_FILE=local.params - if ! test -s $CONFIG_FILE ; then - echo "Must be run from arvados-setup, maybe you need to 'initialize' first?" + CONFIG_DIR=local_config_dir + if [[ ! -s $CONFIG_FILE ]] ; then + echo "Must be run from initialized setup dir, maybe you need to 'initialize' first?" fi source ${CONFIG_FILE} + GITTARGET=arvados-deploy-config-${CLUSTER} } subcmd="$1" -if test -n "$subcmd" ; then +if [[ -n "$subcmd" ]] ; then shift fi case "$subcmd" in initialize) - if ! test -f provision.sh ; then + if [[ ! -f provision.sh ]] ; then echo "Must be run from arvados/tools/salt-install" exit fi @@ -62,24 +64,24 @@ case "$subcmd" in SLS=$3 err= - if test -z "$PARAMS" -o ! -f local.params.example.$PARAMS ; then + if [[ -z "$PARAMS" || ! -f local.params.example.$PARAMS ]] ; then echo "Not found: local.params.example.$PARAMS" echo "Expected one of multiple_hosts, single_host_multiple_hostnames, single_host_single_hostname" err=1 fi - if test -z "$SLS" -o ! -d config_examples/$SLS ; then + if [[ -z "$SLS" || ! -d config_examples/$SLS ]] ; then echo "Not found: config_examples/$SLS" echo "Expected one of multi_host/aws, single_host/multiple_hostnames, single_host/single_hostname" err=1 fi - if test -z "$SETUPDIR" -o -z "$PARAMS" -o -z "$SLS" ; then + if [[ -z "$SETUPDIR" || -z "$PARAMS" || -z "$SLS" ]]; then echo "installer.sh " err=1 fi - if test -n "$err" ; then + if [[ -n "$err" ]] ; then exit 1 fi @@ -101,18 +103,45 @@ case "$subcmd" in loadconfig - set -x + if grep -rni 'fixme' ${CONFIG_FILE} ${CONFIG_DIR} ; then + echo + echo "Some parameters still need to be updated. Please fix them and then re-run deploy." + exit 1 + fi BRANCH=$(git branch --show-current) + set -x + git add -A if ! git diff --cached --exit-code ; then git commit -m"prepare for deploy" fi - if test -z "$NODE"; then + if [[ -z "$NODE" ]]; then + for NODE in "${!NODES[@]}" + do + # Do 'database' role first, + if [[ "${NODES[$NODE]}" =~ database ]] ; then + sync + deploynode + unset NODES[$NODE] + fi + done + + for NODE in "${!NODES[@]}" + do + # then 'api' or 'controller' roles + if [[ "${NODES[$NODE]}" =~ (api|controller) ]] ; then + sync + deploynode + unset NODES[$NODE] + fi + done + for NODE in "${!NODES[@]}" do + # Everything else sync deploynode done