X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/e59273e06c41fa1532ab887f62695a2bd6d0e284..3b470b3778a99c6148f407f25a6ef22bd4bc9a24:/tools/salt-install/installer.sh diff --git a/tools/salt-install/installer.sh b/tools/salt-install/installer.sh index 6fdd0320fe..17890d646e 100755 --- a/tools/salt-install/installer.sh +++ b/tools/salt-install/installer.sh @@ -6,44 +6,54 @@ set -e +declare -A NODES + sync() { - if test $NODE = localhost ; then - # nothing to do - else - 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 [[ ! -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 @@ -53,24 +63,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 @@ -89,12 +99,8 @@ case "$subcmd" in ;; deploy) NODE=$1 - CONFIG_FILE=local.params - if ! test -s $CONFIG_FILE ; then - echo "Must be run from arvados-setup, maybe you need to 'initialize' first?" - fi - source ${CONFIG_FILE} + loadconfig set -x @@ -105,9 +111,30 @@ case "$subcmd" in 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 @@ -115,11 +142,25 @@ case "$subcmd" in sync deploynode fi + + ;; + diagnostics) + loadconfig + + if ! which arvados-client ; then + apt-get install arvados-client + fi + + export ARVADOS_API_HOST="${CLUSTER}.${DOMAIN}" + export ARVADOS_API_TOKEN="$SYSTEM_ROOT_TOKEN" + + arvados-client diagnostics -internal-client ;; *) echo "Arvados installer" echo "" echo "initialize initialize the setup directory for configuration" echo "deploy deploy the configuration from the setup directory" + echo "diagnostics check your install using diagnostics" ;; esac