blob: 1cba489f6a306034b195cad24683123e092786b6 [file] [log] [blame]
buyingyi1341a162013-06-05 15:07:52 -07001#!/bin/bash
Till Westmann276bbc22013-06-05 18:56:27 -07002#/*
3# Copyright 2009-2013 by The Regents of the University of California
4# Licensed under the Apache License, Version 2.0 (the "License");
5# you may not use this file except in compliance with the License.
6# you may obtain a copy of the License from
7#
8# http://www.apache.org/licenses/LICENSE-2.0
9#
10# Unless required by applicable law or agreed to in writing, software
11# distributed under the License is distributed on an "AS IS" BASIS,
12# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13# See the License for the specific language governing permissions and
14# limitations under the License.
15#*/
buyingyi1341a162013-06-05 15:07:52 -070016#
17#------------------------------------------------------------------------
18# Copyright 2009-2013 by The Regents of the University of California
19# Licensed under the Apache License, Version 2.0 (the "License");
20# you may not use this file except in compliance with the License.
21# you may obtain a copy of the License from
22#
23# http://www.apache.org/licenses/LICENSE-2.0
24#
25# Unless required by applicable law or agreed to in writing, software
26# distributed under the License is distributed on an "AS IS" BASIS,
27# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
28# See the License for the specific language governing permissions and
29# limitations under the License.
30# ------------------------------------------------------------------------
31#
32
33hostname
34
35MY_NAME=`hostname`
36#Get the IP address of the cc
37CCHOST_NAME=`cat conf/master`
38CURRENT_PATH=`pwd`
39CCHOST=`ssh ${CCHOST_NAME} "cd ${CURRENT_PATH}; bin/getip.sh"`
40
41#Import cluster properties
42. conf/cluster.properties
43
44#Clean up temp dir
45
46rm -rf $NCTMP_DIR
47mkdir $NCTMP_DIR
48
49#Clean up log dir
50rm -rf $NCLOGS_DIR
51mkdir $NCLOGS_DIR
52
53
54#Clean up I/O working dir
55io_dirs=$(echo $IO_DIRS | tr "," "\n")
56for io_dir in $io_dirs
57do
58 rm -rf $io_dir
59 mkdir $io_dir
60done
61
62#Set JAVA_HOME
63export JAVA_HOME=$JAVA_HOME
64
65IPADDR=`bin/getip.sh`
66#echo $IPADDR
67
68#Get node ID
69NODEID=`hostname | cut -d '.' -f 1`
70
buyingyi1341a162013-06-05 15:07:52 -070071PREGELIX_HOME=`pwd`
72
73#Enter the temp dir
74cd $NCTMP_DIR
75
Yingyi Bu497da872013-12-01 14:46:28 -080076#get the OS
77OS_NAME=`uname -a|awk '{print $1}'`
78LINUX_OS='Linux'
79
80if [ $OS_NAME = $LINUX_OS ];
81then
82 MEM_SIZE=`cat /proc/meminfo |grep MemTotal|awk '{print $2}'`
buyingyicb1573e2013-12-02 17:04:59 -080083 MEM_SIZE=$(($MEM_SIZE * 1000))
Yingyi Bu497da872013-12-01 14:46:28 -080084else
85 MEM_SIZE=`sysctl -a | grep "hw.memsize ="|awk '{print $3}'`
86fi
87
88MEM_SIZE=$(($MEM_SIZE * 3 / 4))
89
90#Set JAVA_OPTS
91export JAVA_OPTS=$NCJAVA_OPTS" -Xmx"$MEM_SIZE
92
Yingyi Bu0622e8e2014-05-27 17:46:41 -070093#TODO: add the optimized setting for -net-buffer-count
94
buyingyi1341a162013-06-05 15:07:52 -070095#Launch hyracks nc
Jake Biesinger0b5368c2013-12-02 17:23:37 -080096cmd=( "${PREGELIX_HOME}/bin/pregelixnc" )
97cmd+=( -cc-host $CCHOST -cc-port $CC_CLUSTERPORT
98 -cluster-net-ip-address $IPADDR -data-ip-address $IPADDR -result-ip-address $IPADDR
Yingyi Bu26c6bb62014-06-06 20:48:32 -070099 -node-id $NODEID -iodevices "${IO_DIRS}" -net-buffer-count 5 -- ${VFRAME_SIZE});
Jake Biesinger0b5368c2013-12-02 17:23:37 -0800100
101printf "\n\n\n********************************************\nStarting NC with command %s\n\n" "${cmd[*]}" >> "$NCLOGS_DIR/$NODEID.log"
Jake Biesinger09f21822013-12-02 18:05:44 -0800102${cmd[@]} >> "$NCLOGS_DIR/$NODEID.log" 2>&1 &