pgbackrest/pgbackrest.spec
Marcus Rueckert e41c55d94d Accepting request 585100 from home:bruno_friedmann:branches:server:database:postgresql
Note for reviewer, could you check the build flags : it seems 
that what upstream use is not the quality of our normal C build.

- Packaging : 
  + modernize spec with spec-cleaner -m
  + remove pgbackrest-release-1.00_datadir.patch pgbackrest is now
    written in C
  + Build C binary and lib C
  + Adjust new parameter name in pgbackrest-conf.patch
- Update to new 2.0 version
  + Features:
    The archive-push command is now partially coded in C which 
    allows the PostgreSQL archive_command to run significantly 
    faster when processing status messages from the asynchronous 
    archive process. (Reviewed by Cynthia Shang.)
  + Improvements:
    - Improve check command to verify that the backup manifest can be
    built. (Contributed by Cynthia Shang.)
    - Improve performance of HTTPS client. Buffering now takes the 
    pending bytes on the socket into account (when present) rather
    than relying entirely on select(). In some instances the final
    bytes would not be flushed until the connection was closed.
    - Improve S3 delete performance. The constant S3_BATCH_MAX had 
    been replaced with a hard-coded value of 2, probably during 
    testing.
    - Allow any non-command-line option to be reset to default on 
    the command-line. This allows options in pgbackrest.conf to be 
    reset to default which reduces the need to write new config 
    files for specific needs.
    - The C library is now required. This eliminates conditional 
    loading and eases development of new library features.
    - The pgbackrest executable is now a C binary instead of Perl.
    This allows certain time-critical commands (like async

OBS-URL: https://build.opensuse.org/request/show/585100
OBS-URL: https://build.opensuse.org/package/show/server:database:postgresql/pgbackrest?expand=0&rev=10
2018-03-10 20:11:23 +00:00

100 lines
3.3 KiB
RPMSpec

#
# spec file for package pgbackrest
#
# Copyright (c) 2018 SUSE LINUX GmbH, Nuernberg, Germany.
#
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
# upon. The license for this file, and modifications and additions to the
# file, is the same license as for the pristine package itself (unless the
# license for the pristine package is not an Open Source License, in which
# case the license is the MIT License). An "Open Source License" is a
# license that conforms to the Open Source Definition (Version 1.9)
# published by the Open Source Initiative.
# Please submit bugfixes or comments via http://bugs.opensuse.org/
#
Name: pgbackrest
# Nobody can stop upstream to be too creative !
Version: 2.00
Release: 0
Summary: Reliable PostgreSQL Backup & Restore
License: MIT
Group: Productivity/Databases/Tools
URL: http://www.pgbackrest.org/
Source: https://github.com/pgbackrest/pgbackrest/archive/release/%{version}.tar.gz
Source1: pgbackrest-conf.patch
BuildRequires: openssl-devel
BuildRequires: perl-libxml-perl
BuildRequires: perl(DBD::Pg)
BuildRequires: perl(IO::Socket::SSL)
Requires: perl-libxml-perl
Requires: perl(DBD::Pg)
Requires: perl(IO::Socket::SSL)
%{perl_requires}
%if %{_arch} == "i586"
ExclusiveArch: do_not_build
%endif
%description
pgBackRest aims to be a simple, reliable backup and restore system that can
seamlessly scale up to the largest databases and workloads.
Instead of relying on traditional backup tools like tar and rsync, pgBackRest
implements all backup features internally and uses a custom protocol for
communicating with remote systems. Removing reliance on tar and rsync allows
for better solutions to database-specific backup challenges. The custom remote
protocol allows for more flexibility and limits the types of connections that
are required to perform a backup which increases security.
%prep
%setup -q -n %{name}-release-%{version}
%build
pushd src
make V=1 %{?_smp_mflags}
popd
pushd libc
perl Makefile.PL
make V=1 %{?_smp_mflags}
popd
%install
install -D -d -m 0755 %{buildroot}%{perl_vendorlib} %{buildroot}%{_bindir}
install -D -d -m 0700 %{buildroot}/%{_localstatedir}/lib/%{name}
install -D -d -m 0700 %{buildroot}%{_localstatedir}/log/%{name}
install -D -d -m 0700 %{buildroot}%{_localstatedir}/spool/%{name}
install -D -d -m 0755 %{buildroot}%{_sysconfdir}
install %{SOURCE1} %{buildroot}/%{_sysconfdir}/%{name}.conf
cp -a lib/* %{buildroot}%{perl_vendorlib}/
# Upstream makefile is nonsense sudo so use install
# make install -C src DESTDIR=%%{buildroot}
install -m 0755 src/%{name} %{buildroot}%{_bindir}/%{name}
make pure_vendor_install -C libc DESTDIR=%{buildroot}
%perl_process_packlist
%perl_gen_filelist
%check
pushd libc
make test
popd
%files -f %{name}.files
%defattr(-,root,root)
%doc README.md
%if 0%{?leap_version} >= 420200 || 0%{?suse_version} > 1320
%license LICENSE
%else
%license LICENSE
%endif
%config(noreplace) %attr (644,root,root) %{_sysconfdir}/%{name}.conf
# We still can do that as postgres user is system fixed
%attr(-,postgres,postgres) %{_localstatedir}/log/%{name}
%attr(-,postgres,postgres) %{_localstatedir}/lib/%{name}
%attr(-,postgres,postgres) %{_localstatedir}/spool/%{name}
%changelog