2021-05-20 16:12:42 +00:00
|
|
|
{ lib, stdenv, fetchFromGitHub, cmake, libtool, llvm-bintools, ninja
|
2020-07-07 16:57:20 +00:00
|
|
|
, boost, brotli, capnproto, cctz, clang-unwrapped, double-conversion
|
|
|
|
, icu, jemalloc, libcpuid, libxml2, lld, llvm, lz4, libmysqlclient, openssl, perl
|
|
|
|
, poco, protobuf, python3, rapidjson, re2, rdkafka, readline, sparsehash, unixODBC
|
2019-10-17 00:37:10 +00:00
|
|
|
, xxHash, zstd
|
2021-11-21 19:38:57 +00:00
|
|
|
, nixosTests
|
2018-06-11 08:37:06 +00:00
|
|
|
}:
|
2017-03-27 01:06:23 +00:00
|
|
|
|
|
|
|
stdenv.mkDerivation rec {
|
2019-08-15 12:41:18 +00:00
|
|
|
pname = "clickhouse";
|
2022-12-16 12:09:57 +00:00
|
|
|
version = "22.8.11.15";
|
2017-03-27 01:06:23 +00:00
|
|
|
|
2021-05-08 12:50:53 +00:00
|
|
|
broken = stdenv.buildPlatform.is32bit; # not supposed to work on 32-bit https://github.com/ClickHouse/ClickHouse/pull/23959#issuecomment-835343685
|
|
|
|
|
2017-03-27 01:06:23 +00:00
|
|
|
src = fetchFromGitHub {
|
2020-07-07 16:57:20 +00:00
|
|
|
owner = "ClickHouse";
|
2018-08-07 22:54:32 +00:00
|
|
|
repo = "ClickHouse";
|
2021-05-18 10:04:37 +00:00
|
|
|
rev = "v${version}-lts";
|
2020-07-07 16:57:20 +00:00
|
|
|
fetchSubmodules = true;
|
2022-12-16 12:09:57 +00:00
|
|
|
sha256 = "sha256-ZFS7RgeTV/eMSiI0o9WO1fHjRkPDNZs0Gm3w+blGsz0=";
|
2017-03-27 01:06:23 +00:00
|
|
|
};
|
|
|
|
|
2021-05-01 03:03:19 +00:00
|
|
|
nativeBuildInputs = [ cmake libtool llvm-bintools ninja ];
|
2017-12-27 15:15:33 +00:00
|
|
|
buildInputs = [
|
2020-07-07 16:57:20 +00:00
|
|
|
boost brotli capnproto cctz clang-unwrapped double-conversion
|
2021-10-10 17:55:21 +00:00
|
|
|
icu jemalloc libxml2 lld llvm lz4 libmysqlclient openssl perl
|
2020-07-07 16:57:20 +00:00
|
|
|
poco protobuf python3 rapidjson re2 rdkafka readline sparsehash unixODBC
|
2019-10-17 00:37:10 +00:00
|
|
|
xxHash zstd
|
2021-10-10 17:55:21 +00:00
|
|
|
] ++ lib.optional stdenv.hostPlatform.isx86 libcpuid;
|
2017-03-27 01:06:23 +00:00
|
|
|
|
2020-07-07 16:57:20 +00:00
|
|
|
postPatch = ''
|
|
|
|
patchShebangs src/
|
|
|
|
|
|
|
|
substituteInPlace src/Storages/System/StorageSystemLicenses.sh \
|
|
|
|
--replace 'git rev-parse --show-toplevel' '$src'
|
|
|
|
substituteInPlace utils/check-style/check-duplicate-includes.sh \
|
|
|
|
--replace 'git rev-parse --show-toplevel' '$src'
|
|
|
|
substituteInPlace utils/check-style/check-ungrouped-includes.sh \
|
|
|
|
--replace 'git rev-parse --show-toplevel' '$src'
|
|
|
|
substituteInPlace utils/list-licenses/list-licenses.sh \
|
|
|
|
--replace 'git rev-parse --show-toplevel' '$src'
|
|
|
|
substituteInPlace utils/check-style/check-style \
|
|
|
|
--replace 'git rev-parse --show-toplevel' '$src'
|
|
|
|
'';
|
|
|
|
|
2018-08-07 22:54:32 +00:00
|
|
|
cmakeFlags = [
|
|
|
|
"-DENABLE_TESTS=OFF"
|
2022-09-03 09:33:45 +00:00
|
|
|
"-DENABLE_CCACHE=0"
|
2020-12-05 12:45:15 +00:00
|
|
|
"-DENABLE_EMBEDDED_COMPILER=ON"
|
|
|
|
"-USE_INTERNAL_LLVM_LIBRARY=OFF"
|
2019-01-06 04:16:10 +00:00
|
|
|
];
|
|
|
|
|
2018-07-28 22:56:04 +00:00
|
|
|
postInstall = ''
|
|
|
|
rm -rf $out/share/clickhouse-test
|
2018-12-19 14:06:53 +00:00
|
|
|
|
|
|
|
sed -i -e '\!<log>/var/log/clickhouse-server/clickhouse-server\.log</log>!d' \
|
|
|
|
$out/etc/clickhouse-server/config.xml
|
|
|
|
substituteInPlace $out/etc/clickhouse-server/config.xml \
|
|
|
|
--replace "<errorlog>/var/log/clickhouse-server/clickhouse-server.err.log</errorlog>" "<console>1</console>"
|
2018-07-28 22:56:04 +00:00
|
|
|
'';
|
|
|
|
|
2019-01-06 04:16:10 +00:00
|
|
|
hardeningDisable = [ "format" ];
|
|
|
|
|
2021-04-25 14:36:22 +00:00
|
|
|
# Builds in 7+h with 2 cores, and ~20m with a big-parallel builder.
|
|
|
|
requiredSystemFeatures = [ "big-parallel" ];
|
|
|
|
|
2021-11-21 19:38:57 +00:00
|
|
|
passthru.tests.clickhouse = nixosTests.clickhouse;
|
|
|
|
|
2021-01-11 07:54:33 +00:00
|
|
|
meta = with lib; {
|
2022-09-03 09:33:45 +00:00
|
|
|
homepage = "https://clickhouse.com";
|
2017-03-27 01:06:23 +00:00
|
|
|
description = "Column-oriented database management system";
|
|
|
|
license = licenses.asl20;
|
|
|
|
maintainers = with maintainers; [ orivej ];
|
|
|
|
platforms = platforms.linux;
|
|
|
|
};
|
|
|
|
}
|