2012-12-28 01:47:37 -05:00
|
|
|
#!/usr/bin/env bash
|
2012-10-19 20:16:41 -04:00
|
|
|
|
2013-07-16 20:21:33 -04:00
|
|
|
#
|
|
|
|
# Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
# contributor license agreements. See the NOTICE file distributed with
|
|
|
|
# this work for additional information regarding copyright ownership.
|
|
|
|
# The ASF licenses this file to You under the Apache License, Version 2.0
|
|
|
|
# (the "License"); you may not use this file except in compliance with
|
|
|
|
# the License. You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
|
|
|
#
|
|
|
|
|
2012-10-19 20:16:41 -04:00
|
|
|
# Figure out where the Scala framework is installed
|
2013-01-01 17:48:45 -05:00
|
|
|
FWDIR="$(cd `dirname $0`; pwd)"
|
2012-10-19 20:16:41 -04:00
|
|
|
|
|
|
|
# Export this as SPARK_HOME
|
|
|
|
export SPARK_HOME="$FWDIR"
|
|
|
|
|
2013-09-15 03:17:20 -04:00
|
|
|
SCALA_VERSION=2.10
|
2013-08-27 18:46:23 -04:00
|
|
|
|
2013-01-17 14:14:47 -05:00
|
|
|
# Exit if the user hasn't compiled Spark
|
2013-08-23 02:02:09 -04:00
|
|
|
if [ ! -f "$FWDIR/RELEASE" ]; then
|
|
|
|
# Exit if the user hasn't compiled Spark
|
2013-08-27 18:46:23 -04:00
|
|
|
ls "$FWDIR"/assembly/target/scala-$SCALA_VERSION/spark-assembly*hadoop*.jar >& /dev/null
|
2013-08-23 02:02:09 -04:00
|
|
|
if [[ $? != 0 ]]; then
|
|
|
|
echo "Failed to find Spark assembly in $FWDIR/assembly/target" >&2
|
2013-08-30 15:38:23 -04:00
|
|
|
echo "You need to build Spark with sbt/sbt assembly before running this program" >&2
|
2013-08-23 02:02:09 -04:00
|
|
|
exit 1
|
|
|
|
fi
|
2013-01-17 14:14:47 -05:00
|
|
|
fi
|
|
|
|
|
2012-10-19 20:16:41 -04:00
|
|
|
# Load environment variables from conf/spark-env.sh, if it exists
|
|
|
|
if [ -e $FWDIR/conf/spark-env.sh ] ; then
|
|
|
|
. $FWDIR/conf/spark-env.sh
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Figure out which Python executable to use
|
|
|
|
if [ -z "$PYSPARK_PYTHON" ] ; then
|
|
|
|
PYSPARK_PYTHON="python"
|
|
|
|
fi
|
|
|
|
export PYSPARK_PYTHON
|
|
|
|
|
|
|
|
# Add the PySpark classes to the Python path:
|
2013-01-01 17:48:45 -05:00
|
|
|
export PYTHONPATH=$SPARK_HOME/python/:$PYTHONPATH
|
2012-10-19 20:16:41 -04:00
|
|
|
|
2013-01-02 00:25:49 -05:00
|
|
|
# Load the PySpark shell.py script when ./pyspark is used interactively:
|
|
|
|
export OLD_PYTHONSTARTUP=$PYTHONSTARTUP
|
|
|
|
export PYTHONSTARTUP=$FWDIR/python/pyspark/shell.py
|
|
|
|
|
2013-07-28 22:21:04 -04:00
|
|
|
if [ -n "$IPYTHON_OPTS" ]; then
|
|
|
|
IPYTHON=1
|
|
|
|
fi
|
|
|
|
|
2013-02-07 09:54:31 -05:00
|
|
|
if [[ "$IPYTHON" = "1" ]] ; then
|
2013-07-28 22:21:04 -04:00
|
|
|
IPYTHON_OPTS=${IPYTHON_OPTS:--i}
|
|
|
|
exec ipython "$IPYTHON_OPTS" -c "%run $PYTHONSTARTUP"
|
2013-02-07 09:54:31 -05:00
|
|
|
else
|
2013-07-28 22:21:04 -04:00
|
|
|
exec "$PYSPARK_PYTHON" "$@"
|
2013-02-07 09:54:31 -05:00
|
|
|
fi
|