tom | 5ca3437 | 2014-09-19 17:43:41 -0700 | [diff] [blame] | 1 | #!/bin/bash |
Pavlin Radoslavov | 9141379 | 2014-10-15 11:00:32 -0700 | [diff] [blame] | 2 | # ----------------------------------------------------------------------------- |
tom | 5ca3437 | 2014-09-19 17:43:41 -0700 | [diff] [blame] | 3 | # Remotely configures & starts ONOS for the first time. |
Pavlin Radoslavov | 9141379 | 2014-10-15 11:00:32 -0700 | [diff] [blame] | 4 | # ----------------------------------------------------------------------------- |
tom | 5ca3437 | 2014-09-19 17:43:41 -0700 | [diff] [blame] | 5 | |
| 6 | [ ! -d "$ONOS_ROOT" ] && echo "ONOS_ROOT is not defined" >&2 && exit 1 |
| 7 | . $ONOS_ROOT/tools/build/envDefaults |
| 8 | |
| 9 | remote=$ONOS_USER@${1:-$OCI} |
| 10 | |
tom | defed6f | 2014-09-29 11:37:02 -0700 | [diff] [blame] | 11 | # Generate a cluster.json from the ON* environment variables |
Yuta HIGUCHI | e4920dc | 2014-11-24 16:26:17 -0800 | [diff] [blame] | 12 | CDEF_FILE=/tmp/${remote}.cluster.json |
tom | defed6f | 2014-09-29 11:37:02 -0700 | [diff] [blame] | 13 | echo "{ \"nodes\":[" > $CDEF_FILE |
| 14 | for node in $(env | sort | egrep "OC[2-9]+" | cut -d= -f2); do |
| 15 | echo " { \"id\": \"$node\", \"ip\": \"$node\", \"tcpPort\": 9876 }," >> $CDEF_FILE |
| 16 | done |
| 17 | echo " { \"id\": \"$OC1\", \"ip\": \"$OC1\", \"tcpPort\": 9876 }" >> $CDEF_FILE |
| 18 | echo "]}" >> $CDEF_FILE |
Yuta HIGUCHI | e4920dc | 2014-11-24 16:26:17 -0800 | [diff] [blame] | 19 | scp -q $CDEF_FILE $remote:$ONOS_INSTALL_DIR/config/cluster.json |
tom | defed6f | 2014-09-29 11:37:02 -0700 | [diff] [blame] | 20 | |
Pavlin Radoslavov | 20bc6ae | 2014-12-03 05:35:04 +0000 | [diff] [blame] | 21 | ssh $remote " |
tom | 0768a02 | 2014-09-24 16:16:16 -0700 | [diff] [blame] | 22 | sudo perl -pi.bak -e \"s/ <interface>.*</ <interface>${ONOS_NIC:-192.168.56.*}</g\" \ |
| 23 | $ONOS_INSTALL_DIR/$KARAF_DIST/etc/hazelcast.xml |
Yuta HIGUCHI | 673aaeb | 2014-11-22 03:31:18 -0800 | [diff] [blame] | 24 | sudo perl -pi -e \"s/ <name>onos</ <name>${ONOS_CELL:-onos}</g\" \ |
| 25 | $ONOS_INSTALL_DIR/$KARAF_DIST/etc/hazelcast.xml |
tom | defed6f | 2014-09-29 11:37:02 -0700 | [diff] [blame] | 26 | |
| 27 | echo \"onos.ip = \$(ifconfig | grep $ONOS_NIC | cut -d: -f2 | cut -d\\ -f1)\" \ |
| 28 | >> $ONOS_INSTALL_DIR/$KARAF_DIST/etc/system.properties |
Yuta HIGUCHI | 18fdb25 | 2014-11-28 23:48:30 -0800 | [diff] [blame] | 29 | |
| 30 | # Drop copycat related log level for the console |
| 31 | echo "log4j.logger.net.kuujo.copycat= INFO" \ |
| 32 | >> $ONOS_INSTALL_DIR/$KARAF_DIST/etc/org.ops4j.pax.logging.cfg |
| 33 | |
tom | defed6f | 2014-09-29 11:37:02 -0700 | [diff] [blame] | 34 | " |
Yuta HIGUCHI | 60731cb | 2014-11-11 01:34:46 -0800 | [diff] [blame] | 35 | |
| 36 | # Generate a default tablets.json from the ON* environment variables |
Yuta HIGUCHI | e4920dc | 2014-11-24 16:26:17 -0800 | [diff] [blame] | 37 | TDEF_FILE=/tmp/${remote}.tablets.json |
| 38 | nodes=( $(env | sort | egrep "OC[0-9]+" | cut -d= -f2) ) |
Yuta HIGUCHI | 60731cb | 2014-11-11 01:34:46 -0800 | [diff] [blame] | 39 | echo "{ \"default\":[" > $TDEF_FILE |
Yuta HIGUCHI | e4920dc | 2014-11-24 16:26:17 -0800 | [diff] [blame] | 40 | while [ ${#nodes[@]} -gt 0 ]; do |
| 41 | node=${nodes[0]} |
| 42 | nodes=( ${nodes[@]:1} ) |
| 43 | if [ "${#nodes[@]}" -ne "0" ]; then |
| 44 | echo " { \"id\": \"$node\", \"ip\": \"$node\", \"tcpPort\": 9876 }," >> $TDEF_FILE |
| 45 | else |
| 46 | echo " { \"id\": \"$node\", \"ip\": \"$node\", \"tcpPort\": 9876 }" >> $TDEF_FILE |
| 47 | fi |
Yuta HIGUCHI | 60731cb | 2014-11-11 01:34:46 -0800 | [diff] [blame] | 48 | done |
Yuta HIGUCHI | 60731cb | 2014-11-11 01:34:46 -0800 | [diff] [blame] | 49 | echo "]}" >> $TDEF_FILE |
Yuta HIGUCHI | e4920dc | 2014-11-24 16:26:17 -0800 | [diff] [blame] | 50 | scp -q $TDEF_FILE $remote:$ONOS_INSTALL_DIR/config/tablets.json |
Yuta HIGUCHI | 60731cb | 2014-11-11 01:34:46 -0800 | [diff] [blame] | 51 | |
| 52 | |
| 53 | # copy tools/package/config/ to remote |
| 54 | scp -qr ${ONOS_ROOT}/tools/package/config/ $remote:$ONOS_INSTALL_DIR/ |
| 55 | |