apache-storm: 1.2.1 -> 2.1.0

This commit is contained in:
rnhmjoj 2020-06-22 15:36:39 +02:00
parent 4cdd64d907
commit aef5ee6964
No known key found for this signature in database
GPG Key ID: BFBAF4C975F76450

View File

@ -1,24 +1,27 @@
{ stdenv, lib, fetchurl, zip, unzip { stdenv, lib, fetchurl, zip, unzip
, jzmq, jdk, python , jdk, python
, confFile ? "", extraLibraryPaths ? [], extraJars ? [] }: , confFile ? ""
, extraLibraryPaths ? []
, extraJars ? []
}:
stdenv.mkDerivation rec { stdenv.mkDerivation rec {
name = "apache-storm-" + version; pname = "apache-storm";
version = "1.2.1"; version = "2.1.0";
name = "${pname}-${version}";
src = fetchurl { src = fetchurl {
url = url = "mirror://apache/storm/${name}/${name}.tar.gz";
"mirror://apache/storm/${name}/${name}.tar.gz"; sha256 = "1i3z08rfy7aavshrbrskv9dmlhx1fjgrhhqm0pczfam4vnas8yg2";
sha256 = "177dqgbviagrpvalg8h67mwiwwgmiqsg0hh97hcqqcjg71ypnjkv";
}; };
buildInputs = [ zip unzip jzmq ]; buildInputs = [ zip unzip ];
installPhase = '' installPhase = ''
mkdir -p $out/share/${name} mkdir -p $out/share/${name}
mv public $out/docs mv public $out/docs
mv examples $out/share/${name}/. mv examples $out/share/${name}/.
rm -f lib/jzmq* || exit 1
mv external extlib* lib $out/. mv external extlib* lib $out/.
mv conf bin $out/. mv conf bin $out/.
mv log4j2 $out/conf/. mv log4j2 $out/conf/.
@ -35,21 +38,22 @@ stdenv.mkDerivation rec {
-e "s|STORM_CONF_DIR = .*|STORM_CONF_DIR = os.getenv('STORM_CONF_DIR','$out/conf')|" \ -e "s|STORM_CONF_DIR = .*|STORM_CONF_DIR = os.getenv('STORM_CONF_DIR','$out/conf')|" \
-e 's|STORM_LOG4J2_CONF_DIR =.*|STORM_LOG4J2_CONF_DIR = os.path.join(STORM_CONF_DIR, "log4j2")|' \ -e 's|STORM_LOG4J2_CONF_DIR =.*|STORM_LOG4J2_CONF_DIR = os.path.join(STORM_CONF_DIR, "log4j2")|' \
$out/bin/storm.py $out/bin/storm.py
# Default jdk location # Default jdk location
sed -i -e 's|#.*export JAVA_HOME=.*|export JAVA_HOME="${jdk.home}"|' \ sed -i -e 's|#.*export JAVA_HOME=.*|export JAVA_HOME="${jdk.home}"|' \
$out/conf/storm-env.sh $out/conf/storm-env.sh
unzip $out/lib/storm-core-${version}.jar defaults.yaml; ls -lh $out/lib
zip -d $out/lib/storm-core-${version}.jar defaults.yaml; unzip $out/lib/storm-client-${version}.jar defaults.yaml;
zip -d $out/lib/storm-client-${version}.jar defaults.yaml;
sed -i \ sed -i \
-e 's|java.library.path: .*|java.library.path: "${jzmq}/lib:${lib.concatStringsSep ":" extraLibraryPaths}"|' \ -e 's|java.library.path: .*|java.library.path: "${lib.concatStringsSep ":" extraLibraryPaths}"|' \
-e 's|storm.log4j2.conf.dir: .*|storm.log4j2.conf.dir: "conf/log4j2"|' \ -e 's|storm.log4j2.conf.dir: .*|storm.log4j2.conf.dir: "conf/log4j2"|' \
defaults.yaml defaults.yaml
${if confFile != "" then ''cat ${confFile} >> defaults.yaml'' else ""} ${if confFile != "" then ''cat ${confFile} >> defaults.yaml'' else ""}
mv defaults.yaml $out/conf; mv defaults.yaml $out/conf;
# Link to jzmq jar and extra jars # Link to extra jars
cd $out/lib; cd $out/lib;
ln -s ${jzmq}/share/java/*.jar;
${lib.concatMapStrings (jar: "ln -s ${jar};\n") extraJars} ${lib.concatMapStrings (jar: "ln -s ${jar};\n") extraJars}
''; '';