2016-09-21 19:39:57 +02:00
|
|
|
{ stdenv, fetchFromGitHub, postgresql, openssl, zlib, readline }:
|
|
|
|
|
|
|
|
stdenv.mkDerivation rec {
|
2018-11-04 01:46:05 +01:00
|
|
|
name = "pg_repack-${version}";
|
|
|
|
version = "1.4.4";
|
2016-09-21 19:39:57 +02:00
|
|
|
|
2018-11-04 01:46:05 +01:00
|
|
|
buildInputs = [ postgresql openssl zlib readline ];
|
2016-09-21 19:39:57 +02:00
|
|
|
|
2018-11-04 01:46:05 +01:00
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "reorg";
|
|
|
|
repo = "pg_repack";
|
|
|
|
rev = "refs/tags/ver_${version}";
|
|
|
|
sha256 = "0ynsmsxfkcp82ccpz2nrgg8wiil8yxqigvw6425lx8v80h5lszbw";
|
|
|
|
};
|
2016-09-21 19:39:57 +02:00
|
|
|
|
2018-11-04 01:46:05 +01:00
|
|
|
installPhase = ''
|
|
|
|
install -D bin/pg_repack -t $out/bin/
|
|
|
|
install -D lib/pg_repack.so -t $out/lib/
|
2019-07-01 16:18:03 +02:00
|
|
|
install -D lib/{pg_repack--${version}.sql,pg_repack.control} -t $out/share/postgresql/extension
|
2018-11-04 01:46:05 +01:00
|
|
|
'';
|
2016-09-21 19:39:57 +02:00
|
|
|
|
2018-11-04 01:46:05 +01:00
|
|
|
meta = with stdenv.lib; {
|
|
|
|
description = "Reorganize tables in PostgreSQL databases with minimal locks";
|
|
|
|
longDescription = ''
|
|
|
|
pg_repack is a PostgreSQL extension which lets you remove bloat from tables and indexes, and optionally restore
|
|
|
|
the physical order of clustered indexes. Unlike CLUSTER and VACUUM FULL it works online, without holding an
|
|
|
|
exclusive lock on the processed tables during processing. pg_repack is efficient to boot,
|
|
|
|
with performance comparable to using CLUSTER directly.
|
|
|
|
'';
|
|
|
|
license = licenses.bsd3;
|
|
|
|
maintainers = with maintainers; [ danbst ];
|
|
|
|
inherit (postgresql.meta) platforms;
|
|
|
|
inherit (src.meta) homepage;
|
|
|
|
};
|
2016-09-21 19:39:57 +02:00
|
|
|
}
|