#!/bin/bash # Exit immediately if anything goes wrong, instead of making things worse. set -e source $REPO_ROOT/bootstrap/shared/shared_functions.sh global REQUIRED_VARS := '( 'BOOTSTRAP_CHEF_DO_CONVERGE BOOTSTRAP_CHEF_ENV BCPC_HYPERVISOR_DOMAIN FILECACHE_MOUNT_POINT REPO_MOUNT_POINT REPO_ROOT ) check_for_envvars $(REQUIRED_VARS[@]) # This script does a lot of stuff: # - installs Chef Server on the bootstrap node # - installs Chef client on all nodes # It would be more efficient as something executed in one shot on each node, but # doing it this way makes it easy to orchestrate operations between nodes. In some cases, # commands can be &&'d together to avoid SSHing repeatedly to a node (SSH setup/teardown # can add a fair amount of time to this script). cd $REPO_ROOT/bootstrap/vagrant_scripts # use Chef Server embedded knife instead of the one in /usr/bin global KNIFE := '/opt/opscode/embedded/bin/knife' # install and configure Chef Server 12 and Chef 12 client on the bootstrap node # move nginx insecure to 4000/TCP is so that Cobbler can run on the regular 80/TCP if [[ -n "$CHEF_SERVER_DEB" ]] { global debpath := ""$FILECACHE_MOUNT_POINT/$CHEF_SERVER_DEB"" global CHEF_SERVER_INSTALL_CMD := ""sudo dpkg -i $debpath"" } else { global CHEF_SERVER_INSTALL_CMD := ""sudo dpkg -i \$(find $FILECACHE_MOUNT_POINT/ -name chef-server\*deb -not -name \*downloaded | tail -1)"" } if [[ -n "$CHEF_CLIENT_DEB" ]] { global debpath := ""$FILECACHE_MOUNT_POINT/$CHEF_CLIENT_DEB"" global CHEF_CLIENT_INSTALL_CMD := ""sudo dpkg -i $debpath"" } else { global CHEF_CLIENT_INSTALL_CMD := ""sudo dpkg -i \$(find $FILECACHE_MOUNT_POINT/ -name chef_\*deb -not -name \*downloaded | tail -1)"" } unset debpath do_on_node vm-bootstrap "$CHEF_SERVER_INSTALL_CMD \ && sudo sh -c \"echo nginx[\'non_ssl_port\'] = 4000 > /etc/opscode/chef-server.rb\" \ && sudo chef-server-ctl reconfigure \ && sudo chef-server-ctl user-create admin admin admin admin@localhost.com welcome --filename /etc/opscode/admin.pem \ && sudo chef-server-ctl org-create bcpc BCPC --association admin --filename /etc/opscode/bcpc-validator.pem \ && sudo chmod 0644 /etc/opscode/admin.pem /etc/opscode/bcpc-validator.pem \ && $CHEF_CLIENT_INSTALL_CMD" # configure knife on the bootstrap node and perform a knife bootstrap to create the bootstrap node in Chef do_on_node vm-bootstrap "mkdir -p \$HOME/.chef && echo -e \"chef_server_url 'https://bcpc-vm-bootstrap.$BCPC_HYPERVISOR_DOMAIN/organizations/bcpc'\\\nvalidation_client_name 'bcpc-validator'\\\nvalidation_key '/etc/opscode/bcpc-validator.pem'\\\nnode_name 'admin'\\\nclient_key '/etc/opscode/admin.pem'\\\nknife['editor'] = 'vim'\\\ncookbook_path [ \\\"#{ENV['HOME']}/chef-bcpc/cookbooks\\\" ]\" > \$HOME/.chef/knife.rb \ && $KNIFE ssl fetch \ && $KNIFE bootstrap -x vagrant -P vagrant --sudo 10.0.100.3" # Initialize VM lists global vms := '"vm1 vm2 vm3'" if test $MONITORING_NODES -gt 0 { global i := '1' while [ $i -le $MONITORING_NODES ] { global mon_vm := ""vm$[expr 3 + $i]"" global mon_vms := ""$mon_vms $mon_vm"" global i := $[expr $i + 1] } } # install the knife-acl plugin into embedded knife, rsync the Chef repository into the non-root user # (vagrant)'s home directory, and add the dependency cookbooks from the file cache do_on_node vm-bootstrap "sudo /opt/opscode/embedded/bin/gem install $FILECACHE_MOUNT_POINT/knife-acl-1.0.2.gem \ && rsync -a $REPO_MOUNT_POINT/* \$HOME/chef-bcpc \ && cp $FILECACHE_MOUNT_POINT/cookbooks/*.tar.gz \$HOME/chef-bcpc/cookbooks \ && cd \$HOME/chef-bcpc/cookbooks && ls -1 *.tar.gz | xargs -I% tar xvzf %" # build binaries before uploading the bcpc cookbook # (this step will change later but using the existing build_bins script for now) do_on_node vm-bootstrap "sudo apt-get update \ && cd \$HOME/chef-bcpc \ && sudo bash -c 'export FILECACHE_MOUNT_POINT=$FILECACHE_MOUNT_POINT \ && source \$HOME/proxy_config.sh && bootstrap/shared/shared_build_bins.sh'" # upload all cookbooks, roles and our chosen environment to the Chef server # (cookbook upload uses the cookbook_path set when configuring knife on the bootstrap node) do_on_node vm-bootstrap "$KNIFE cookbook upload -a \ && cd \$HOME/chef-bcpc/roles && $KNIFE role from file *.json \ && cd \$HOME/chef-bcpc/environments && $KNIFE environment from file $BOOTSTRAP_CHEF_ENV.json" # install and bootstrap Chef on cluster nodes global i := '1' for vm in [$vms $mon_vms] { # Try to install a specific version, or just the latest if [[ -z "$CHEF_CLIENT_DEB" ]] { echo "Installing latest chef-client found in $vm:$FILECACHE_MOUNT_POINT" } do_on_node $vm $CHEF_CLIENT_INSTALL_CMD do_on_node vm-bootstrap "$KNIFE bootstrap -x vagrant -P vagrant --sudo 10.0.100.1$(i)" global i := $[expr $i + 1] } # augment the previously configured nodes with our newly uploaded environments and roles global ENVIRONMENT_SET := ''"" for vm in [vm-bootstrap $vms $mon_vms] { global ENVIRONMENT_SET := ""$ENVIRONMENT_SET $KNIFE node environment set bcpc-$vm.$BCPC_HYPERVISOR_DOMAIN $BOOTSTRAP_CHEF_ENV && "" } global ENVIRONMENT_SET := ""$ENVIRONMENT_SET :"" do_on_node vm-bootstrap $ENVIRONMENT_SET do_on_node vm-bootstrap "$KNIFE node run_list set bcpc-vm-bootstrap.$BCPC_HYPERVISOR_DOMAIN 'role[BCPC-Hardware-Virtual],role[BCPC-Bootstrap]' \ && $KNIFE node run_list set bcpc-vm1.$BCPC_HYPERVISOR_DOMAIN 'role[BCPC-Hardware-Virtual],role[BCPC-Headnode]' \ && $KNIFE node run_list set bcpc-vm2.$BCPC_HYPERVISOR_DOMAIN 'role[BCPC-Hardware-Virtual],role[BCPC-Worknode]' \ && $KNIFE node run_list set bcpc-vm3.$BCPC_HYPERVISOR_DOMAIN 'role[BCPC-Hardware-Virtual],role[BCPC-EphemeralWorknode]'" # set bootstrap, vm1 and mon vms (if any) as admins so that they can write into the data bag global ADMIN_SET := '"true && '" for vm in [vm-bootstrap vm1 $mon_vms] { global ADMIN_SET := ""$ADMIN_SET $KNIFE group add client bcpc-$vm.$BCPC_HYPERVISOR_DOMAIN admins && "" } global ADMIN_SET := ""$ADMIN_SET :"" do_on_node vm-bootstrap $ADMIN_SET # Clustered monitoring setup (>1 mon VM) requires completely initialized node attributes for chef to run # on each node successfully. If we are not converging automatically, set run_list (for mon VMs) and exit. # Otherwise, each mon VM needs to complete chef run first before setting the next node's run_list. if [[ $BOOTSTRAP_CHEF_DO_CONVERGE -eq 0 ]] { for vm in [$mon_vms] { do_on_node vm-bootstrap "$KNIFE node run_list set bcpc-$vm.$BCPC_HYPERVISOR_DOMAIN 'role[BCPC-Monitoring]'" } echo "BOOTSTRAP_CHEF_DO_CONVERGE is set to 0, skipping automatic convergence." exit 0 } else { # run Chef on each node do_on_node vm-bootstrap "sudo chef-client" for vm in [$vms] { do_on_node $vm "sudo chef-client" } # run on head node one last time to update HAProxy with work node IPs do_on_node vm1 "sudo chef-client" # HUP OpenStack services on each node to ensure everything's in a working state for vm in [$vms] { do_on_node $vm "sudo hup_openstack || true" } # Run chef on each mon VM before assigning next node for monitoring. for vm in [$mon_vms] { do_on_node vm-bootstrap "$KNIFE node run_list set bcpc-$vm.$BCPC_HYPERVISOR_DOMAIN 'role[BCPC-Monitoring]'" do_on_node $vm "sudo chef-client" } # Run chef on each mon VM except the last node to update cluster components for vm in [$[echo $mon_vms | awk '{$NF=""}1]] { do_on_node $vm "sudo chef-client" } } (CommandList children: [ (C {(set)} {(-e)}) (C {(.)} {($ VSub_Name "$REPO_ROOT") (/bootstrap/shared/shared_functions.sh)}) (Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (LhsName name:REQUIRED_VARS) op: Equal rhs: { (ArrayLiteralPart words: [ {(BOOTSTRAP_CHEF_DO_CONVERGE)} {(BOOTSTRAP_CHEF_ENV)} {(BCPC_HYPERVISOR_DOMAIN)} {(FILECACHE_MOUNT_POINT)} {(REPO_MOUNT_POINT)} {(REPO_ROOT)} ] ) } spids: [17] ) ] spids: [17] ) (C {(check_for_envvars)} { (BracedVarSub token: bracket_op: (WholeArray op_id:Lit_At) spids: [36 41] ) } ) (C {(cd)} {($ VSub_Name "$REPO_ROOT") (/bootstrap/vagrant_scripts)}) (Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (LhsName name:KNIFE) op: Equal rhs: {(/opt/opscode/embedded/bin/knife)} spids: [76] ) ] spids: [76] ) (If arms: [ (if_arm cond: [ (Sentence child: (DBracket expr: (BoolUnary op_id:BoolUnary_n child:{(DQ ($ VSub_Name "$CHEF_SERVER_DEB"))}) ) terminator: ) ] action: [ (Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (LhsName name:debpath) op: Equal rhs: { (DQ ($ VSub_Name "$FILECACHE_MOUNT_POINT") (/) ($ VSub_Name "$CHEF_SERVER_DEB")) } spids: [102] ) ] spids: [102] ) (Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (LhsName name:CHEF_SERVER_INSTALL_CMD) op: Equal rhs: {(DQ ("sudo dpkg -i ") ($ VSub_Name "$debpath"))} spids: [110] ) ] spids: [110] ) ] spids: [-1 99] ) ] else_action: [ (Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (LhsName name:CHEF_SERVER_INSTALL_CMD) op: Equal rhs: { (DQ ("sudo dpkg -i ") (EscapedLiteralPart token:) ("(find ") ($ VSub_Name "$FILECACHE_MOUNT_POINT") ("/ -name chef-server") (EscapedLiteralPart token:) ("deb -not -name ") (EscapedLiteralPart token:) ("downloaded | tail -1)") ) } spids: [119] ) ] spids: [119] ) ] spids: [116 132] ) (If arms: [ (if_arm cond: [ (Sentence child: (DBracket expr: (BoolUnary op_id:BoolUnary_n child:{(DQ ($ VSub_Name "$CHEF_CLIENT_DEB"))}) ) terminator: ) ] action: [ (Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (LhsName name:debpath) op: Equal rhs: { (DQ ($ VSub_Name "$FILECACHE_MOUNT_POINT") (/) ($ VSub_Name "$CHEF_CLIENT_DEB")) } spids: [150] ) ] spids: [150] ) (Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (LhsName name:CHEF_CLIENT_INSTALL_CMD) op: Equal rhs: {(DQ ("sudo dpkg -i ") ($ VSub_Name "$debpath"))} spids: [158] ) ] spids: [158] ) ] spids: [-1 147] ) ] else_action: [ (Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (LhsName name:CHEF_CLIENT_INSTALL_CMD) op: Equal rhs: { (DQ ("sudo dpkg -i ") (EscapedLiteralPart token:) ("(find ") ($ VSub_Name "$FILECACHE_MOUNT_POINT") ("/ -name chef_") (EscapedLiteralPart token:) ("deb -not -name ") (EscapedLiteralPart token:) ("downloaded | tail -1)") ) } spids: [167] ) ] spids: [167] ) ] spids: [164 180] ) (C {(unset)} {(debpath)}) (C {(do_on_node)} {(vm-bootstrap)} { (DQ ($ VSub_Name "$CHEF_SERVER_INSTALL_CMD") (" ") (" && sudo sh -c ") (EscapedLiteralPart token:) ("echo nginx[") (EscapedLiteralPart token:) (non_ssl_port) (EscapedLiteralPart token:) ("] = 4000 > /etc/opscode/chef-server.rb") (EscapedLiteralPart token:) (" ") (" && sudo chef-server-ctl reconfigure ") ( " && sudo chef-server-ctl user-create admin admin admin admin@localhost.com welcome --filename /etc/opscode/admin.pem " ) ( " && sudo chef-server-ctl org-create bcpc BCPC --association admin --filename /etc/opscode/bcpc-validator.pem " ) (" && sudo chmod 0644 /etc/opscode/admin.pem /etc/opscode/bcpc-validator.pem ") (" && ") ($ VSub_Name "$CHEF_CLIENT_INSTALL_CMD") ) } ) (C {(do_on_node)} {(vm-bootstrap)} { (DQ ("mkdir -p ") (EscapedLiteralPart token:) ("HOME/.chef && echo -e ") (EscapedLiteralPart token:) ("chef_server_url 'https://bcpc-vm-bootstrap.") ($ VSub_Name "$BCPC_HYPERVISOR_DOMAIN") ("/organizations/bcpc'") (EscapedLiteralPart token:) (EscapedLiteralPart token:) ("validation_client_name 'bcpc-validator'") (EscapedLiteralPart token:) (EscapedLiteralPart token:) ("validation_key '/etc/opscode/bcpc-validator.pem'") (EscapedLiteralPart token:) (EscapedLiteralPart token:) ("node_name 'admin'") (EscapedLiteralPart token:) (EscapedLiteralPart token:) ("client_key '/etc/opscode/admin.pem'") (EscapedLiteralPart token:) (EscapedLiteralPart token:) ("knife['editor'] = 'vim'") (EscapedLiteralPart token:) (EscapedLiteralPart token:) ("cookbook_path [ ") (EscapedLiteralPart token:) (EscapedLiteralPart token:) ("#{ENV['HOME']}/chef-bcpc/cookbooks") (EscapedLiteralPart token:) (EscapedLiteralPart token:) (" ]") (EscapedLiteralPart token:) (" > ") (EscapedLiteralPart token:) ("HOME/.chef/knife.rb ") (" && ") ($ VSub_Name "$KNIFE") (" ssl fetch ") (" && ") ($ VSub_Name "$KNIFE") (" bootstrap -x vagrant -P vagrant --sudo 10.0.100.3") ) } ) (Assignment keyword: Assign_None pairs: [(assign_pair lhs:(LhsName name:vms) op:Equal rhs:{(DQ ("vm1 vm2 vm3"))} spids:[274])] spids: [274] ) (If arms: [ (if_arm cond: [ (Sentence child: (C {(Lit_Other "[")} {($ VSub_Name "$MONITORING_NODES")} {(-gt)} {(0)} {(Lit_Other "]")}) terminator: ) ] action: [ (Assignment keyword: Assign_None pairs: [(assign_pair lhs:(LhsName name:i) op:Equal rhs:{(1)} spids:[295])] spids: [295] ) (While cond: [ (Sentence child: (C {(Lit_Other "[")} {($ VSub_Name "$i")} {(-le)} {($ VSub_Name "$MONITORING_NODES")} {(Lit_Other "]")} ) terminator: ) ] body: (DoGroup children: [ (Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (LhsName name:mon_vm) op: Equal rhs: { (DQ (vm) (CommandSubPart command_list: (CommandList children: [ (C {(expr)} {(3)} {(Lit_Other "+")} {($ VSub_Name "$i")}) ] ) left_token: spids: [318 326] ) ) } spids: [315] ) ] spids: [315] ) (Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (LhsName name:mon_vms) op: Equal rhs: {(DQ ($ VSub_Name "$mon_vms") (" ") ($ VSub_Name "$mon_vm"))} spids: [330] ) ] spids: [330] ) (Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (LhsName name:i) op: Equal rhs: { (CommandSubPart command_list: (CommandList children: [ (C {(expr)} {($ VSub_Name "$i")} {(Lit_Other "+")} {(1)}) ] ) left_token: spids: [339 347] ) } spids: [338] ) ] spids: [338] ) ] spids: [312 350] ) ) ] spids: [-1 292] ) ] spids: [-1 352] ) (C {(do_on_node)} {(vm-bootstrap)} { (DQ ("sudo /opt/opscode/embedded/bin/gem install ") ($ VSub_Name "$FILECACHE_MOUNT_POINT") ("/knife-acl-1.0.2.gem ") (" && rsync -a ") ($ VSub_Name "$REPO_MOUNT_POINT") ("/* ") (EscapedLiteralPart token:) ("HOME/chef-bcpc ") (" && cp ") ($ VSub_Name "$FILECACHE_MOUNT_POINT") ("/cookbooks/*.tar.gz ") (EscapedLiteralPart token:) ("HOME/chef-bcpc/cookbooks ") (" && cd ") (EscapedLiteralPart token:) ("HOME/chef-bcpc/cookbooks && ls -1 *.tar.gz | xargs -I% tar xvzf %") ) } ) (C {(do_on_node)} {(vm-bootstrap)} { (DQ ("sudo apt-get update ") (" && cd ") (EscapedLiteralPart token:) ("HOME/chef-bcpc ") (" && sudo bash -c 'export FILECACHE_MOUNT_POINT=") ($ VSub_Name "$FILECACHE_MOUNT_POINT") (" ") (" && source ") (EscapedLiteralPart token:) ("HOME/proxy_config.sh && bootstrap/shared/shared_build_bins.sh'") ) } ) (C {(do_on_node)} {(vm-bootstrap)} { (DQ ($ VSub_Name "$KNIFE") (" cookbook upload -a ") (" && cd ") (EscapedLiteralPart token:) ("HOME/chef-bcpc/roles && ") ($ VSub_Name "$KNIFE") (" role from file *.json ") (" && cd ") (EscapedLiteralPart token:) ("HOME/chef-bcpc/environments && ") ($ VSub_Name "$KNIFE") (" environment from file ") ($ VSub_Name "$BOOTSTRAP_CHEF_ENV") (.json) ) } ) (Assignment keyword: Assign_None pairs: [(assign_pair lhs:(LhsName name:i) op:Equal rhs:{(1)} spids:[448])] spids: [448] ) (ForEach iter_name: vm iter_words: [{($ VSub_Name "$vms")} {($ VSub_Name "$mon_vms")}] do_arg_iter: False body: (DoGroup children: [ (If arms: [ (if_arm cond: [ (Sentence child: (DBracket expr: (BoolUnary op_id: BoolUnary_z child: {(DQ ($ VSub_Name "$CHEF_CLIENT_DEB"))} ) ) terminator: ) ] action: [ (C {(echo)} { (DQ ("Installing latest chef-client found in ") ($ VSub_Name "$vm") (":") ($ VSub_Name "$FILECACHE_MOUNT_POINT") ) } ) ] spids: [-1 482] ) ] spids: [-1 495] ) (C {(do_on_node)} {($ VSub_Name "$vm")} {(DQ ($ VSub_Name "$CHEF_CLIENT_INSTALL_CMD"))}) (C {(do_on_node)} {(vm-bootstrap)} { (DQ ($ VSub_Name "$KNIFE") (" bootstrap -x vagrant -P vagrant --sudo 10.0.100.1") (${ VSub_Name i) ) } ) (Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (LhsName name:i) op: Equal rhs: { (CommandSubPart command_list: (CommandList children: [(C {(expr)} {($ VSub_Name "$i")} {(Lit_Other "+")} {(1)})] ) left_token: spids: [521 529] ) } spids: [520] ) ] spids: [520] ) ] spids: [462 531] ) spids: [456 460] ) (Assignment keyword: Assign_None pairs: [(assign_pair lhs:(LhsName name:ENVIRONMENT_SET) op:Equal rhs:{(DQ )} spids:[537])] spids: [537] ) (ForEach iter_name: vm iter_words: [{(vm-bootstrap)} {($ VSub_Name "$vms")} {($ VSub_Name "$mon_vms")}] do_arg_iter: False body: (DoGroup children: [ (Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (LhsName name:ENVIRONMENT_SET) op: Equal rhs: { (DQ ($ VSub_Name "$ENVIRONMENT_SET") (" ") ($ VSub_Name "$KNIFE") (" node environment set bcpc-") ($ VSub_Name "$vm") (.) ($ VSub_Name "$BCPC_HYPERVISOR_DOMAIN") (" ") ($ VSub_Name "$BOOTSTRAP_CHEF_ENV") (" && ") ) } spids: [557] ) ] spids: [557] ) ] spids: [554 571] ) spids: [546 552] ) (Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (LhsName name:ENVIRONMENT_SET) op: Equal rhs: {(DQ ($ VSub_Name "$ENVIRONMENT_SET") (" :"))} spids: [573] ) ] spids: [573] ) (C {(do_on_node)} {(vm-bootstrap)} {($ VSub_Name "$ENVIRONMENT_SET")}) (C {(do_on_node)} {(vm-bootstrap)} { (DQ ($ VSub_Name "$KNIFE") (" node run_list set bcpc-vm-bootstrap.") ($ VSub_Name "$BCPC_HYPERVISOR_DOMAIN") (" 'role[BCPC-Hardware-Virtual],role[BCPC-Bootstrap]' ") (" && ") ($ VSub_Name "$KNIFE") (" node run_list set bcpc-vm1.") ($ VSub_Name "$BCPC_HYPERVISOR_DOMAIN") (" 'role[BCPC-Hardware-Virtual],role[BCPC-Headnode]' ") (" && ") ($ VSub_Name "$KNIFE") (" node run_list set bcpc-vm2.") ($ VSub_Name "$BCPC_HYPERVISOR_DOMAIN") (" 'role[BCPC-Hardware-Virtual],role[BCPC-Worknode]' ") (" && ") ($ VSub_Name "$KNIFE") (" node run_list set bcpc-vm3.") ($ VSub_Name "$BCPC_HYPERVISOR_DOMAIN") (" 'role[BCPC-Hardware-Virtual],role[BCPC-EphemeralWorknode]'") ) } ) (Assignment keyword: Assign_None pairs: [(assign_pair lhs:(LhsName name:ADMIN_SET) op:Equal rhs:{(DQ ("true && "))} spids:[619])] spids: [619] ) (ForEach iter_name: vm iter_words: [{(vm-bootstrap)} {(vm1)} {($ VSub_Name "$mon_vms")}] do_arg_iter: False body: (DoGroup children: [ (Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (LhsName name:ADMIN_SET) op: Equal rhs: { (DQ ($ VSub_Name "$ADMIN_SET") (" ") ($ VSub_Name "$KNIFE") (" group add client bcpc-") ($ VSub_Name "$vm") (.) ($ VSub_Name "$BCPC_HYPERVISOR_DOMAIN") (" admins && ") ) } spids: [640] ) ] spids: [640] ) ] spids: [637 652] ) spids: [629 635] ) (Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (LhsName name:ADMIN_SET) op: Equal rhs: {(DQ ($ VSub_Name "$ADMIN_SET") (" :"))} spids: [654] ) ] spids: [654] ) (C {(do_on_node)} {(vm-bootstrap)} {($ VSub_Name "$ADMIN_SET")}) (If arms: [ (if_arm cond: [ (Sentence child: (DBracket expr: (BoolBinary op_id: BoolBinary_eq left: {($ VSub_Name "$BOOTSTRAP_CHEF_DO_CONVERGE")} right: {(0)} ) ) terminator: ) ] action: [ (ForEach iter_name: vm iter_words: [{($ VSub_Name "$mon_vms")}] do_arg_iter: False body: (DoGroup children: [ (C {(do_on_node)} {(vm-bootstrap)} { (DQ ($ VSub_Name "$KNIFE") (" node run_list set bcpc-") ($ VSub_Name "$vm") (.) ($ VSub_Name "$BCPC_HYPERVISOR_DOMAIN") (" 'role[BCPC-Monitoring]'") ) } ) ] spids: [701 718] ) spids: [697 699] ) (C {(echo)} {(DQ ("BOOTSTRAP_CHEF_DO_CONVERGE is set to 0, skipping automatic convergence."))} ) (C {(exit)} {(0)}) ] spids: [-1 689] ) ] else_action: [ (C {(do_on_node)} {(vm-bootstrap)} {(DQ ("sudo chef-client"))}) (ForEach iter_name: vm iter_words: [{($ VSub_Name "$vms")}] do_arg_iter: False body: (DoGroup children: [(C {(do_on_node)} {($ VSub_Name "$vm")} {(DQ ("sudo chef-client"))})] spids: [757 769] ) spids: [753 755] ) (C {(do_on_node)} {(vm1)} {(DQ ("sudo chef-client"))}) (ForEach iter_name: vm iter_words: [{($ VSub_Name "$vms")}] do_arg_iter: False body: (DoGroup children: [(C {(do_on_node)} {($ VSub_Name "$vm")} {(DQ ("sudo hup_openstack || true"))})] spids: [798 810] ) spids: [794 796] ) (ForEach iter_name: vm iter_words: [{($ VSub_Name "$mon_vms")}] do_arg_iter: False body: (DoGroup children: [ (C {(do_on_node)} {(vm-bootstrap)} { (DQ ($ VSub_Name "$KNIFE") (" node run_list set bcpc-") ($ VSub_Name "$vm") (.) ($ VSub_Name "$BCPC_HYPERVISOR_DOMAIN") (" 'role[BCPC-Monitoring]'") ) } ) (C {(do_on_node)} {($ VSub_Name "$vm")} {(DQ ("sudo chef-client"))}) ] spids: [826 852] ) spids: [822 824] ) (ForEach iter_name: vm iter_words: [ { (CommandSubPart command_list: (CommandList children: [ (Pipeline children: [ (C {(echo)} {($ VSub_Name "$mon_vms")}) (C {(awk)} {(SQ <"{$NF=\"\"}1">)}) ] negated: False ) ] ) left_token: spids: [865 877] ) } ] do_arg_iter: False body: (DoGroup children: [(C {(do_on_node)} {($ VSub_Name "$vm")} {(DQ ("sudo chef-client"))})] spids: [880 892] ) spids: [864 878] ) ] spids: [732 894] ) ] )