36 lines
1.1 KiB
Bash
Executable file
36 lines
1.1 KiB
Bash
Executable file
#!/usr/bin/env bash
|
|
|
|
# Starts the master on the machine this script is executed on.
|
|
|
|
bin=`dirname "$0"`
|
|
bin=`cd "$bin"; pwd`
|
|
|
|
. "$bin/spark-config.sh"
|
|
|
|
if [ -f "${SPARK_CONF_DIR}/spark-env.sh" ]; then
|
|
. "${SPARK_CONF_DIR}/spark-env.sh"
|
|
fi
|
|
|
|
if [ "$SPARK_MASTER_PORT" = "" ]; then
|
|
SPARK_MASTER_PORT=7077
|
|
fi
|
|
|
|
if [ "$SPARK_MASTER_IP" = "" ]; then
|
|
SPARK_MASTER_IP=`hostname`
|
|
fi
|
|
|
|
if [ "$SPARK_MASTER_WEBUI_PORT" = "" ]; then
|
|
SPARK_MASTER_WEBUI_PORT=8080
|
|
fi
|
|
|
|
# Set SPARK_PUBLIC_DNS so the master report the correct webUI address to the slaves
|
|
if [ "$SPARK_PUBLIC_DNS" = "" ]; then
|
|
# If we appear to be running on EC2, use the public address by default:
|
|
# NOTE: ec2-metadata is installed on Amazon Linux AMI. Check based on that and hostname
|
|
if command -v ec2-metadata > /dev/null || [[ `hostname` == *ec2.internal ]]; then
|
|
export SPARK_PUBLIC_DNS=`wget -q -O - http://instance-data.ec2.internal/latest/meta-data/public-hostname`
|
|
fi
|
|
fi
|
|
|
|
"$bin"/spark-daemon.sh start spark.deploy.master.Master 1 --ip $SPARK_MASTER_IP --port $SPARK_MASTER_PORT --webui-port $SPARK_MASTER_WEBUI_PORT
|