nixpkgs/pkgs/applications/networking/cluster/mesos/default.nix

254 lines
9.1 KiB
Nix
Raw Normal View History

2014-12-02 12:09:36 +01:00
{ stdenv, lib, makeWrapper, fetchurl, curl, sasl, openssh, autoconf
, automake, libtool, unzip, gnutar, jdk, maven, python, wrapPython
2016-02-22 23:25:50 +01:00
, setuptools, boto, pythonProtobuf, apr, subversion, gzip, systemd
, leveldb, glog, perf, utillinux, libnl, iproute, openssl, libevent
2016-12-28 06:19:51 +01:00
, ethtool, coreutils, which, iptables
2016-02-22 23:25:50 +01:00
, bash
}:
let
mavenRepo = import ./mesos-deps.nix { inherit stdenv curl; };
soext = if stdenv.system == "x86_64-darwin" then "dylib" else "so";
2016-12-28 06:19:51 +01:00
# `tar -z` requires gzip on $PATH, so wrap tar.
# At some point, we should try to patch mesos so we add gzip to the PATH when
# tar is invoked. I think that only needs to be done here:
# src/common/command_utils.cpp
# https://github.com/NixOS/nixpkgs/issues/13783
tarWithGzip = lib.overrideDerivation gnutar (oldAttrs: {
buildInputs = (oldAttrs.buildInputs or []) ++ [ makeWrapper ];
postInstall = (oldAttrs.postInstall or "") + ''
wrapProgram $out/bin/tar --prefix PATH ":" "${gzip}/bin"
'';
});
in stdenv.mkDerivation rec {
2017-04-27 11:13:15 +02:00
version = "1.1.1";
name = "mesos-${version}";
2016-02-22 23:25:50 +01:00
enableParallelBuilding = true;
dontDisableStatic = true;
src = fetchurl {
2015-12-28 22:27:47 +01:00
url = "mirror://apache/mesos/${version}/${name}.tar.gz";
2017-04-27 11:13:15 +02:00
sha256 = "0f46ebb130d2d4a9732f95d0a71d80c8c5967f3c172b110f2ece316e05922115";
};
patches = [
# https://reviews.apache.org/r/36610/
2016-12-28 06:19:51 +01:00
# TODO: is this still needed?
./rb36610.patch
2016-09-29 03:39:19 +02:00
# see https://github.com/cstrahan/mesos/tree/nixos-${version}
./nixos.patch
];
buildInputs = [
makeWrapper autoconf automake libtool curl sasl jdk maven
python wrapPython boto setuptools leveldb
subversion apr glog openssl libevent
] ++ lib.optionals stdenv.isLinux [
libnl
];
propagatedBuildInputs = [
pythonProtobuf
];
2016-12-28 06:19:51 +01:00
# note that we *must* statically link libprotobuf.
# if we dynamically link the lib, we get these errors:
# https://github.com/NixOS/nixpkgs/pull/19064#issuecomment-255082684
preConfigure = ''
# https://issues.apache.org/jira/browse/MESOS-6616
configureFlagsArray+=(
"CXXFLAGS=-O2 -Wno-error=strict-aliasing"
)
# Fix cases where makedev(),major(),minor() are referenced through
# <sys/types.h> instead of <sys/sysmacros.h>
sed 1i'#include <sys/sysmacros.h>' -i src/linux/fs.cpp
sed 1i'#include <sys/sysmacros.h>' -i src/slave/containerizer/mesos/isolators/gpu/isolator.cpp
2016-12-28 06:19:51 +01:00
substituteInPlace 3rdparty/stout/include/stout/os/posix/chown.hpp \
--subst-var-by chown ${coreutils}/bin/chown
substituteInPlace 3rdparty/stout/Makefile.am \
--replace "-lprotobuf" \
"${pythonProtobuf.protobuf}/lib/libprotobuf.so"
2016-12-28 06:19:51 +01:00
substituteInPlace 3rdparty/stout/include/stout/os/posix/fork.hpp \
2016-09-29 03:39:19 +02:00
--subst-var-by sh ${bash}/bin/bash
2016-03-11 15:23:48 +01:00
2016-12-28 06:19:51 +01:00
substituteInPlace 3rdparty/stout/include/stout/posix/os.hpp \
--subst-var-by tar ${tarWithGzip}/bin/tar
2016-09-29 03:39:19 +02:00
substituteInPlace src/cli/mesos-scp \
--subst-var-by scp ${openssh}/bin/scp
2016-12-28 06:19:51 +01:00
substituteInPlace src/common/command_utils.cpp \
--subst-var-by curl ${curl}/bin/curl \
--subst-var-by gzip ${gzip}/bin/gzip \
--subst-var-by sha512sum ${coreutils}/bin/sha512sum \
--subst-var-by tar ${tarWithGzip}/bin/tar
substituteInPlace src/launcher/fetcher.cpp \
2016-12-28 06:19:51 +01:00
--subst-var-by cp ${coreutils}/bin/cp \
2016-09-29 03:39:19 +02:00
--subst-var-by gzip ${gzip}/bin/gzip \
2016-12-28 06:19:51 +01:00
--subst-var-by tar ${tarWithGzip}/bin/tar \
2016-09-29 03:39:19 +02:00
--subst-var-by unzip ${unzip}/bin/unzip
substituteInPlace src/python/cli/src/mesos/cli.py \
2016-09-29 03:39:19 +02:00
--subst-var-by mesos-resolve $out/bin/mesos-resolve
2016-12-28 06:19:51 +01:00
substituteInPlace src/python/native_common/ext_modules.py.in \
--replace "-lprotobuf" \
"${pythonProtobuf.protobuf}/lib/libprotobuf.so"
2016-12-28 06:19:51 +01:00
substituteInPlace src/slave/containerizer/mesos/isolators/gpu/volume.cpp \
--subst-var-by cp ${coreutils}/bin/cp \
--subst-var-by which ${which}/bin/which
2016-09-29 03:39:19 +02:00
substituteInPlace src/slave/containerizer/mesos/isolators/posix/disk.cpp \
2016-12-28 06:19:51 +01:00
--subst-var-by du ${coreutils}/bin/du
2016-09-29 03:39:19 +02:00
substituteInPlace src/slave/containerizer/mesos/provisioner/backends/copy.cpp \
2016-12-28 06:19:51 +01:00
--subst-var-by cp ${coreutils}/bin/cp \
--subst-var-by rm ${coreutils}/bin/rm
2016-09-29 03:39:19 +02:00
substituteInPlace src/uri/fetchers/copy.cpp \
--subst-var-by cp ${coreutils}/bin/cp
2016-09-29 03:39:19 +02:00
substituteInPlace src/uri/fetchers/curl.cpp \
--subst-var-by curl ${curl}/bin/curl
substituteInPlace src/uri/fetchers/docker.cpp \
--subst-var-by curl ${curl}/bin/curl
2016-12-28 06:19:51 +01:00
substituteInPlace src/Makefile.am \
--subst-var-by mavenRepo ${mavenRepo} \
--replace "-lprotobuf" \
"${pythonProtobuf.protobuf}/lib/libprotobuf.so"
2016-12-28 06:19:51 +01:00
2016-09-29 03:39:19 +02:00
'' + lib.optionalString stdenv.isLinux ''
2016-09-29 03:39:19 +02:00
substituteInPlace src/linux/perf.cpp \
--subst-var-by perf ${perf}/bin/perf
2016-12-28 06:19:51 +01:00
substituteInPlace src/slave/containerizer/mesos/isolators/docker/volume/isolator.cpp \
--subst-var-by mount ${utillinux}/bin/mount
substituteInPlace src/slave/containerizer/mesos/isolators/filesystem/linux.cpp \
--subst-var-by mount ${utillinux}/bin/mount
substituteInPlace src/slave/containerizer/mesos/isolators/filesystem/shared.cpp \
2016-09-29 03:39:19 +02:00
--subst-var-by mount ${utillinux}/bin/mount
2016-12-28 06:19:51 +01:00
substituteInPlace src/slave/containerizer/mesos/isolators/gpu/isolator.cpp \
--subst-var-by mount ${utillinux}/bin/mount
substituteInPlace src/slave/containerizer/mesos/isolators/namespaces/pid.cpp \
2016-09-29 03:39:19 +02:00
--subst-var-by mount ${utillinux}/bin/mount
2016-12-28 06:19:51 +01:00
substituteInPlace src/slave/containerizer/mesos/isolators/network/cni/cni.cpp \
--subst-var-by mount ${utillinux}/bin/mount
substituteInPlace src/slave/containerizer/mesos/isolators/network/cni/plugins/port_mapper/port_mapper.cpp \
--subst-var-by iptables ${iptables}/bin/iptables
substituteInPlace src/slave/containerizer/mesos/isolators/network/port_mapping.cpp \
2016-12-28 06:19:51 +01:00
--subst-var-by ethtool ${ethtool}/sbin/ethtool \
2016-09-29 03:39:19 +02:00
--subst-var-by ip ${iproute}/bin/ip \
--subst-var-by mount ${utillinux}/bin/mount \
2016-12-28 06:19:51 +01:00
--subst-var-by tc ${iproute}/bin/tc
substituteInPlace src/slave/containerizer/mesos/isolators/volume/image.cpp \
--subst-var-by mount ${utillinux}/bin/mount
substituteInPlace src/slave/containerizer/mesos/isolators/volume/sandbox_path.cpp \
--subst-var-by mount ${utillinux}/bin/mount
'';
configureFlags = [
"--sbindir=\${out}/bin"
"--with-apr=${apr.dev}"
"--with-svn=${subversion.dev}"
2014-12-02 12:09:36 +01:00
"--with-leveldb=${leveldb}"
"--with-glog=${glog}"
"--enable-optimize"
2014-12-02 12:09:36 +01:00
"--disable-python-dependency-install"
"--enable-ssl"
"--with-ssl=${openssl.dev}"
"--enable-libevent"
"--with-libevent=${libevent.dev}"
2016-09-29 03:39:19 +02:00
"--with-protobuf=${pythonProtobuf.protobuf}"
"PROTOBUF_JAR=${mavenRepo}/com/google/protobuf/protobuf-java/2.6.1/protobuf-java-2.6.1.jar"
] ++ lib.optionals stdenv.isLinux [
"--with-network-isolator"
2016-09-29 03:39:19 +02:00
"--with-nl=${libnl.dev}"
];
postInstall = ''
rm -rf $out/var
rm $out/bin/*.sh
mkdir -p $out/share/java
cp src/java/target/mesos-*.jar $out/share/java
MESOS_NATIVE_JAVA_LIBRARY=$out/lib/libmesos.${soext}
mkdir -p $out/nix-support
touch $out/nix-support/setup-hook
echo "export MESOS_NATIVE_JAVA_LIBRARY=$MESOS_NATIVE_JAVA_LIBRARY" >> $out/nix-support/setup-hook
echo "export MESOS_NATIVE_LIBRARY=$MESOS_NATIVE_JAVA_LIBRARY" >> $out/nix-support/setup-hook
# Inspired by: pkgs/development/python-modules/generic/default.nix
2015-08-04 09:12:52 +02:00
pushd src/python
mkdir -p $out/lib/${python.libPrefix}/site-packages
export PYTHONPATH="$out/lib/${python.libPrefix}/site-packages:$PYTHONPATH"
2015-08-04 09:12:52 +02:00
${python}/bin/${python.executable} setup.py install \
--install-lib=$out/lib/${python.libPrefix}/site-packages \
--old-and-unmanageable \
--prefix="$out"
rm -f "$out/lib/${python.libPrefix}"/site-packages/site.py*
2015-08-04 09:12:52 +02:00
popd
2016-02-22 23:25:50 +01:00
# optional python dependency for mesos cli
pushd src/python/cli
${python}/bin/${python.executable} setup.py install \
--install-lib=$out/lib/${python.libPrefix}/site-packages \
--old-and-unmanageable \
--prefix="$out"
popd
'';
postFixup = ''
if test -e $out/nix-support/propagated-build-inputs; then
ln -s $out/nix-support/propagated-build-inputs $out/nix-support/propagated-user-env-packages
fi
for inputsfile in propagated-build-inputs propagated-native-build-inputs; do
if test -e $out/nix-support/$inputsfile; then
createBuildInputsPth $inputsfile "$(cat $out/nix-support/$inputsfile)"
fi
done
for f in $out/libexec/mesos/python/mesos/*.py; do
${python}/bin/${python.executable} -c "import py_compile; py_compile.compile('$f')"
done
# wrap the python programs
for prog in mesos-cat mesos-ps mesos-scp mesos-tail; do
wrapProgram "$out/bin/$prog" \
--prefix PYTHONPATH ":" "$out/lib/${python.libPrefix}/site-packages"
true
done
'';
meta = with lib; {
homepage = "http://mesos.apache.org";
license = licenses.asl20;
description = "A cluster manager that provides efficient resource isolation and sharing across distributed applications, or frameworks";
2017-08-29 20:34:52 +02:00
maintainers = with maintainers; [ cstrahan kevincox offline ];
platforms = platforms.linux;
};
}