2016-09-21 18:39:57 +01:00
|
|
|
{ stdenv, fetchFromGitHub, postgresql, openssl, zlib, readline }:
|
|
|
|
|
|
|
|
stdenv.mkDerivation rec {
|
2019-08-15 13:41:18 +01:00
|
|
|
pname = "pg_repack";
|
2020-10-01 05:20:00 +01:00
|
|
|
version = "1.4.6";
|
2016-09-21 18:39:57 +01:00
|
|
|
|
2018-11-04 00:46:05 +00:00
|
|
|
buildInputs = [ postgresql openssl zlib readline ];
|
2016-09-21 18:39:57 +01:00
|
|
|
|
2018-11-04 00:46:05 +00:00
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "reorg";
|
|
|
|
repo = "pg_repack";
|
|
|
|
rev = "refs/tags/ver_${version}";
|
2020-10-01 05:20:00 +01:00
|
|
|
sha256 = "01n320cvn0z48ac4mbclpbzspdraaqzzw4xdcns7fj33vqq8nqm7";
|
2018-11-04 00:46:05 +00:00
|
|
|
};
|
2016-09-21 18:39:57 +01:00
|
|
|
|
2018-11-04 00:46:05 +00:00
|
|
|
installPhase = ''
|
|
|
|
install -D bin/pg_repack -t $out/bin/
|
|
|
|
install -D lib/pg_repack.so -t $out/lib/
|
2019-07-01 15:18:03 +01:00
|
|
|
install -D lib/{pg_repack--${version}.sql,pg_repack.control} -t $out/share/postgresql/extension
|
2018-11-04 00:46:05 +00:00
|
|
|
'';
|
2016-09-21 18:39:57 +01:00
|
|
|
|
2018-11-04 00:46:05 +00: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 18:39:57 +01:00
|
|
|
}
|