github.com/iqoqo/nomad@v0.11.3-0.20200911112621-d7021c74d101/terraform/shared/scripts/server.sh (about)

     1  #!/bin/bash
     2  
     3  set -e
     4  
     5  CONFIGDIR=/ops/shared/config
     6  
     7  CONSULCONFIGDIR=/etc/consul.d
     8  VAULTCONFIGDIR=/etc/vault.d
     9  NOMADCONFIGDIR=/etc/nomad.d
    10  CONSULTEMPLATECONFIGDIR=/etc/consul-template.d
    11  HADOOP_VERSION=hadoop-2.7.7
    12  HADOOPCONFIGDIR=/usr/local/$HADOOP_VERSION/etc/hadoop
    13  HOME_DIR=ubuntu
    14  
    15  # Wait for network
    16  sleep 15
    17  
    18  IP_ADDRESS=$(curl http://instance-data/latest/meta-data/local-ipv4)
    19  # IP_ADDRESS="$(/sbin/ifconfig eth0 | grep 'inet addr:' | cut -d: -f2 | awk '{ print $1}')"
    20  DOCKER_BRIDGE_IP_ADDRESS=(`ifconfig docker0 2>/dev/null|awk '/inet addr:/ {print $2}'|sed 's/addr://'`)
    21  CLOUD=$1
    22  SERVER_COUNT=$2
    23  RETRY_JOIN=$3
    24  NOMAD_BINARY=$4
    25  
    26  # Consul
    27  sed -i "s/IP_ADDRESS/$IP_ADDRESS/g" $CONFIGDIR/consul.json
    28  sed -i "s/SERVER_COUNT/$SERVER_COUNT/g" $CONFIGDIR/consul.json
    29  sed -i "s/RETRY_JOIN/$RETRY_JOIN/g" $CONFIGDIR/consul.json
    30  sudo cp $CONFIGDIR/consul.json $CONSULCONFIGDIR
    31  sudo cp $CONFIGDIR/consul_$CLOUD.service /etc/systemd/system/consul.service
    32  
    33  sudo systemctl enable consul.service
    34  sudo systemctl start consul.service
    35  sleep 10
    36  export CONSUL_HTTP_ADDR=$IP_ADDRESS:8500
    37  export CONSUL_RPC_ADDR=$IP_ADDRESS:8400
    38  
    39  # Vault
    40  sed -i "s/IP_ADDRESS/$IP_ADDRESS/g" $CONFIGDIR/vault.hcl
    41  sudo cp $CONFIGDIR/vault.hcl $VAULTCONFIGDIR
    42  sudo cp $CONFIGDIR/vault.service /etc/systemd/system/vault.service
    43  
    44  sudo systemctl enable vault.service
    45  sudo systemctl start vault.service
    46  
    47  # Nomad
    48  
    49  ## Replace existing Nomad binary if remote file exists
    50  if [[ `wget -S --spider $NOMAD_BINARY  2>&1 | grep 'HTTP/1.1 200 OK'` ]]; then
    51    curl -L $NOMAD_BINARY > nomad.zip
    52    sudo unzip -o nomad.zip -d /usr/local/bin
    53    sudo chmod 0755 /usr/local/bin/nomad
    54    sudo chown root:root /usr/local/bin/nomad
    55  fi
    56  
    57  sed -i "s/SERVER_COUNT/$SERVER_COUNT/g" $CONFIGDIR/nomad.hcl
    58  sudo cp $CONFIGDIR/nomad.hcl $NOMADCONFIGDIR
    59  sudo cp $CONFIGDIR/nomad.service /etc/systemd/system/nomad.service
    60  
    61  sudo systemctl enable nomad.service
    62  sudo systemctl start nomad.service
    63  sleep 10
    64  export NOMAD_ADDR=http://$IP_ADDRESS:4646
    65  
    66  # Consul Template
    67  sudo cp $CONFIGDIR/consul-template.hcl $CONSULTEMPLATECONFIGDIR/consul-template.hcl
    68  sudo cp $CONFIGDIR/consul-template.service /etc/systemd/system/consul-template.service
    69  
    70  # Add hostname to /etc/hosts
    71  
    72  echo "127.0.0.1 $(hostname)" | sudo tee --append /etc/hosts
    73  
    74  # Add Docker bridge network IP to /etc/resolv.conf (at the top)
    75  
    76  echo "nameserver $DOCKER_BRIDGE_IP_ADDRESS" | sudo tee /etc/resolv.conf.new
    77  cat /etc/resolv.conf | sudo tee --append /etc/resolv.conf.new
    78  sudo mv /etc/resolv.conf.new /etc/resolv.conf
    79  
    80  # Hadoop
    81  sudo cp $CONFIGDIR/core-site.xml $HADOOPCONFIGDIR
    82  
    83  # Move examples directory to $HOME
    84  sudo mv /ops/examples /home/$HOME_DIR
    85  sudo chown -R $HOME_DIR:$HOME_DIR /home/$HOME_DIR/examples
    86  sudo chmod -R 775 /home/$HOME_DIR/examples
    87  
    88  # Set env vars for tool CLIs
    89  echo "export CONSUL_RPC_ADDR=$IP_ADDRESS:8400" | sudo tee --append /home/$HOME_DIR/.bashrc
    90  echo "export CONSUL_HTTP_ADDR=$IP_ADDRESS:8500" | sudo tee --append /home/$HOME_DIR/.bashrc
    91  echo "export VAULT_ADDR=http://$IP_ADDRESS:8200" | sudo tee --append /home/$HOME_DIR/.bashrc
    92  echo "export NOMAD_ADDR=http://$IP_ADDRESS:4646" | sudo tee --append /home/$HOME_DIR/.bashrc
    93  echo "export JAVA_HOME=/usr/lib/jvm/java-8-openjdk-amd64/jre"  | sudo tee --append /home/$HOME_DIR/.bashrc
    94  
    95  # Update PATH
    96  echo "export PATH=$PATH:/usr/local/bin/spark/bin:/usr/local/$HADOOP_VERSION/bin" | sudo tee --append /home/$HOME_DIR/.bashrc