From 4a5897be657ec7ba8b7cad537293a9bbbdcdd5c3 Mon Sep 17 00:00:00 2001 From: Jaka Hudoklin Date: Thu, 4 Dec 2014 17:27:01 +0100 Subject: [PATCH] spark: update to 1.1.1, simplify a lot --- .../networking/cluster/spark/default.nix | 124 +++--------------- 1 file changed, 21 insertions(+), 103 deletions(-) diff --git a/pkgs/applications/networking/cluster/spark/default.nix b/pkgs/applications/networking/cluster/spark/default.nix index 1e9fe918a2e5..1852f21d27ac 100644 --- a/pkgs/applications/networking/cluster/spark/default.nix +++ b/pkgs/applications/networking/cluster/spark/default.nix @@ -1,128 +1,46 @@ -{ stdenv, fetchurl, jre, bash, simpleBuildTool, python27Packages }: +{ stdenv, fetchurl, makeWrapper, jre, pythonPackages +, mesosSupport ? true, mesos +}: + +with stdenv.lib; stdenv.mkDerivation rec { name = "spark-${version}"; - version = "0.9.1"; + version = "1.1.1"; src = fetchurl { url = "http://d3kbcqa49mib13.cloudfront.net/${name}-bin-cdh4.tgz"; - sha256 = "1k3954srx3km3ckmfi6wn8rldrljxc039g0pf5m3azgkmaz0gld5"; + sha256 = "1k0lw8aq5is3gnsrm8q24s0knga6kb3c9xsca20g11fy8b0y4nvk"; }; - unpackPhase = ''tar zxf $src''; + buildInputs = [ makeWrapper jre pythonPackages.python pythonPackages.numpy ] + ++ optional mesosSupport [ mesos ]; untarDir = "${name}-bin-cdh4"; installPhase = '' - set -x - mkdir -p $out/lib $out/bin - mv ${untarDir} $out/lib + mkdir -p $out/{lib/${untarDir}/conf,bin} + mv * $out/lib/${untarDir} - cat > $out/bin/spark-class < []" >&2 - exit 1 - fi - - export SPARK_MEM=\''${SPARK_MEM:-1024m} - - JAVA_OPTS="" - JAVA_OPTS="\$JAVA_OPTS -Djava.library.path=\"\$SPARK_LIBRARY_PATH\"" - JAVA_OPTS="\$JAVA_OPTS -Xms\$SPARK_MEM -Xmx\$SPARK_MEM" - export JAVA_OPTS - - CLASSPATH=\`$out/lib/${untarDir}/bin/compute-classpath.sh\` - export CLASSPATH - - exec ${jre}/bin/java -cp "\$CLASSPATH" \$JAVA_OPTS "\$@" + cat > $out/lib/${untarDir}/conf/spark-env.sh <<- EOF + export JAVA_HOME="${jre}" + export SPARK_HOME="$out/lib/${untarDir}" + export PYSPARK_PYTHON="${pythonPackages.python}/bin/${pythonPackages.python.executable}" + export PYTHONPATH="\$PYTHONPATH:$PYTHONPATH" + ${optionalString mesosSupport + ''export MESOS_NATIVE_LIBRARY="$MESOS_NATIVE_LIBRARY"''} EOF - chmod +x $out/bin/spark-class - cat > $out/bin/spark-shell </dev/null) - if [[ ! \$? ]]; then - saved_stty="" - fi - - $out/bin/spark-class \$OPTIONS org.apache.spark.repl.Main "\$@" - - exit_status=\$? - onExit - EOF - chmod +x $out/bin/spark-shell - - cat > $out/bin/pyspark < $out/bin/spark-upload-scala < $out/bin/spark-upload-python <