2017-11-15 13:56:13 +00:00
|
|
|
%global _hardened_build 1
|
|
|
|
|
|
|
|
%global _for_fedora_koji_builds 0
|
|
|
|
|
|
|
|
# uncomment and add '%' to use the prereltag for pre-releases
|
|
|
|
# %%global prereltag qa3
|
|
|
|
|
|
|
|
##-----------------------------------------------------------------------------
|
|
|
|
## All argument definitions should be placed here and keep them sorted
|
|
|
|
##
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
# asan
|
|
|
|
# if you wish to compile an rpm with address sanitizer...
|
|
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --with asan
|
|
|
|
%{?_with_asan:%global _with_asan --enable-asan}
|
2017-11-15 13:56:13 +00:00
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{?rhel} && 0%{?rhel} < 7 )
|
|
|
|
%global _with_asan %{nil}
|
|
|
|
%endif
|
2017-11-15 13:56:13 +00:00
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
# bd
|
|
|
|
# if you wish to compile an rpm without the BD map support...
|
|
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --without bd
|
|
|
|
%{?_without_bd:%global _without_bd --disable-bd-xlator}
|
|
|
|
|
|
|
|
%if ( 0%{?rhel} && 0%{?rhel} > 7 )
|
|
|
|
%global _without_bd --without-bd
|
|
|
|
%endif
|
|
|
|
|
|
|
|
# cmocka
|
2017-11-15 13:56:13 +00:00
|
|
|
# if you wish to compile an rpm with cmocka unit testing...
|
2019-04-08 03:04:00 +00:00
|
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --with cmocka
|
2017-11-15 13:56:13 +00:00
|
|
|
%{?_with_cmocka:%global _with_cmocka --enable-cmocka}
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
# debug
|
|
|
|
# if you wish to compile an rpm with debugging...
|
|
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --with debug
|
|
|
|
%{?_with_debug:%global _with_debug --enable-debug}
|
2017-11-15 13:56:13 +00:00
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
# epoll
|
2017-11-15 13:56:13 +00:00
|
|
|
# if you wish to compile an rpm without epoll...
|
2019-04-08 03:04:00 +00:00
|
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --without epoll
|
2017-11-15 13:56:13 +00:00
|
|
|
%{?_without_epoll:%global _without_epoll --disable-epoll}
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
# fusermount
|
2017-11-15 13:56:13 +00:00
|
|
|
# if you wish to compile an rpm without fusermount...
|
2019-04-08 03:04:00 +00:00
|
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --without fusermount
|
2017-11-15 13:56:13 +00:00
|
|
|
%{?_without_fusermount:%global _without_fusermount --disable-fusermount}
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
# geo-rep
|
2017-11-15 13:56:13 +00:00
|
|
|
# if you wish to compile an rpm without geo-replication support, compile like this...
|
2019-04-08 03:04:00 +00:00
|
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --without georeplication
|
2017-11-15 13:56:13 +00:00
|
|
|
%{?_without_georeplication:%global _without_georeplication --disable-georeplication}
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
# gnfs
|
|
|
|
# if you wish to compile an rpm with the legacy gNFS server xlator
|
|
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --with gnfs
|
|
|
|
%{?_with_gnfs:%global _with_gnfs --enable-gnfs}
|
|
|
|
|
|
|
|
# ipv6default
|
|
|
|
# if you wish to compile an rpm with IPv6 default...
|
|
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --with ipv6default
|
|
|
|
%{?_with_ipv6default:%global _with_ipv6default --with-ipv6-default}
|
|
|
|
|
|
|
|
# libtirpc
|
|
|
|
# if you wish to compile an rpm without TIRPC (i.e. use legacy glibc rpc)
|
|
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --without libtirpc
|
|
|
|
%{?_without_libtirpc:%global _without_libtirpc --without-libtirpc}
|
|
|
|
|
|
|
|
# Do not use libtirpc on EL6, it does not have xdr_uint64_t() and xdr_uint32_t
|
|
|
|
# Do not use libtirpc on EL7, it does not have xdr_sizeof()
|
|
|
|
%if ( 0%{?rhel} && 0%{?rhel} <= 7 )
|
|
|
|
%global _without_libtirpc --without-libtirpc
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
|
|
|
|
# ocf
|
2017-11-15 13:56:13 +00:00
|
|
|
# if you wish to compile an rpm without the OCF resource agents...
|
2019-04-08 03:04:00 +00:00
|
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --without ocf
|
2017-11-15 13:56:13 +00:00
|
|
|
%{?_without_ocf:%global _without_ocf --without-ocf}
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
# rdma
|
|
|
|
# if you wish to compile an rpm without rdma support, compile like this...
|
|
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --without rdma
|
|
|
|
%{?_without_rdma:%global _without_rdma --disable-ibverbs}
|
|
|
|
|
|
|
|
# No RDMA Support on 32-bit ARM
|
|
|
|
%ifarch armv7hl
|
|
|
|
%global _without_rdma --disable-ibverbs
|
|
|
|
%endif
|
|
|
|
|
|
|
|
# server
|
|
|
|
# if you wish to build rpms without server components, compile like this
|
|
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --without server
|
|
|
|
%{?_without_server:%global _without_server --without-server}
|
|
|
|
|
|
|
|
# disable server components forcefully as rhel <= 6
|
|
|
|
%if ( 0%{?rhel} )
|
|
|
|
%if (!(( "%{?dist}" == ".el6rhs" ) || ( "%{?dist}" == ".el7rhs" ) || ( "%{?dist}" == ".el7rhgs" )))
|
|
|
|
%global _without_server --without-server
|
|
|
|
%endif
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%global _without_extra_xlators 1
|
|
|
|
%global _without_regression_tests 1
|
|
|
|
|
|
|
|
# syslog
|
2017-11-15 13:56:13 +00:00
|
|
|
# if you wish to build rpms without syslog logging, compile like this
|
2019-04-08 03:04:00 +00:00
|
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --without syslog
|
2017-11-15 13:56:13 +00:00
|
|
|
%{?_without_syslog:%global _without_syslog --disable-syslog}
|
|
|
|
|
|
|
|
# disable syslog forcefully as rhel <= 6 doesn't have rsyslog or rsyslog-mmcount
|
|
|
|
# Fedora deprecated syslog, see
|
|
|
|
# https://fedoraproject.org/wiki/Changes/NoDefaultSyslog
|
|
|
|
# (And what about RHEL7?)
|
|
|
|
%if ( 0%{?fedora} && 0%{?fedora} >= 20 ) || ( 0%{?rhel} && 0%{?rhel} <= 6 )
|
|
|
|
%global _without_syslog --disable-syslog
|
|
|
|
%endif
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
# tsan
|
|
|
|
# if you wish to compile an rpm with thread sanitizer...
|
|
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --with tsan
|
|
|
|
%{?_with_tsan:%global _with_tsan --enable-tsan}
|
2017-11-15 13:56:13 +00:00
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{?rhel} && 0%{?rhel} < 7 )
|
|
|
|
%global _with_tsan %{nil}
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
# valgrind
|
|
|
|
# if you wish to compile an rpm to run all processes under valgrind...
|
|
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --with valgrind
|
|
|
|
%{?_with_valgrind:%global _with_valgrind --enable-valgrind}
|
2017-11-15 13:56:13 +00:00
|
|
|
|
|
|
|
##-----------------------------------------------------------------------------
|
|
|
|
## All %%global definitions should be placed here and keep them sorted
|
|
|
|
##
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{?fedora} ) || ( 0%{?rhel} && 0%{?rhel} > 6 )
|
2017-11-15 13:56:13 +00:00
|
|
|
%global _with_systemd true
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%if ( 0%{?fedora} ) || ( 0%{?rhel} && 0%{?rhel} >= 7 )
|
|
|
|
%global _with_firewalld --enable-firewalld
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%if 0%{?_tmpfilesdir:1}
|
|
|
|
%global _with_tmpfilesdir --with-tmpfilesdir=%{_tmpfilesdir}
|
|
|
|
%else
|
|
|
|
%global _with_tmpfilesdir --without-tmpfilesdir
|
|
|
|
%endif
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
# without server should also disable some server-only components
|
|
|
|
%if 0%{?_without_server:1}
|
2017-11-15 13:56:13 +00:00
|
|
|
%global _without_events --disable-events
|
2019-04-08 03:04:00 +00:00
|
|
|
%global _without_georeplication --disable-georeplication
|
|
|
|
%global _with_gnfs %{nil}
|
|
|
|
%global _without_ocf --without-ocf
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%if ( 0%{?fedora} ) || ( 0%{?rhel} && 0%{?rhel} > 7 )
|
|
|
|
%global _usepython3 1
|
|
|
|
%global _pythonver 3
|
|
|
|
%else
|
|
|
|
%global _usepython3 0
|
|
|
|
%global _pythonver 2
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
|
|
|
|
# From https://fedoraproject.org/wiki/Packaging:Python#Macros
|
|
|
|
%if ( 0%{?rhel} && 0%{?rhel} <= 6 )
|
|
|
|
%{!?python2_sitelib: %global python2_sitelib %(python2 -c "from distutils.sysconfig import get_python_lib; print(get_python_lib())")}
|
|
|
|
%{!?python2_sitearch: %global python2_sitearch %(python2 -c "from distutils.sysconfig import get_python_lib; print(get_python_lib(1))")}
|
|
|
|
%global _rundir %{_localstatedir}/run
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%if ( 0%{?_with_systemd:1} )
|
2019-04-08 03:04:00 +00:00
|
|
|
%global service_start() /bin/systemctl --quiet start %1.service || : \
|
|
|
|
%{nil}
|
|
|
|
%global service_stop() /bin/systemctl --quiet stop %1.service || :\
|
|
|
|
%{nil}
|
|
|
|
%global service_install() install -D -p -m 0644 %1.service %{buildroot}%2 \
|
|
|
|
%{nil}
|
2017-11-15 13:56:13 +00:00
|
|
|
# can't seem to make a generic macro that works
|
2019-04-08 03:04:00 +00:00
|
|
|
%global glusterd_svcfile %{_unitdir}/glusterd.service
|
|
|
|
%global glusterfsd_svcfile %{_unitdir}/glusterfsd.service
|
|
|
|
%global glusterta_svcfile %{_unitdir}/gluster-ta-volume.service
|
|
|
|
%global glustereventsd_svcfile %{_unitdir}/glustereventsd.service
|
|
|
|
%global glusterfssharedstorage_svcfile %{_unitdir}/glusterfssharedstorage.service
|
2017-11-15 13:56:13 +00:00
|
|
|
%else
|
2019-04-08 03:04:00 +00:00
|
|
|
%global systemd_post() /sbin/chkconfig --add %1 >/dev/null 2>&1 || : \
|
|
|
|
%{nil}
|
|
|
|
%global systemd_preun() /sbin/chkconfig --del %1 >/dev/null 2>&1 || : \
|
|
|
|
%{nil}
|
|
|
|
%global systemd_postun_with_restart() /sbin/service %1 condrestart >/dev/null 2>&1 || : \
|
|
|
|
%{nil}
|
|
|
|
%global service_start() /sbin/service %1 start >/dev/null 2>&1 || : \
|
|
|
|
%{nil}
|
|
|
|
%global service_stop() /sbin/service %1 stop >/dev/null 2>&1 || : \
|
|
|
|
%{nil}
|
|
|
|
%global service_install() install -D -p -m 0755 %1.init %{buildroot}%2 \
|
|
|
|
%{nil}
|
2017-11-15 13:56:13 +00:00
|
|
|
# can't seem to make a generic macro that works
|
2019-04-08 03:04:00 +00:00
|
|
|
%global glusterd_svcfile %{_sysconfdir}/init.d/glusterd
|
|
|
|
%global glusterfsd_svcfile %{_sysconfdir}/init.d/glusterfsd
|
|
|
|
%global glustereventsd_svcfile %{_sysconfdir}/init.d/glustereventsd
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
|
|
|
|
%{!?_pkgdocdir: %global _pkgdocdir %{_docdir}/%{name}-%{version}}
|
|
|
|
|
|
|
|
# We do not want to generate useless provides and requires for xlator
|
|
|
|
# .so files to be set for glusterfs packages.
|
|
|
|
# Filter all generated:
|
|
|
|
#
|
|
|
|
# TODO: RHEL5 does not have a convenient solution
|
|
|
|
%if ( 0%{?rhel} == 6 )
|
|
|
|
# filter_setup exists in RHEL6 only
|
|
|
|
%filter_provides_in %{_libdir}/glusterfs/%{version}/
|
|
|
|
%global __filter_from_req %{?__filter_from_req} | grep -v -P '^(?!lib).*\.so.*$'
|
|
|
|
%filter_setup
|
|
|
|
%else
|
|
|
|
# modern rpm and current Fedora do not generate requires when the
|
|
|
|
# provides are filtered
|
|
|
|
%global __provides_exclude_from ^%{_libdir}/glusterfs/%{version}/.*$
|
|
|
|
%endif
|
|
|
|
|
|
|
|
|
|
|
|
##-----------------------------------------------------------------------------
|
|
|
|
## All package definitions should be placed here in alphabetical order
|
|
|
|
##
|
|
|
|
Summary: Distributed File System
|
|
|
|
%if ( 0%{_for_fedora_koji_builds} )
|
|
|
|
Name: glusterfs
|
|
|
|
Version: 3.8.0
|
|
|
|
Release: 0.1%{?prereltag:.%{prereltag}}%{?dist}
|
|
|
|
%else
|
|
|
|
Name: glusterfs
|
2019-04-08 03:04:00 +00:00
|
|
|
Version: 6.0
|
|
|
|
Release: 1%{?dist}
|
|
|
|
ExcludeArch: i686
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
License: GPLv2 or LGPLv3+
|
2019-04-08 03:04:00 +00:00
|
|
|
URL: http://docs.gluster.org/
|
2017-11-15 13:56:13 +00:00
|
|
|
%if ( 0%{_for_fedora_koji_builds} )
|
|
|
|
Source0: http://bits.gluster.org/pub/gluster/glusterfs/src/glusterfs-%{version}%{?prereltag}.tar.gz
|
|
|
|
Source1: glusterd.sysconfig
|
|
|
|
Source2: glusterfsd.sysconfig
|
|
|
|
Source7: glusterfsd.service
|
|
|
|
Source8: glusterfsd.init
|
|
|
|
%else
|
2019-04-08 03:04:00 +00:00
|
|
|
Source0: glusterfs-6.0.tar.gz
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
|
|
|
|
Requires(pre): shadow-utils
|
|
|
|
%if ( 0%{?_with_systemd:1} )
|
|
|
|
BuildRequires: systemd
|
|
|
|
%endif
|
|
|
|
|
|
|
|
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
|
|
|
%if ( 0%{?_with_systemd:1} )
|
|
|
|
%{?systemd_requires}
|
|
|
|
%endif
|
2019-04-08 03:04:00 +00:00
|
|
|
%if 0%{?_with_asan:1} && !( 0%{?rhel} && 0%{?rhel} < 7 )
|
|
|
|
BuildRequires: libasan
|
|
|
|
%endif
|
|
|
|
%if 0%{?_with_tsan:1} && !( 0%{?rhel} && 0%{?rhel} < 7 )
|
|
|
|
BuildRequires: libtsan
|
|
|
|
%endif
|
2017-11-15 13:56:13 +00:00
|
|
|
BuildRequires: git
|
|
|
|
BuildRequires: bison flex
|
|
|
|
BuildRequires: gcc make libtool
|
|
|
|
BuildRequires: ncurses-devel readline-devel
|
|
|
|
BuildRequires: libxml2-devel openssl-devel
|
|
|
|
BuildRequires: libaio-devel libacl-devel
|
2019-04-08 03:04:00 +00:00
|
|
|
BuildRequires: python%{_pythonver}-devel
|
|
|
|
%if ( 0%{?rhel} && 0%{?rhel} < 8 )
|
2017-11-15 13:56:13 +00:00
|
|
|
BuildRequires: python-ctypes
|
|
|
|
%endif
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{?_with_ipv6default:1} ) || ( 0%{!?_without_libtirpc:1} )
|
|
|
|
BuildRequires: libtirpc-devel
|
|
|
|
%endif
|
|
|
|
%if ( 0%{?fedora} && 0%{?fedora} > 27 ) || ( 0%{?rhel} && 0%{?rhel} > 7 )
|
|
|
|
BuildRequires: rpcgen
|
|
|
|
%endif
|
2017-11-15 13:56:13 +00:00
|
|
|
BuildRequires: userspace-rcu-devel >= 0.7
|
|
|
|
%if ( 0%{?rhel} && 0%{?rhel} <= 6 )
|
|
|
|
BuildRequires: automake
|
|
|
|
%endif
|
|
|
|
BuildRequires: libuuid-devel
|
|
|
|
%if ( 0%{?_with_cmocka:1} )
|
|
|
|
BuildRequires: libcmocka-devel >= 1.0.1
|
|
|
|
%endif
|
|
|
|
%if ( 0%{!?_without_georeplication:1} )
|
|
|
|
BuildRequires: libattr-devel
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%if (0%{?_with_firewalld:1})
|
|
|
|
BuildRequires: firewalld
|
|
|
|
%endif
|
|
|
|
|
|
|
|
Obsoletes: hekafs
|
|
|
|
Obsoletes: %{name}-common < %{version}-%{release}
|
|
|
|
Obsoletes: %{name}-core < %{version}-%{release}
|
|
|
|
Obsoletes: %{name}-ufo
|
2019-04-08 03:04:00 +00:00
|
|
|
Obsoletes: %{name}-ganesha
|
|
|
|
%if ( 0%{!?_with_gnfs:1} )
|
|
|
|
Obsoletes: %{name}-gnfs
|
|
|
|
%endif
|
2017-11-15 13:56:13 +00:00
|
|
|
Provides: %{name}-common = %{version}-%{release}
|
|
|
|
Provides: %{name}-core = %{version}-%{release}
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
# Patch0001: 0001-Update-rfc.sh-to-rhgs-3.5.0.patch
|
2017-11-15 13:56:13 +00:00
|
|
|
Patch0002: 0002-glusterd-fix-op-versions-for-RHS-backwards-compatabi.patch
|
2019-04-08 03:04:00 +00:00
|
|
|
Patch0003: 0003-rpc-set-bind-insecure-to-off-by-default.patch
|
|
|
|
Patch0004: 0004-glusterd-spec-fixing-autogen-issue.patch
|
|
|
|
Patch0005: 0005-libglusterfs-glusterd-Fix-compilation-errors.patch
|
|
|
|
Patch0006: 0006-build-remove-ghost-directory-entries.patch
|
|
|
|
Patch0007: 0007-build-add-RHGS-specific-changes.patch
|
|
|
|
Patch0008: 0008-secalert-remove-setuid-bit-for-fusermount-glusterfs.patch
|
|
|
|
Patch0009: 0009-build-introduce-security-hardening-flags-in-gluster.patch
|
|
|
|
Patch0010: 0010-spec-fix-add-pre-transaction-scripts-for-geo-rep-and.patch
|
|
|
|
Patch0011: 0011-rpm-glusterfs-devel-for-client-builds-should-not-dep.patch
|
|
|
|
Patch0012: 0012-build-add-pretrans-check.patch
|
|
|
|
Patch0013: 0013-glusterd-fix-info-file-checksum-mismatch-during-upgr.patch
|
|
|
|
Patch0014: 0014-build-spec-file-conflict-resolution.patch
|
|
|
|
Patch0015: 0015-build-randomize-temp-file-names-in-pretrans-scriptle.patch
|
|
|
|
Patch0016: 0016-glusterd-parallel-readdir-Change-the-op-version-of-p.patch
|
|
|
|
Patch0017: 0017-glusterd-Revert-op-version-for-cluster.max-brick-per.patch
|
|
|
|
Patch0018: 0018-cli-Add-message-for-user-before-modifying-brick-mult.patch
|
|
|
|
Patch0019: 0019-build-launch-glusterd-upgrade-after-all-new-bits-are.patch
|
|
|
|
Patch0020: 0020-spec-unpackaged-files-found-for-RHEL-7-client-build.patch
|
|
|
|
Patch0021: 0021-cli-glusterfsd-remove-copyright-information.patch
|
|
|
|
Patch0022: 0022-cli-Remove-upstream-doc-reference.patch
|
|
|
|
Patch0023: 0023-hooks-remove-selinux-hooks.patch
|
|
|
|
Patch0024: 0024-glusterd-Make-localtime-logging-option-invisible-in-.patch
|
|
|
|
Patch0025: 0025-build-make-RHGS-version-available-for-server.patch
|
|
|
|
Patch0026: 0026-glusterd-Introduce-daemon-log-level-cluster-wide-opt.patch
|
|
|
|
Patch0027: 0027-glusterd-change-op-version-of-fips-mode-rchecksum.patch
|
|
|
|
Patch0028: 0028-glusterd-Reset-op-version-for-features.shard-deletio.patch
|
|
|
|
Patch0029: 0029-glusterd-Reset-op-version-for-features.shard-lru-lim.patch
|
|
|
|
Patch0030: 0030-selinux-glusterd-add-features.selinux-to-glusterd-vo.patch
|
|
|
|
Patch0031: 0031-glusterd-turn-off-selinux-feature-in-downstream.patch
|
|
|
|
Patch0032: 0032-glusterd-update-gd-op-version-to-3_7_0.patch
|
|
|
|
Patch0033: 0033-build-add-missing-explicit-package-dependencies.patch
|
|
|
|
Patch0034: 0034-glusterd-introduce-a-new-op-version-for-rhgs-3.4.3.patch
|
|
|
|
Patch0035: 0035-glusterd-tag-rebalance-mgmt_v3-command-to-op-version.patch
|
|
|
|
Patch0036: 0036-build-add-conditional-dependency-on-server-for-devel.patch
|
|
|
|
Patch0037: 0037-cli-change-the-warning-message.patch
|
|
|
|
Patch0038: 0038-spec-avoid-creation-of-temp-file-in-lua-script.patch
|
|
|
|
Patch0039: 0039-cli-fix-query-to-user-during-brick-mux-selection.patch
|
|
|
|
Patch0040: 0040-build-Remove-unsupported-test-cases-failing-consiste.patch
|
|
|
|
Patch0041: 0041-tests-geo-rep-Build-failed-in-Jenkins-for-test-bug-1.patch
|
|
|
|
Patch0042: 0042-spec-client-server-Builds-are-failing-on-rhel-6.patch
|
|
|
|
Patch0043: 0043-inode-don-t-dump-the-whole-table-to-CLI.patch
|
|
|
|
Patch0044: 0044-cluster-ec-Don-t-enqueue-an-entry-if-it-is-already-h.patch
|
|
|
|
Patch0045: 0045-glusterd-fix-txn-id-mem-leak.patch
|
|
|
|
Patch0046: 0046-protocol-client-Do-not-fallback-to-anon-fd-if-fd-is-.patch
|
|
|
|
Patch0047: 0047-client-rpc-Fix-the-payload-being-sent-on-the-wire.patch
|
|
|
|
Patch0048: 0048-gfapi-Unblock-epoll-thread-for-upcall-processing.patch
|
|
|
|
Patch0049: 0049-transport-socket-log-shutdown-msg-occasionally.patch
|
|
|
|
Patch0050: 0050-geo-rep-Fix-syncing-multiple-rename-of-symlink.patch
|
|
|
|
Patch0051: 0051-spec-update-rpm-install-condition.patch
|
|
|
|
Patch0052: 0052-geo-rep-IPv6-support.patch
|
2017-11-15 13:56:13 +00:00
|
|
|
|
|
|
|
%description
|
|
|
|
GlusterFS is a distributed file-system capable of scaling to several
|
|
|
|
petabytes. It aggregates various storage bricks over Infiniband RDMA
|
|
|
|
or TCP/IP interconnect into one large parallel network file
|
|
|
|
system. GlusterFS is one of the most sophisticated file systems in
|
|
|
|
terms of features and extensibility. It borrows a powerful concept
|
|
|
|
called Translators from GNU Hurd kernel. Much of the code in GlusterFS
|
|
|
|
is in user space and easily manageable.
|
|
|
|
|
|
|
|
This package includes the glusterfs binary, the glusterfsd daemon and the
|
|
|
|
libglusterfs and glusterfs translator modules common to both GlusterFS server
|
|
|
|
and client framework.
|
|
|
|
|
|
|
|
%package api
|
|
|
|
Summary: GlusterFS api library
|
|
|
|
Requires: %{name}%{?_isa} = %{version}-%{release}
|
|
|
|
Requires: %{name}-client-xlators%{?_isa} = %{version}-%{release}
|
2018-12-18 16:23:13 +00:00
|
|
|
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
2017-11-15 13:56:13 +00:00
|
|
|
|
|
|
|
%description api
|
|
|
|
GlusterFS is a distributed file-system capable of scaling to several
|
|
|
|
petabytes. It aggregates various storage bricks over Infiniband RDMA
|
|
|
|
or TCP/IP interconnect into one large parallel network file
|
|
|
|
system. GlusterFS is one of the most sophisticated file systems in
|
|
|
|
terms of features and extensibility. It borrows a powerful concept
|
|
|
|
called Translators from GNU Hurd kernel. Much of the code in GlusterFS
|
|
|
|
is in user space and easily manageable.
|
|
|
|
|
|
|
|
This package provides the glusterfs libgfapi library.
|
|
|
|
|
|
|
|
%package api-devel
|
|
|
|
Summary: Development Libraries
|
|
|
|
Requires: %{name}%{?_isa} = %{version}-%{release}
|
|
|
|
Requires: %{name}-devel%{?_isa} = %{version}-%{release}
|
|
|
|
Requires: libacl-devel
|
2018-12-18 16:23:13 +00:00
|
|
|
Requires: %{name}-api%{?_isa} = %{version}-%{release}
|
2017-11-15 13:56:13 +00:00
|
|
|
|
|
|
|
%description api-devel
|
|
|
|
GlusterFS is a distributed file-system capable of scaling to several
|
|
|
|
petabytes. It aggregates various storage bricks over Infiniband RDMA
|
|
|
|
or TCP/IP interconnect into one large parallel network file
|
|
|
|
system. GlusterFS is one of the most sophisticated file systems in
|
|
|
|
terms of features and extensibility. It borrows a powerful concept
|
|
|
|
called Translators from GNU Hurd kernel. Much of the code in GlusterFS
|
|
|
|
is in user space and easily manageable.
|
|
|
|
|
|
|
|
This package provides the api include files.
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{!?_without_server:1} )
|
2017-11-15 13:56:13 +00:00
|
|
|
%package cli
|
|
|
|
Summary: GlusterFS CLI
|
|
|
|
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
|
|
|
|
|
|
|
%description cli
|
|
|
|
GlusterFS is a distributed file-system capable of scaling to several
|
|
|
|
petabytes. It aggregates various storage bricks over Infiniband RDMA
|
|
|
|
or TCP/IP interconnect into one large parallel network file
|
|
|
|
system. GlusterFS is one of the most sophisticated file systems in
|
|
|
|
terms of features and extensibility. It borrows a powerful concept
|
|
|
|
called Translators from GNU Hurd kernel. Much of the code in GlusterFS
|
|
|
|
is in user space and easily manageable.
|
|
|
|
|
|
|
|
This package provides the GlusterFS CLI application and its man page
|
2019-04-08 03:04:00 +00:00
|
|
|
%endif
|
|
|
|
|
|
|
|
%package cloudsync-plugins
|
|
|
|
Summary: Cloudsync Plugins
|
|
|
|
BuildRequires: libcurl-devel
|
|
|
|
|
|
|
|
%description cloudsync-plugins
|
|
|
|
GlusterFS is a distributed file-system capable of scaling to several
|
|
|
|
petabytes. It aggregates various storage bricks over Infiniband RDMA
|
|
|
|
or TCP/IP interconnect into one large parallel network file
|
|
|
|
system. GlusterFS is one of the most sophisticated file systems in
|
|
|
|
terms of features and extensibility. It borrows a powerful concept
|
|
|
|
called Translators from GNU Hurd kernel. Much of the code in GlusterFS
|
|
|
|
is in user space and easily manageable.
|
|
|
|
|
|
|
|
This package provides cloudsync plugins for archival feature.
|
2017-11-15 13:56:13 +00:00
|
|
|
|
|
|
|
%package devel
|
|
|
|
Summary: Development Libraries
|
|
|
|
Requires: %{name}%{?_isa} = %{version}-%{release}
|
|
|
|
# Needed for the Glupy examples to work
|
|
|
|
%if ( 0%{!?_without_extra_xlators:1} )
|
2019-04-08 03:04:00 +00:00
|
|
|
Requires: %{name}-extra-xlators%{?_isa} = %{version}-%{release}
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
2018-12-18 16:23:13 +00:00
|
|
|
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{!?_without_server:1} )
|
2018-12-18 16:23:13 +00:00
|
|
|
Requires: %{name}-server%{?_isa} = %{version}-%{release}
|
2018-12-19 08:26:48 +00:00
|
|
|
%endif
|
2017-11-15 13:56:13 +00:00
|
|
|
|
|
|
|
%description devel
|
|
|
|
GlusterFS is a distributed file-system capable of scaling to several
|
|
|
|
petabytes. It aggregates various storage bricks over Infiniband RDMA
|
|
|
|
or TCP/IP interconnect into one large parallel network file
|
|
|
|
system. GlusterFS is one of the most sophisticated file systems in
|
|
|
|
terms of features and extensibility. It borrows a powerful concept
|
|
|
|
called Translators from GNU Hurd kernel. Much of the code in GlusterFS
|
|
|
|
is in user space and easily manageable.
|
|
|
|
|
|
|
|
This package provides the development libraries and include files.
|
|
|
|
|
|
|
|
%if ( 0%{!?_without_extra_xlators:1} )
|
|
|
|
%package extra-xlators
|
|
|
|
Summary: Extra Gluster filesystem Translators
|
|
|
|
# We need python-gluster rpm for gluster module's __init__.py in Python
|
|
|
|
# site-packages area
|
2019-04-08 03:04:00 +00:00
|
|
|
Requires: python%{_pythonver}-gluster = %{version}-%{release}
|
|
|
|
Requires: python%{_pythonver}
|
2017-11-15 13:56:13 +00:00
|
|
|
|
|
|
|
%description extra-xlators
|
|
|
|
GlusterFS is a distributed file-system capable of scaling to several
|
|
|
|
petabytes. It aggregates various storage bricks over Infiniband RDMA
|
|
|
|
or TCP/IP interconnect into one large parallel network file
|
|
|
|
system. GlusterFS is one of the most sophisticated file systems in
|
|
|
|
terms of features and extensibility. It borrows a powerful concept
|
|
|
|
called Translators from GNU Hurd kernel. Much of the code in GlusterFS
|
|
|
|
is in user space and easily manageable.
|
|
|
|
|
|
|
|
This package provides extra filesystem Translators, such as Glupy,
|
|
|
|
for GlusterFS.
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%package fuse
|
|
|
|
Summary: Fuse client
|
|
|
|
BuildRequires: fuse-devel
|
|
|
|
Requires: attr
|
|
|
|
Requires: psmisc
|
|
|
|
|
|
|
|
Requires: %{name}%{?_isa} = %{version}-%{release}
|
|
|
|
Requires: %{name}-client-xlators%{?_isa} = %{version}-%{release}
|
|
|
|
|
|
|
|
Obsoletes: %{name}-client < %{version}-%{release}
|
|
|
|
Provides: %{name}-client = %{version}-%{release}
|
2018-12-18 16:23:13 +00:00
|
|
|
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
2017-11-15 13:56:13 +00:00
|
|
|
|
|
|
|
%description fuse
|
|
|
|
GlusterFS is a distributed file-system capable of scaling to several
|
|
|
|
petabytes. It aggregates various storage bricks over Infiniband RDMA
|
|
|
|
or TCP/IP interconnect into one large parallel network file
|
|
|
|
system. GlusterFS is one of the most sophisticated file systems in
|
|
|
|
terms of features and extensibility. It borrows a powerful concept
|
|
|
|
called Translators from GNU Hurd kernel. Much of the code in GlusterFS
|
|
|
|
is in user space and easily manageable.
|
|
|
|
|
|
|
|
This package provides support to FUSE based clients and inlcudes the
|
|
|
|
glusterfs(d) binary.
|
|
|
|
|
|
|
|
%if ( 0%{!?_without_georeplication:1} )
|
|
|
|
%package geo-replication
|
|
|
|
Summary: GlusterFS Geo-replication
|
|
|
|
Requires: %{name}%{?_isa} = %{version}-%{release}
|
|
|
|
Requires: %{name}-server%{?_isa} = %{version}-%{release}
|
2019-04-08 03:04:00 +00:00
|
|
|
Requires: python%{_pythonver}
|
|
|
|
Requires: python%{_pythonver}-prettytable
|
|
|
|
Requires: python%{_pythonver}-gluster = %{version}-%{release}
|
|
|
|
|
2017-11-15 13:56:13 +00:00
|
|
|
Requires: rsync
|
2018-03-07 13:56:57 +00:00
|
|
|
Requires: util-linux
|
2018-12-18 16:23:13 +00:00
|
|
|
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
2017-11-15 13:56:13 +00:00
|
|
|
|
|
|
|
%description geo-replication
|
|
|
|
GlusterFS is a distributed file-system capable of scaling to several
|
|
|
|
peta-bytes. It aggregates various storage bricks over Infiniband RDMA
|
|
|
|
or TCP/IP interconnect into one large parallel network file
|
|
|
|
system. GlusterFS is one of the most sophisticated file system in
|
|
|
|
terms of features and extensibility. It borrows a powerful concept
|
|
|
|
called Translators from GNU Hurd kernel. Much of the code in GlusterFS
|
|
|
|
is in userspace and easily manageable.
|
|
|
|
|
|
|
|
This package provides support to geo-replication.
|
|
|
|
%endif
|
2019-04-08 03:04:00 +00:00
|
|
|
|
|
|
|
%if ( 0%{?_with_gnfs:1} )
|
|
|
|
%package gnfs
|
|
|
|
Summary: GlusterFS gNFS server
|
|
|
|
Requires: %{name}%{?_isa} = %{version}-%{release}
|
|
|
|
Requires: %{name}-client-xlators%{?_isa} = %{version}-%{release}
|
|
|
|
Requires: nfs-utils
|
|
|
|
|
|
|
|
%description gnfs
|
|
|
|
GlusterFS is a distributed file-system capable of scaling to several
|
|
|
|
petabytes. It aggregates various storage bricks over Infiniband RDMA
|
|
|
|
or TCP/IP interconnect into one large parallel network file
|
|
|
|
system. GlusterFS is one of the most sophisticated file systems in
|
|
|
|
terms of features and extensibility. It borrows a powerful concept
|
|
|
|
called Translators from GNU Hurd kernel. Much of the code in GlusterFS
|
|
|
|
is in user space and easily manageable.
|
|
|
|
|
|
|
|
This package provides the glusterfs legacy gNFS server xlator
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
|
|
|
|
%package libs
|
|
|
|
Summary: GlusterFS common libraries
|
|
|
|
|
|
|
|
%description libs
|
|
|
|
GlusterFS is a distributed file-system capable of scaling to several
|
|
|
|
petabytes. It aggregates various storage bricks over Infiniband RDMA
|
|
|
|
or TCP/IP interconnect into one large parallel network file
|
|
|
|
system. GlusterFS is one of the most sophisticated file systems in
|
|
|
|
terms of features and extensibility. It borrows a powerful concept
|
|
|
|
called Translators from GNU Hurd kernel. Much of the code in GlusterFS
|
|
|
|
is in user space and easily manageable.
|
|
|
|
|
|
|
|
This package provides the base GlusterFS libraries
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
%package -n python%{_pythonver}-gluster
|
2017-11-15 13:56:13 +00:00
|
|
|
Summary: GlusterFS python library
|
2019-04-08 03:04:00 +00:00
|
|
|
Requires: python%{_pythonver}
|
|
|
|
%if ( ! %{_usepython3} )
|
|
|
|
%{?python_provide:%python_provide python-gluster}
|
2017-11-15 13:56:13 +00:00
|
|
|
Provides: python-gluster = %{version}-%{release}
|
|
|
|
Obsoletes: python-gluster < 3.10
|
2019-04-08 03:04:00 +00:00
|
|
|
%endif
|
|
|
|
|
|
|
|
%description -n python%{_pythonver}-gluster
|
|
|
|
GlusterFS is a distributed file-system capable of scaling to several
|
|
|
|
petabytes. It aggregates various storage bricks over Infiniband RDMA
|
|
|
|
or TCP/IP interconnect into one large parallel network file
|
|
|
|
system. GlusterFS is one of the most sophisticated file systems in
|
|
|
|
terms of features and extensibility. It borrows a powerful concept
|
|
|
|
called Translators from GNU Hurd kernel. Much of the code in GlusterFS
|
|
|
|
is in user space and easily manageable.
|
2017-11-15 13:56:13 +00:00
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
This package contains the python modules of GlusterFS and own gluster
|
|
|
|
namespace.
|
2017-11-15 13:56:13 +00:00
|
|
|
|
|
|
|
%if ( 0%{!?_without_rdma:1} )
|
|
|
|
%package rdma
|
|
|
|
Summary: GlusterFS rdma support for ib-verbs
|
|
|
|
%if ( 0%{?fedora} && 0%{?fedora} > 26 )
|
|
|
|
BuildRequires: rdma-core-devel
|
|
|
|
%else
|
|
|
|
BuildRequires: libibverbs-devel
|
|
|
|
BuildRequires: librdmacm-devel >= 1.0.15
|
|
|
|
%endif
|
|
|
|
Requires: %{name}%{?_isa} = %{version}-%{release}
|
2018-12-18 16:23:13 +00:00
|
|
|
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
2017-11-15 13:56:13 +00:00
|
|
|
|
|
|
|
%description rdma
|
|
|
|
GlusterFS is a distributed file-system capable of scaling to several
|
|
|
|
petabytes. It aggregates various storage bricks over Infiniband RDMA
|
|
|
|
or TCP/IP interconnect into one large parallel network file
|
|
|
|
system. GlusterFS is one of the most sophisticated file systems in
|
|
|
|
terms of features and extensibility. It borrows a powerful concept
|
|
|
|
called Translators from GNU Hurd kernel. Much of the code in GlusterFS
|
|
|
|
is in user space and easily manageable.
|
|
|
|
|
|
|
|
This package provides support to ib-verbs library.
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%if ( 0%{!?_without_regression_tests:1} )
|
|
|
|
%package regression-tests
|
|
|
|
Summary: Development Tools
|
|
|
|
Requires: %{name}%{?_isa} = %{version}-%{release}
|
|
|
|
Requires: %{name}-fuse%{?_isa} = %{version}-%{release}
|
|
|
|
Requires: %{name}-server%{?_isa} = %{version}-%{release}
|
|
|
|
## thin provisioning support
|
|
|
|
Requires: lvm2 >= 2.02.89
|
|
|
|
Requires: perl(App::Prove) perl(Test::Harness) gcc util-linux-ng
|
2019-04-08 03:04:00 +00:00
|
|
|
Requires: python%{_pythonver}
|
|
|
|
Requires: attr dbench file git libacl-devel net-tools
|
2017-11-15 13:56:13 +00:00
|
|
|
Requires: nfs-utils xfsprogs yajl psmisc bc
|
|
|
|
|
|
|
|
%description regression-tests
|
|
|
|
The Gluster Test Framework, is a suite of scripts used for
|
|
|
|
regression testing of Gluster.
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%if ( 0%{!?_without_ocf:1} )
|
|
|
|
%package resource-agents
|
|
|
|
Summary: OCF Resource Agents for GlusterFS
|
|
|
|
License: GPLv3+
|
|
|
|
BuildArch: noarch
|
|
|
|
# this Group handling comes from the Fedora resource-agents package
|
|
|
|
# for glusterd
|
|
|
|
Requires: %{name}-server = %{version}-%{release}
|
|
|
|
# depending on the distribution, we need pacemaker or resource-agents
|
|
|
|
Requires: %{_prefix}/lib/ocf/resource.d
|
|
|
|
|
|
|
|
%description resource-agents
|
|
|
|
GlusterFS is a distributed file-system capable of scaling to several
|
|
|
|
petabytes. It aggregates various storage bricks over Infiniband RDMA
|
|
|
|
or TCP/IP interconnect into one large parallel network file
|
|
|
|
system. GlusterFS is one of the most sophisticated file systems in
|
|
|
|
terms of features and extensibility. It borrows a powerful concept
|
|
|
|
called Translators from GNU Hurd kernel. Much of the code in GlusterFS
|
|
|
|
is in user space and easily manageable.
|
|
|
|
|
|
|
|
This package provides the resource agents which plug glusterd into
|
|
|
|
Open Cluster Framework (OCF) compliant cluster resource managers,
|
|
|
|
like Pacemaker.
|
|
|
|
%endif
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{!?_without_server:1} )
|
2017-11-15 13:56:13 +00:00
|
|
|
%package server
|
|
|
|
Summary: Clustered file-system server
|
|
|
|
Requires: %{name}%{?_isa} = %{version}-%{release}
|
|
|
|
Requires: %{name}-cli%{?_isa} = %{version}-%{release}
|
|
|
|
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
|
|
|
# some daemons (like quota) use a fuse-mount, glusterfsd is part of -fuse
|
|
|
|
Requires: %{name}-fuse%{?_isa} = %{version}-%{release}
|
|
|
|
# self-heal daemon, rebalance, nfs-server etc. are actually clients
|
|
|
|
Requires: %{name}-api%{?_isa} = %{version}-%{release}
|
|
|
|
Requires: %{name}-client-xlators%{?_isa} = %{version}-%{release}
|
|
|
|
# lvm2 for snapshot, and nfs-utils and rpcbind/portmap for gnfs server
|
|
|
|
Requires: lvm2
|
|
|
|
%if ( 0%{?_with_systemd:1} )
|
|
|
|
%{?systemd_requires}
|
|
|
|
%else
|
|
|
|
Requires(post): /sbin/chkconfig
|
|
|
|
Requires(preun): /sbin/service
|
|
|
|
Requires(preun): /sbin/chkconfig
|
|
|
|
Requires(postun): /sbin/service
|
|
|
|
%endif
|
|
|
|
%if (0%{?_with_firewalld:1})
|
|
|
|
# we install firewalld rules, so we need to have the directory owned
|
|
|
|
%if ( 0%{!?rhel} )
|
|
|
|
# not on RHEL because firewalld-filesystem appeared in 7.3
|
|
|
|
# when EL7 rpm gets weak dependencies we can add a Suggests:
|
|
|
|
Requires: firewalld-filesystem
|
|
|
|
%endif
|
|
|
|
%endif
|
|
|
|
%if ( 0%{?fedora} ) || ( 0%{?rhel} && 0%{?rhel} >= 6 )
|
|
|
|
Requires: rpcbind
|
|
|
|
%else
|
|
|
|
Requires: portmap
|
|
|
|
%endif
|
|
|
|
%if ( 0%{?rhel} && 0%{?rhel} <= 6 )
|
|
|
|
Requires: python-argparse
|
|
|
|
%endif
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{?fedora} && 0%{?fedora} > 27 ) || ( 0%{?rhel} && 0%{?rhel} > 7 )
|
|
|
|
Requires: python%{_pythonver}-pyxattr
|
|
|
|
%else
|
2017-11-15 13:56:13 +00:00
|
|
|
Requires: pyxattr
|
2019-04-08 03:04:00 +00:00
|
|
|
%endif
|
2017-11-15 13:56:13 +00:00
|
|
|
%if (0%{?_with_valgrind:1})
|
|
|
|
Requires: valgrind
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%description server
|
|
|
|
GlusterFS is a distributed file-system capable of scaling to several
|
|
|
|
petabytes. It aggregates various storage bricks over Infiniband RDMA
|
|
|
|
or TCP/IP interconnect into one large parallel network file
|
|
|
|
system. GlusterFS is one of the most sophisticated file systems in
|
|
|
|
terms of features and extensibility. It borrows a powerful concept
|
|
|
|
called Translators from GNU Hurd kernel. Much of the code in GlusterFS
|
|
|
|
is in user space and easily manageable.
|
|
|
|
|
|
|
|
This package provides the glusterfs server daemon.
|
|
|
|
%endif
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
%package thin-arbiter
|
|
|
|
Summary: GlusterFS thin-arbiter module
|
|
|
|
Requires: %{name}%{?_isa} = %{version}-%{release}
|
|
|
|
Requires: %{name}-server%{?_isa} = %{version}-%{release}
|
|
|
|
|
|
|
|
%description thin-arbiter
|
|
|
|
This package provides a tie-breaker functionality to GlusterFS
|
|
|
|
replicate volume. It includes translators required to provide the
|
|
|
|
functionality, and also few other scripts required for getting the setup done.
|
|
|
|
|
|
|
|
This package provides the glusterfs thin-arbiter translator.
|
|
|
|
|
2017-11-15 13:56:13 +00:00
|
|
|
%package client-xlators
|
|
|
|
Summary: GlusterFS client-side translators
|
2018-12-18 16:23:13 +00:00
|
|
|
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
2017-11-15 13:56:13 +00:00
|
|
|
|
|
|
|
%description client-xlators
|
|
|
|
GlusterFS is a distributed file-system capable of scaling to several
|
|
|
|
petabytes. It aggregates various storage bricks over Infiniband RDMA
|
|
|
|
or TCP/IP interconnect into one large parallel network file
|
|
|
|
system. GlusterFS is one of the most sophisticated file systems in
|
|
|
|
terms of features and extensibility. It borrows a powerful concept
|
|
|
|
called Translators from GNU Hurd kernel. Much of the code in GlusterFS
|
|
|
|
is in user space and easily manageable.
|
|
|
|
|
|
|
|
This package provides the translators needed on any GlusterFS client.
|
|
|
|
|
|
|
|
%if ( 0%{!?_without_events:1} )
|
|
|
|
%package events
|
|
|
|
Summary: GlusterFS Events
|
|
|
|
Requires: %{name}-server%{?_isa} = %{version}-%{release}
|
2019-04-08 03:04:00 +00:00
|
|
|
Requires: python%{_pythonver} python%{_pythonver}-prettytable
|
|
|
|
Requires: python%{_pythonver}-gluster = %{version}-%{release}
|
|
|
|
%if ( 0%{?rhel} && 0%{?rhel} < 8 )
|
2017-11-15 13:56:13 +00:00
|
|
|
Requires: python-requests
|
|
|
|
%else
|
2019-04-08 03:04:00 +00:00
|
|
|
Requires: python%{_pythonver}-requests
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
%if ( 0%{?rhel} && 0%{?rhel} < 7 )
|
|
|
|
Requires: python-argparse
|
|
|
|
%endif
|
|
|
|
%if ( 0%{?_with_systemd:1} )
|
|
|
|
%{?systemd_requires}
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%description events
|
|
|
|
GlusterFS Events
|
|
|
|
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%prep
|
|
|
|
%setup -q -n %{name}-%{version}%{?prereltag}
|
|
|
|
|
|
|
|
# sanitization scriptlet for patches with file renames
|
|
|
|
ls %{_topdir}/SOURCES/*.patch | sort | \
|
|
|
|
while read p
|
|
|
|
do
|
|
|
|
# if the destination file exists, its most probably stale
|
|
|
|
# so we must remove it
|
2019-02-12 01:46:22 +00:00
|
|
|
rename_to=( $(grep -i 'rename to' $p | cut -f 3 -d ' ') )
|
2017-11-15 13:56:13 +00:00
|
|
|
if [ ${#rename_to[*]} -gt 0 ]; then
|
|
|
|
for f in ${rename_to[*]}
|
|
|
|
do
|
|
|
|
if [ -f $f ]; then
|
|
|
|
rm -f $f
|
|
|
|
elif [ -d $f ]; then
|
|
|
|
rm -rf $f
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
|
|
|
|
SOURCE_FILES=( $(egrep '^\-\-\- a/' $p | cut -f 2- -d '/') )
|
|
|
|
DEST_FILES=( $(egrep '^\+\+\+ b/' $p | cut -f 2- -d '/') )
|
|
|
|
EXCLUDE_DOCS=()
|
|
|
|
for idx in ${!SOURCE_FILES[@]}; do
|
|
|
|
# skip the doc
|
|
|
|
source_file=${SOURCE_FILES[$idx]}
|
|
|
|
dest_file=${DEST_FILES[$idx]}
|
|
|
|
if [[ "$dest_file" =~ ^doc/.+ ]]; then
|
|
|
|
if [ "$source_file" != "dev/null" ] && [ ! -f "$dest_file" ]; then
|
|
|
|
# if patch is being applied to a doc file and if the doc file
|
|
|
|
# hasn't been added so far then we need to exclude it
|
|
|
|
EXCLUDE_DOCS=( ${EXCLUDE_DOCS[*]} "$dest_file" )
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
EXCLUDE_DOCS_OPT=""
|
|
|
|
for doc in ${EXCLUDE_DOCS}; do
|
|
|
|
EXCLUDE_DOCS_OPT="--exclude=$doc $EXCLUDE_DOCS_OPT"
|
|
|
|
done
|
|
|
|
# apply the patch with 'git apply'
|
|
|
|
git apply -p1 --exclude=rfc.sh \
|
|
|
|
--exclude=.gitignore \
|
2018-07-18 12:38:52 +00:00
|
|
|
--exclude=.testignore \
|
2017-11-15 13:56:13 +00:00
|
|
|
--exclude=MAINTAINERS \
|
|
|
|
--exclude=extras/checkpatch.pl \
|
|
|
|
--exclude=build-aux/checkpatch.pl \
|
|
|
|
--exclude='tests/*' \
|
|
|
|
${EXCLUDE_DOCS_OPT} \
|
|
|
|
$p
|
|
|
|
done
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( ! %{_usepython3} )
|
|
|
|
echo "fixing python shebangs..."
|
|
|
|
for f in api events extras geo-replication libglusterfs tools xlators; do
|
|
|
|
find $f -type f -exec sed -i 's|/usr/bin/python3|/usr/bin/python2|' {} \;
|
|
|
|
done
|
|
|
|
%endif
|
2017-11-15 13:56:13 +00:00
|
|
|
|
|
|
|
%build
|
2019-04-08 03:04:00 +00:00
|
|
|
|
2017-11-15 13:56:13 +00:00
|
|
|
# In RHEL7 few hardening flags are available by default, however the RELRO
|
|
|
|
# default behaviour is partial, convert to full
|
|
|
|
%if ( 0%{?rhel} && 0%{?rhel} >= 7 )
|
|
|
|
LDFLAGS="$RPM_LD_FLAGS -Wl,-z,relro,-z,now"
|
|
|
|
export LDFLAGS
|
|
|
|
%else
|
|
|
|
%if ( 0%{?rhel} && 0%{?rhel} == 6 )
|
|
|
|
CFLAGS="$RPM_OPT_FLAGS -fPIE -DPIE"
|
|
|
|
LDFLAGS="$RPM_LD_FLAGS -pie -Wl,-z,relro,-z,now"
|
|
|
|
%else
|
|
|
|
#It appears that with gcc-4.1.2 in RHEL5 there is an issue using both -fPIC and
|
|
|
|
# -fPIE that makes -z relro not work; -fPIE seems to undo what -fPIC does
|
|
|
|
CFLAGS="$CFLAGS $RPM_OPT_FLAGS"
|
|
|
|
LDFLAGS="$RPM_LD_FLAGS -Wl,-z,relro,-z,now"
|
|
|
|
%endif
|
|
|
|
export CFLAGS
|
|
|
|
export LDFLAGS
|
|
|
|
%endif
|
|
|
|
|
|
|
|
./autogen.sh && %configure \
|
2019-04-08 03:04:00 +00:00
|
|
|
%{?_with_asan} \
|
2017-11-15 13:56:13 +00:00
|
|
|
%{?_with_cmocka} \
|
|
|
|
%{?_with_debug} \
|
2019-04-08 03:04:00 +00:00
|
|
|
%{?_with_firewalld} \
|
|
|
|
%{?_with_gnfs} \
|
2017-11-15 13:56:13 +00:00
|
|
|
%{?_with_tmpfilesdir} \
|
2019-04-08 03:04:00 +00:00
|
|
|
%{?_with_tsan} \
|
|
|
|
%{?_with_valgrind} \
|
2017-11-15 13:56:13 +00:00
|
|
|
%{?_without_epoll} \
|
2019-04-08 03:04:00 +00:00
|
|
|
%{?_without_events} \
|
2017-11-15 13:56:13 +00:00
|
|
|
%{?_without_fusermount} \
|
|
|
|
%{?_without_georeplication} \
|
|
|
|
%{?_without_ocf} \
|
|
|
|
%{?_without_rdma} \
|
2019-04-08 03:04:00 +00:00
|
|
|
%{?_without_server} \
|
2017-11-15 13:56:13 +00:00
|
|
|
%{?_without_syslog} \
|
2019-04-08 03:04:00 +00:00
|
|
|
%{?_with_ipv6default} \
|
|
|
|
%{?_without_libtirpc}
|
2017-11-15 13:56:13 +00:00
|
|
|
|
|
|
|
# fix hardening and remove rpath in shlibs
|
|
|
|
%if ( 0%{?fedora} && 0%{?fedora} > 17 ) || ( 0%{?rhel} && 0%{?rhel} > 6 )
|
|
|
|
sed -i 's| \\\$compiler_flags |&\\\$LDFLAGS |' libtool
|
|
|
|
%endif
|
|
|
|
sed -i 's|^hardcode_libdir_flag_spec=.*|hardcode_libdir_flag_spec=""|' libtool
|
|
|
|
sed -i 's|^runpath_var=LD_RUN_PATH|runpath_var=DIE_RPATH_DIE|' libtool
|
|
|
|
|
|
|
|
make %{?_smp_mflags}
|
|
|
|
|
|
|
|
%check
|
|
|
|
make check
|
|
|
|
|
|
|
|
%install
|
|
|
|
rm -rf %{buildroot}
|
|
|
|
make install DESTDIR=%{buildroot}
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{!?_without_server:1} )
|
2017-11-15 13:56:13 +00:00
|
|
|
%if ( 0%{_for_fedora_koji_builds} )
|
|
|
|
install -D -p -m 0644 %{SOURCE1} \
|
|
|
|
%{buildroot}%{_sysconfdir}/sysconfig/glusterd
|
|
|
|
install -D -p -m 0644 %{SOURCE2} \
|
|
|
|
%{buildroot}%{_sysconfdir}/sysconfig/glusterfsd
|
|
|
|
%else
|
|
|
|
install -D -p -m 0644 extras/glusterd-sysconfig \
|
|
|
|
%{buildroot}%{_sysconfdir}/sysconfig/glusterd
|
|
|
|
%endif
|
|
|
|
%endif
|
|
|
|
|
|
|
|
mkdir -p %{buildroot}%{_localstatedir}/log/glusterd
|
|
|
|
mkdir -p %{buildroot}%{_localstatedir}/log/glusterfs
|
|
|
|
mkdir -p %{buildroot}%{_localstatedir}/log/glusterfsd
|
|
|
|
mkdir -p %{buildroot}%{_rundir}/gluster
|
|
|
|
|
|
|
|
# Remove unwanted files from all the shared libraries
|
|
|
|
find %{buildroot}%{_libdir} -name '*.a' -delete
|
|
|
|
find %{buildroot}%{_libdir} -name '*.la' -delete
|
|
|
|
|
|
|
|
# Remove installed docs, the ones we want are included by %%doc, in
|
|
|
|
# /usr/share/doc/glusterfs or /usr/share/doc/glusterfs-x.y.z depending
|
|
|
|
# on the distribution
|
|
|
|
%if ( 0%{?fedora} && 0%{?fedora} > 19 ) || ( 0%{?rhel} && 0%{?rhel} > 6 )
|
|
|
|
rm -rf %{buildroot}%{_pkgdocdir}/*
|
|
|
|
%else
|
|
|
|
rm -rf %{buildroot}%{_defaultdocdir}/%{name}
|
|
|
|
mkdir -p %{buildroot}%{_pkgdocdir}
|
|
|
|
%endif
|
|
|
|
head -50 ChangeLog > ChangeLog.head && mv ChangeLog.head ChangeLog
|
|
|
|
cat << EOM >> ChangeLog
|
|
|
|
|
|
|
|
More commit messages for this ChangeLog can be found at
|
|
|
|
https://forge.gluster.org/glusterfs-core/glusterfs/commits/v%{version}%{?prereltag}
|
|
|
|
EOM
|
|
|
|
|
|
|
|
# Remove benchmarking and other unpackaged files
|
|
|
|
# make install always puts these in %%{_defaultdocdir}/%%{name} so don't
|
|
|
|
# use %%{_pkgdocdir}; that will be wrong on later Fedora distributions
|
|
|
|
rm -rf %{buildroot}%{_defaultdocdir}/%{name}/benchmarking
|
|
|
|
rm -f %{buildroot}%{_defaultdocdir}/%{name}/glusterfs-mode.el
|
|
|
|
rm -f %{buildroot}%{_defaultdocdir}/%{name}/glusterfs.vim
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{!?_without_server:1} )
|
2017-11-15 13:56:13 +00:00
|
|
|
# Create working directory
|
|
|
|
mkdir -p %{buildroot}%{_sharedstatedir}/glusterd
|
|
|
|
|
|
|
|
# Update configuration file to /var/lib working directory
|
|
|
|
sed -i 's|option working-directory /etc/glusterd|option working-directory %{_sharedstatedir}/glusterd|g' \
|
|
|
|
%{buildroot}%{_sysconfdir}/glusterfs/glusterd.vol
|
2019-04-08 03:04:00 +00:00
|
|
|
%endif
|
2017-11-15 13:56:13 +00:00
|
|
|
|
|
|
|
# Install glusterfsd .service or init.d file
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{!?_without_server:1} )
|
2017-11-15 13:56:13 +00:00
|
|
|
%if ( 0%{_for_fedora_koji_builds} )
|
2019-04-08 03:04:00 +00:00
|
|
|
%service_install glusterfsd %{glusterfsd_svcfile}
|
|
|
|
%endif
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
|
|
|
|
install -D -p -m 0644 extras/glusterfs-logrotate \
|
|
|
|
%{buildroot}%{_sysconfdir}/logrotate.d/glusterfs
|
|
|
|
|
|
|
|
%if ( 0%{!?_without_georeplication:1} )
|
|
|
|
mkdir -p %{buildroot}%{_sharedstatedir}/glusterd/geo-replication
|
|
|
|
touch %{buildroot}%{_sharedstatedir}/glusterd/geo-replication/gsyncd_template.conf
|
|
|
|
install -D -p -m 0644 extras/glusterfs-georep-logrotate \
|
|
|
|
%{buildroot}%{_sysconfdir}/logrotate.d/glusterfs-georep
|
|
|
|
%endif
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{!?_without_server:1} )
|
2017-11-15 13:56:13 +00:00
|
|
|
touch %{buildroot}%{_sharedstatedir}/glusterd/glusterd.info
|
|
|
|
touch %{buildroot}%{_sharedstatedir}/glusterd/options
|
|
|
|
subdirs=(add-brick create copy-file delete gsync-create remove-brick reset set start stop)
|
|
|
|
for dir in ${subdirs[@]}; do
|
|
|
|
mkdir -p %{buildroot}%{_sharedstatedir}/glusterd/hooks/1/"$dir"/{pre,post}
|
|
|
|
done
|
|
|
|
mkdir -p %{buildroot}%{_sharedstatedir}/glusterd/glustershd
|
|
|
|
mkdir -p %{buildroot}%{_sharedstatedir}/glusterd/peers
|
|
|
|
mkdir -p %{buildroot}%{_sharedstatedir}/glusterd/vols
|
|
|
|
mkdir -p %{buildroot}%{_sharedstatedir}/glusterd/nfs/run
|
|
|
|
mkdir -p %{buildroot}%{_sharedstatedir}/glusterd/bitd
|
|
|
|
mkdir -p %{buildroot}%{_sharedstatedir}/glusterd/quotad
|
|
|
|
mkdir -p %{buildroot}%{_sharedstatedir}/glusterd/scrub
|
|
|
|
mkdir -p %{buildroot}%{_sharedstatedir}/glusterd/snaps
|
|
|
|
mkdir -p %{buildroot}%{_sharedstatedir}/glusterd/ss_brick
|
|
|
|
touch %{buildroot}%{_sharedstatedir}/glusterd/nfs/nfs-server.vol
|
|
|
|
touch %{buildroot}%{_sharedstatedir}/glusterd/nfs/run/nfs.pid
|
2019-04-08 03:04:00 +00:00
|
|
|
%endif
|
2017-11-15 13:56:13 +00:00
|
|
|
|
|
|
|
find ./tests ./run-tests.sh -type f | cpio -pd %{buildroot}%{_prefix}/share/glusterfs
|
|
|
|
|
|
|
|
## Install bash completion for cli
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{!?_without_server:1} )
|
2017-11-15 13:56:13 +00:00
|
|
|
install -p -m 0744 -D extras/command-completion/gluster.bash \
|
|
|
|
%{buildroot}%{_sysconfdir}/bash_completion.d/gluster
|
2019-04-08 03:04:00 +00:00
|
|
|
%endif
|
2017-11-15 13:56:13 +00:00
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{!?_without_server:1} )
|
|
|
|
echo "RHGS 3.5" > %{buildroot}%{_datadir}/glusterfs/release
|
2018-05-09 12:42:05 +00:00
|
|
|
%endif
|
|
|
|
|
2017-11-15 13:56:13 +00:00
|
|
|
%clean
|
|
|
|
rm -rf %{buildroot}
|
|
|
|
|
|
|
|
##-----------------------------------------------------------------------------
|
|
|
|
## All %%post should be placed here and keep them sorted
|
|
|
|
##
|
|
|
|
%post
|
|
|
|
/sbin/ldconfig
|
|
|
|
%if ( 0%{!?_without_syslog:1} )
|
|
|
|
%if ( 0%{?fedora} ) || ( 0%{?rhel} && 0%{?rhel} >= 6 )
|
2019-04-08 03:04:00 +00:00
|
|
|
%systemd_postun_with_restart rsyslog
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
%endif
|
|
|
|
exit 0
|
|
|
|
|
|
|
|
%post api
|
|
|
|
/sbin/ldconfig
|
|
|
|
|
|
|
|
%if ( 0%{!?_without_events:1} )
|
|
|
|
%post events
|
2019-04-08 03:04:00 +00:00
|
|
|
%systemd_post glustereventsd
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
|
|
|
|
%if ( 0%{!?_without_georeplication:1} )
|
|
|
|
%post geo-replication
|
|
|
|
if [ $1 -ge 1 ]; then
|
2019-04-08 03:04:00 +00:00
|
|
|
%systemd_postun_with_restart glusterd
|
2017-11-15 13:56:13 +00:00
|
|
|
fi
|
|
|
|
exit 0
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%post libs
|
|
|
|
/sbin/ldconfig
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{!?_without_server:1} )
|
2017-11-15 13:56:13 +00:00
|
|
|
%post server
|
|
|
|
# Legacy server
|
2019-04-08 03:04:00 +00:00
|
|
|
%systemd_post glusterd
|
2017-11-15 13:56:13 +00:00
|
|
|
%if ( 0%{_for_fedora_koji_builds} )
|
2019-04-08 03:04:00 +00:00
|
|
|
%systemd_post glusterfsd
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
# ".cmd_log_history" is renamed to "cmd_history.log" in GlusterFS-3.7 .
|
|
|
|
# While upgrading glusterfs-server package form GlusterFS version <= 3.6 to
|
|
|
|
# GlusterFS version 3.7, ".cmd_log_history" should be renamed to
|
|
|
|
# "cmd_history.log" to retain cli command history contents.
|
|
|
|
if [ -f %{_localstatedir}/log/glusterfs/.cmd_log_history ]; then
|
|
|
|
mv %{_localstatedir}/log/glusterfs/.cmd_log_history \
|
|
|
|
%{_localstatedir}/log/glusterfs/cmd_history.log
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Genuine Fedora (and EPEL) builds never put gluster files in /etc; if
|
|
|
|
# there are any files in /etc from a prior gluster.org install, move them
|
|
|
|
# to /var/lib. (N.B. Starting with 3.3.0 all gluster files are in /var/lib
|
|
|
|
# in gluster.org RPMs.) Be careful to copy them on the off chance that
|
|
|
|
# /etc and /var/lib are on separate file systems
|
|
|
|
if [ -d /etc/glusterd -a ! -h %{_sharedstatedir}/glusterd ]; then
|
|
|
|
mkdir -p %{_sharedstatedir}/glusterd
|
|
|
|
cp -a /etc/glusterd %{_sharedstatedir}/glusterd
|
|
|
|
rm -rf /etc/glusterd
|
|
|
|
ln -sf %{_sharedstatedir}/glusterd /etc/glusterd
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Rename old volfiles in an RPM-standard way. These aren't actually
|
|
|
|
# considered package config files, so %%config doesn't work for them.
|
|
|
|
if [ -d %{_sharedstatedir}/glusterd/vols ]; then
|
|
|
|
for file in $(find %{_sharedstatedir}/glusterd/vols -name '*.vol'); do
|
|
|
|
newfile=${file}.rpmsave
|
|
|
|
echo "warning: ${file} saved as ${newfile}"
|
|
|
|
cp ${file} ${newfile}
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
|
|
|
|
# add marker translator
|
|
|
|
# but first make certain that there are no old libs around to bite us
|
|
|
|
# BZ 834847
|
|
|
|
if [ -e /etc/ld.so.conf.d/glusterfs.conf ]; then
|
|
|
|
rm -f /etc/ld.so.conf.d/glusterfs.conf
|
|
|
|
/sbin/ldconfig
|
|
|
|
fi
|
|
|
|
|
|
|
|
%if (0%{?_with_firewalld:1})
|
|
|
|
%firewalld_reload
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%endif
|
|
|
|
|
|
|
|
##-----------------------------------------------------------------------------
|
|
|
|
## All %%pre should be placed here and keep them sorted
|
|
|
|
##
|
|
|
|
%pre
|
|
|
|
getent group gluster > /dev/null || groupadd -r gluster
|
|
|
|
getent passwd gluster > /dev/null || useradd -r -g gluster -d %{_rundir}/gluster -s /sbin/nologin -c "GlusterFS daemons" gluster
|
|
|
|
exit 0
|
|
|
|
|
|
|
|
##-----------------------------------------------------------------------------
|
|
|
|
## All %%preun should be placed here and keep them sorted
|
|
|
|
##
|
|
|
|
%if ( 0%{!?_without_events:1} )
|
|
|
|
%preun events
|
|
|
|
if [ $1 -eq 0 ]; then
|
2019-04-08 03:04:00 +00:00
|
|
|
if [ -f %glustereventsd_svcfile ]; then
|
|
|
|
%service_stop glustereventsd
|
|
|
|
%systemd_preun glustereventsd
|
2017-11-15 13:56:13 +00:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
exit 0
|
|
|
|
%endif
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{!?_without_server:1} )
|
2017-11-15 13:56:13 +00:00
|
|
|
%preun server
|
|
|
|
if [ $1 -eq 0 ]; then
|
2019-04-08 03:04:00 +00:00
|
|
|
if [ -f %glusterfsd_svcfile ]; then
|
|
|
|
%service_stop glusterfsd
|
2017-11-15 13:56:13 +00:00
|
|
|
fi
|
2019-04-08 03:04:00 +00:00
|
|
|
%service_stop glusterd
|
|
|
|
if [ -f %glusterfsd_svcfile ]; then
|
|
|
|
%systemd_preun glusterfsd
|
2017-11-15 13:56:13 +00:00
|
|
|
fi
|
2019-04-08 03:04:00 +00:00
|
|
|
%systemd_preun glusterd
|
2017-11-15 13:56:13 +00:00
|
|
|
fi
|
|
|
|
if [ $1 -ge 1 ]; then
|
2019-04-08 03:04:00 +00:00
|
|
|
if [ -f %glusterfsd_svcfile ]; then
|
|
|
|
%systemd_postun_with_restart glusterfsd
|
2017-11-15 13:56:13 +00:00
|
|
|
fi
|
2019-04-08 03:04:00 +00:00
|
|
|
%systemd_postun_with_restart glusterd
|
2017-11-15 13:56:13 +00:00
|
|
|
fi
|
2019-04-08 03:04:00 +00:00
|
|
|
exit 0
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
%preun thin-arbiter
|
|
|
|
if [ $1 -eq 0 ]; then
|
|
|
|
if [ -f %glusterta_svcfile ]; then
|
|
|
|
%service_stop gluster-ta-volume
|
|
|
|
%systemd_preun gluster-ta-volume
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2017-11-15 13:56:13 +00:00
|
|
|
##-----------------------------------------------------------------------------
|
|
|
|
## All %%postun should be placed here and keep them sorted
|
|
|
|
##
|
|
|
|
%postun
|
|
|
|
%if ( 0%{!?_without_syslog:1} )
|
|
|
|
%if ( 0%{?fedora} ) || ( 0%{?rhel} && 0%{?rhel} >= 6 )
|
2019-04-08 03:04:00 +00:00
|
|
|
%systemd_postun_with_restart rsyslog
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
%endif
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{!?_without_server:1} )
|
2017-11-15 13:56:13 +00:00
|
|
|
%postun server
|
|
|
|
%if (0%{?_with_firewalld:1})
|
|
|
|
%firewalld_reload
|
|
|
|
%endif
|
|
|
|
exit 0
|
|
|
|
%endif
|
|
|
|
|
|
|
|
##-----------------------------------------------------------------------------
|
|
|
|
## All %%files should be placed here and keep them grouped
|
|
|
|
##
|
|
|
|
%files
|
2019-04-08 03:04:00 +00:00
|
|
|
%doc ChangeLog COPYING-GPLV2 COPYING-LGPLV3 INSTALL README.md THANKS COMMITMENT
|
2017-11-15 13:56:13 +00:00
|
|
|
%{_mandir}/man8/*gluster*.8*
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{!?_without_server:1} )
|
2017-11-15 13:56:13 +00:00
|
|
|
%exclude %{_mandir}/man8/gluster.8*
|
2019-04-08 03:04:00 +00:00
|
|
|
%endif
|
2017-11-15 13:56:13 +00:00
|
|
|
%dir %{_localstatedir}/log/glusterfs
|
|
|
|
%if ( 0%{!?_without_rdma:1} )
|
|
|
|
%exclude %{_libdir}/glusterfs/%{version}%{?prereltag}/rpc-transport/rdma*
|
|
|
|
%endif
|
2019-04-08 03:04:00 +00:00
|
|
|
%if 0%{?!_without_server:1}
|
2017-11-15 13:56:13 +00:00
|
|
|
%dir %{_datadir}/glusterfs
|
|
|
|
%dir %{_datadir}/glusterfs/scripts
|
|
|
|
%{_datadir}/glusterfs/scripts/post-upgrade-script-for-quota.sh
|
|
|
|
%{_datadir}/glusterfs/scripts/pre-upgrade-script-for-quota.sh
|
2019-04-08 03:04:00 +00:00
|
|
|
%endif
|
2017-11-15 13:56:13 +00:00
|
|
|
# xlators that are needed on the client- and on the server-side
|
|
|
|
%dir %{_libdir}/glusterfs
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/auth
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/auth/addr.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/auth/login.so
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/rpc-transport
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/rpc-transport/socket.so
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/debug
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/debug/error-gen.so
|
2019-04-08 03:04:00 +00:00
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/debug/delay-gen.so
|
2017-11-15 13:56:13 +00:00
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/debug/io-stats.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/debug/sink.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/debug/trace.so
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/access-control.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/barrier.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/cdc.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/changelog.so
|
2019-04-08 03:04:00 +00:00
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/utime.so
|
2017-11-15 13:56:13 +00:00
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/gfid-access.so
|
2019-04-08 03:04:00 +00:00
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/namespace.so
|
2017-11-15 13:56:13 +00:00
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/read-only.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/shard.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/snapview-client.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/worm.so
|
2019-04-08 03:04:00 +00:00
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/cloudsync.so
|
2017-11-15 13:56:13 +00:00
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/meta.so
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/performance
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/performance/io-cache.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/performance/io-threads.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/performance/md-cache.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/performance/open-behind.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/performance/quick-read.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/performance/read-ahead.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/performance/readdir-ahead.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/performance/stat-prefetch.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/performance/write-behind.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/performance/nl-cache.so
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/system
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/system/posix-acl.so
|
|
|
|
%dir %attr(0775,gluster,gluster) %{_rundir}/gluster
|
2019-04-08 03:04:00 +00:00
|
|
|
%if 0%{?_tmpfilesdir:1} && 0%{!?_without_server:1}
|
2017-11-15 13:56:13 +00:00
|
|
|
%{_tmpfilesdir}/gluster.conf
|
|
|
|
%endif
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{?_without_extra_xlators:1} )
|
|
|
|
%exclude %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/quiesce.so
|
|
|
|
%exclude %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/playground/template.so
|
|
|
|
%endif
|
|
|
|
%if ( 0%{?_without_regression_tests:1} )
|
|
|
|
%exclude %{_datadir}/glusterfs/run-tests.sh
|
|
|
|
%exclude %{_datadir}/glusterfs/tests
|
|
|
|
%endif
|
|
|
|
%if 0%{?_without_server:1}
|
2018-01-17 07:21:37 +00:00
|
|
|
%if ( 0%{?_with_systemd:1} )
|
|
|
|
%exclude %{_datadir}/glusterfs/scripts/control-cpu-load.sh
|
|
|
|
%exclude %{_datadir}/glusterfs/scripts/control-mem.sh
|
|
|
|
%endif
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
|
|
|
|
%files api
|
|
|
|
%exclude %{_libdir}/*.so
|
|
|
|
# libgfapi files
|
|
|
|
%{_libdir}/libgfapi.*
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/mount
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/mount/api.so
|
|
|
|
|
|
|
|
%files api-devel
|
|
|
|
%{_libdir}/pkgconfig/glusterfs-api.pc
|
|
|
|
%{_libdir}/libgfapi.so
|
|
|
|
%dir %{_includedir}/glusterfs
|
|
|
|
%dir %{_includedir}/glusterfs/api
|
|
|
|
%{_includedir}/glusterfs/api/*
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{!?_without_server:1} )
|
2017-11-15 13:56:13 +00:00
|
|
|
%files cli
|
|
|
|
%{_sbindir}/gluster
|
|
|
|
%{_mandir}/man8/gluster.8*
|
|
|
|
%{_sysconfdir}/bash_completion.d/gluster
|
2019-04-08 03:04:00 +00:00
|
|
|
%endif
|
|
|
|
|
|
|
|
%files cloudsync-plugins
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/cloudsync-plugins
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/cloudsync-plugins/cloudsyncs3.so
|
2017-11-15 13:56:13 +00:00
|
|
|
|
|
|
|
%files devel
|
|
|
|
%dir %{_includedir}/glusterfs
|
|
|
|
%{_includedir}/glusterfs/*
|
|
|
|
%exclude %{_includedir}/glusterfs/api
|
|
|
|
%exclude %{_libdir}/libgfapi.so
|
|
|
|
%{_libdir}/*.so
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{?_without_server:1} )
|
2017-11-15 13:56:13 +00:00
|
|
|
%exclude %{_libdir}/pkgconfig/libgfchangelog.pc
|
2019-04-08 03:04:00 +00:00
|
|
|
%exclude %{_libdir}/libgfchangelog.so
|
2017-11-15 13:56:13 +00:00
|
|
|
%else
|
2019-04-08 03:04:00 +00:00
|
|
|
%{_libdir}/pkgconfig/libgfchangelog.pc
|
|
|
|
%{_libdir}/libgfchangelog.so
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
|
|
|
|
%files client-xlators
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/cluster
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/cluster/*.so
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/protocol
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/protocol/client.so
|
|
|
|
|
|
|
|
%if ( 0%{!?_without_extra_xlators:1} )
|
|
|
|
%files extra-xlators
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/quiesce.so
|
2019-04-08 03:04:00 +00:00
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/playground
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/playground/template.so
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
|
|
|
|
%files fuse
|
|
|
|
# glusterfs is a symlink to glusterfsd, -server depends on -fuse.
|
|
|
|
%{_sbindir}/glusterfs
|
|
|
|
%{_sbindir}/glusterfsd
|
|
|
|
%config(noreplace) %{_sysconfdir}/logrotate.d/glusterfs
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/mount
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/mount/fuse.so
|
|
|
|
/sbin/mount.glusterfs
|
|
|
|
%if ( 0%{!?_without_fusermount:1} )
|
|
|
|
%{_bindir}/fusermount-glusterfs
|
|
|
|
%endif
|
2019-04-08 03:04:00 +00:00
|
|
|
|
|
|
|
%if ( 0%{?_with_gnfs:1} && 0%{!?_without_server:1} )
|
|
|
|
%files gnfs
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/nfs
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/nfs/server.so
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/nfs
|
|
|
|
%ghost %attr(0600,-,-) %{_sharedstatedir}/glusterd/nfs/nfs-server.vol
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/nfs/run
|
|
|
|
%ghost %attr(0600,-,-) %{_sharedstatedir}/glusterd/nfs/run/nfs.pid
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
%files thin-arbiter
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/thin-arbiter.so
|
|
|
|
%dir %{_datadir}/glusterfs/scripts
|
|
|
|
%{_datadir}/glusterfs/scripts/setup-thin-arbiter.sh
|
|
|
|
%config %{_sysconfdir}/glusterfs/thin-arbiter.vol
|
|
|
|
|
|
|
|
%if ( 0%{?_with_systemd:1} )
|
|
|
|
%{_unitdir}/gluster-ta-volume.service
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
|
2017-11-15 13:56:13 +00:00
|
|
|
%if ( 0%{!?_without_georeplication:1} )
|
|
|
|
%files geo-replication
|
|
|
|
%config(noreplace) %{_sysconfdir}/logrotate.d/glusterfs-georep
|
|
|
|
|
|
|
|
%{_sbindir}/gfind_missing_files
|
|
|
|
%{_sbindir}/gluster-mountbroker
|
|
|
|
%dir %{_libexecdir}/glusterfs
|
|
|
|
%dir %{_libexecdir}/glusterfs/python
|
|
|
|
%dir %{_libexecdir}/glusterfs/python/syncdaemon
|
|
|
|
%{_libexecdir}/glusterfs/gsyncd
|
|
|
|
%{_libexecdir}/glusterfs/python/syncdaemon/*
|
|
|
|
%{_libexecdir}/glusterfs/gverify.sh
|
|
|
|
%{_libexecdir}/glusterfs/set_geo_rep_pem_keys.sh
|
|
|
|
%{_libexecdir}/glusterfs/peer_gsec_create
|
|
|
|
%{_libexecdir}/glusterfs/peer_mountbroker
|
|
|
|
%{_libexecdir}/glusterfs/peer_mountbroker.py*
|
|
|
|
%{_libexecdir}/glusterfs/gfind_missing_files
|
|
|
|
%{_libexecdir}/glusterfs/peer_georep-sshkey.py*
|
|
|
|
%{_sbindir}/gluster-georep-sshkey
|
|
|
|
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/geo-replication
|
|
|
|
%ghost %attr(0644,-,-) %{_sharedstatedir}/glusterd/geo-replication/gsyncd_template.conf
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/gsync-create
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/gsync-create/post
|
|
|
|
%attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/gsync-create/post/S56glusterd-geo-rep-create-post.sh
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/gsync-create/pre
|
|
|
|
|
|
|
|
%dir %{_datadir}/glusterfs
|
|
|
|
%dir %{_datadir}/glusterfs/scripts
|
|
|
|
%{_datadir}/glusterfs/scripts/get-gfid.sh
|
|
|
|
%{_datadir}/glusterfs/scripts/slave-upgrade.sh
|
|
|
|
%{_datadir}/glusterfs/scripts/gsync-upgrade.sh
|
|
|
|
%{_datadir}/glusterfs/scripts/generate-gfid-file.sh
|
|
|
|
%{_datadir}/glusterfs/scripts/gsync-sync-gfid
|
|
|
|
%{_datadir}/glusterfs/scripts/schedule_georep.py*
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%files libs
|
|
|
|
%{_libdir}/*.so.*
|
|
|
|
%exclude %{_libdir}/libgfapi.*
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
%files -n python%{_pythonver}-gluster
|
2017-11-15 13:56:13 +00:00
|
|
|
# introducing glusterfs module in site packages.
|
|
|
|
# so that all other gluster submodules can reside in the same namespace.
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( %{_usepython3} )
|
|
|
|
%dir %{python3_sitelib}/gluster
|
|
|
|
%{python3_sitelib}/gluster/__init__.*
|
|
|
|
%{python3_sitelib}/gluster/__pycache__
|
|
|
|
%{python3_sitelib}/gluster/cliutils
|
|
|
|
%else
|
2017-11-15 13:56:13 +00:00
|
|
|
%dir %{python2_sitelib}/gluster
|
|
|
|
%{python2_sitelib}/gluster/__init__.*
|
|
|
|
%{python2_sitelib}/gluster/cliutils
|
2019-04-08 03:04:00 +00:00
|
|
|
%endif
|
2017-11-15 13:56:13 +00:00
|
|
|
|
|
|
|
%if ( 0%{!?_without_rdma:1} )
|
|
|
|
%files rdma
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/rpc-transport
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/rpc-transport/rdma*
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%if ( 0%{!?_without_regression_tests:1} )
|
|
|
|
%files regression-tests
|
|
|
|
%dir %{_datadir}/glusterfs
|
|
|
|
%{_datadir}/glusterfs/run-tests.sh
|
|
|
|
%{_datadir}/glusterfs/tests
|
|
|
|
%exclude %{_datadir}/glusterfs/tests/vagrant
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%if ( 0%{!?_without_ocf:1} )
|
|
|
|
%files resource-agents
|
|
|
|
# /usr/lib is the standard for OCF, also on x86_64
|
|
|
|
%{_prefix}/lib/ocf/resource.d/glusterfs
|
|
|
|
%endif
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
%if ( 0%{!?_without_server:1} )
|
2017-11-15 13:56:13 +00:00
|
|
|
%files server
|
|
|
|
%doc extras/clear_xattrs.sh
|
|
|
|
# sysconf
|
|
|
|
%config(noreplace) %{_sysconfdir}/glusterfs
|
2019-04-08 03:04:00 +00:00
|
|
|
%exclude %{_sysconfdir}/glusterfs/thin-arbiter.vol
|
2017-11-15 13:56:13 +00:00
|
|
|
%exclude %{_sysconfdir}/glusterfs/eventsconfig.json
|
2019-04-08 03:04:00 +00:00
|
|
|
%exclude %{_sharedstatedir}/glusterd/nfs/nfs-server.vol
|
|
|
|
%exclude %{_sharedstatedir}/glusterd/nfs/run/nfs.pid
|
|
|
|
%if ( 0%{?_with_gnfs:1} )
|
|
|
|
%exclude %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/nfs/*
|
|
|
|
%endif
|
2017-11-15 13:56:13 +00:00
|
|
|
%config(noreplace) %{_sysconfdir}/sysconfig/glusterd
|
|
|
|
%if ( 0%{_for_fedora_koji_builds} )
|
|
|
|
%config(noreplace) %{_sysconfdir}/sysconfig/glusterfsd
|
|
|
|
%endif
|
|
|
|
|
|
|
|
# init files
|
2019-04-08 03:04:00 +00:00
|
|
|
%glusterd_svcfile
|
2017-11-15 13:56:13 +00:00
|
|
|
%if ( 0%{_for_fedora_koji_builds} )
|
2019-04-08 03:04:00 +00:00
|
|
|
%glusterfsd_svcfile
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
%if ( 0%{?_with_systemd:1} )
|
2019-04-08 03:04:00 +00:00
|
|
|
%glusterfssharedstorage_svcfile
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
|
|
|
|
# binaries
|
|
|
|
%{_sbindir}/glusterd
|
|
|
|
%{_sbindir}/glfsheal
|
|
|
|
%{_sbindir}/gf_attach
|
|
|
|
%{_sbindir}/gluster-setgfid2path
|
|
|
|
# {_sbindir}/glusterfsd is the actual binary, but glusterfs (client) is a
|
|
|
|
# symlink. The binary itself (and symlink) are part of the glusterfs-fuse
|
|
|
|
# package, because glusterfs-server depends on that anyway.
|
|
|
|
|
|
|
|
# Manpages
|
|
|
|
%{_mandir}/man8/gluster-setgfid2path.8*
|
|
|
|
|
|
|
|
# xlators
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/arbiter.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/bit-rot.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/bitrot-stub.so
|
2019-04-08 03:04:00 +00:00
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/sdfs.so
|
2017-11-15 13:56:13 +00:00
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/index.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/locks.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/posix*
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/snapview-server.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/marker.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/quota*
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/selinux.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/trash.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/upcall.so
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/leases.so
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/mgmt
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/mgmt/glusterd.so
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/protocol
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/protocol/server.so
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/storage
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/storage/posix.so
|
|
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/performance
|
|
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/performance/decompounder.so
|
|
|
|
|
|
|
|
# snap_scheduler
|
|
|
|
%{_sbindir}/snap_scheduler.py
|
|
|
|
%{_sbindir}/gcron.py
|
|
|
|
%{_sbindir}/conf.py
|
|
|
|
|
|
|
|
# /var/lib/glusterd, e.g. hookscripts, etc.
|
|
|
|
%ghost %attr(0644,-,-) %config(noreplace) %{_sharedstatedir}/glusterd/glusterd.info
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/bitd
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/groups
|
|
|
|
%attr(0644,-,-) %{_sharedstatedir}/glusterd/groups/virt
|
|
|
|
%attr(0644,-,-) %{_sharedstatedir}/glusterd/groups/metadata-cache
|
|
|
|
%attr(0644,-,-) %{_sharedstatedir}/glusterd/groups/gluster-block
|
2019-04-08 03:04:00 +00:00
|
|
|
%attr(0644,-,-) %{_sharedstatedir}/glusterd/groups/nl-cache
|
2018-07-18 12:38:52 +00:00
|
|
|
%attr(0644,-,-) %{_sharedstatedir}/glusterd/groups/db-workload
|
2018-12-18 16:23:13 +00:00
|
|
|
%attr(0644,-,-) %{_sharedstatedir}/glusterd/groups/distributed-virt
|
|
|
|
%attr(0644,-,-) %{_sharedstatedir}/glusterd/groups/samba
|
2017-11-15 13:56:13 +00:00
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/glusterfind
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/glusterfind/.keys
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/glustershd
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/add-brick
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/add-brick/post
|
|
|
|
%attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/add-brick/post/disabled-quota-root-xattr-heal.sh
|
2018-03-07 13:56:57 +00:00
|
|
|
%attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/add-brick/post/S13create-subdir-mounts.sh
|
2017-11-15 13:56:13 +00:00
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/add-brick/pre
|
2018-03-07 13:56:57 +00:00
|
|
|
%attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/add-brick/pre/S28Quota-enable-root-xattr-heal.sh
|
2017-11-15 13:56:13 +00:00
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/create
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/create/post
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/create/pre
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/copy-file
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/copy-file/post
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/copy-file/pre
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/delete
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/delete/post
|
|
|
|
%{_sharedstatedir}/glusterd/hooks/1/delete/post/S57glusterfind-delete-post
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/delete/pre
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/remove-brick
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/remove-brick/post
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/remove-brick/pre
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/reset
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/reset/post
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/reset/pre
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/set
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/set/post
|
|
|
|
%attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/set/post/S30samba-set.sh
|
|
|
|
%attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/set/post/S32gluster_enable_shared_storage.sh
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/set/pre
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/start
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/start/post
|
|
|
|
%attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/start/post/S29CTDBsetup.sh
|
|
|
|
%attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/start/post/S30samba-start.sh
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/start/pre
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/stop
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/stop/post
|
|
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/stop/pre
|
|
|
|
%attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/stop/pre/S30samba-stop.sh
|
|
|
|
%attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/stop/pre/S29CTDB-teardown.sh
|
2019-04-08 03:04:00 +00:00
|
|
|
%config(noreplace) %ghost %attr(0600,-,-) %{_sharedstatedir}/glusterd/options
|
2017-11-15 13:56:13 +00:00
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/peers
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/quotad
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/scrub
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/snaps
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/ss_brick
|
|
|
|
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/vols
|
|
|
|
|
|
|
|
# Extra utility script
|
|
|
|
%dir %{_libexecdir}/glusterfs
|
2018-05-09 12:42:05 +00:00
|
|
|
%{_datadir}/glusterfs/release
|
2017-11-15 13:56:13 +00:00
|
|
|
%dir %{_datadir}/glusterfs/scripts
|
|
|
|
%{_datadir}/glusterfs/scripts/stop-all-gluster-processes.sh
|
|
|
|
%if ( 0%{?_with_systemd:1} )
|
|
|
|
%{_libexecdir}/glusterfs/mount-shared-storage.sh
|
2018-01-17 07:21:37 +00:00
|
|
|
%{_datadir}/glusterfs/scripts/control-cpu-load.sh
|
|
|
|
%{_datadir}/glusterfs/scripts/control-mem.sh
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
|
|
|
|
# Incrementalapi
|
|
|
|
%{_libexecdir}/glusterfs/glusterfind
|
|
|
|
%{_bindir}/glusterfind
|
|
|
|
%{_libexecdir}/glusterfs/peer_add_secret_pub
|
|
|
|
|
|
|
|
%if ( 0%{?_with_firewalld:1} )
|
|
|
|
%{_prefix}/lib/firewalld/services/glusterfs.xml
|
|
|
|
%endif
|
2019-04-08 03:04:00 +00:00
|
|
|
# end of server files
|
2017-11-15 13:56:13 +00:00
|
|
|
%endif
|
|
|
|
|
2019-04-08 03:04:00 +00:00
|
|
|
# Events
|
|
|
|
%if ( 0%{!?_without_events:1} )
|
|
|
|
%files events
|
|
|
|
%config(noreplace) %{_sysconfdir}/glusterfs/eventsconfig.json
|
|
|
|
%dir %{_sharedstatedir}/glusterd
|
|
|
|
%dir %{_sharedstatedir}/glusterd/events
|
|
|
|
%dir %{_libexecdir}/glusterfs
|
|
|
|
%{_libexecdir}/glusterfs/gfevents
|
|
|
|
%{_libexecdir}/glusterfs/peer_eventsapi.py*
|
|
|
|
%{_sbindir}/glustereventsd
|
|
|
|
%{_sbindir}/gluster-eventsapi
|
|
|
|
%{_datadir}/glusterfs/scripts/eventsdash.py*
|
|
|
|
%if ( 0%{?_with_systemd:1} )
|
|
|
|
%{_unitdir}/glustereventsd.service
|
|
|
|
%else
|
|
|
|
%{_sysconfdir}/init.d/glustereventsd
|
|
|
|
%endif
|
|
|
|
%endif
|
2017-11-15 13:56:13 +00:00
|
|
|
|
|
|
|
##-----------------------------------------------------------------------------
|
|
|
|
## All %pretrans should be placed here and keep them sorted
|
|
|
|
##
|
2019-04-08 03:04:00 +00:00
|
|
|
%if 0%{!?_without_server:1}
|
2017-11-15 13:56:13 +00:00
|
|
|
%pretrans -p <lua>
|
|
|
|
if not posix.access("/bin/bash", "x") then
|
|
|
|
-- initial installation, no shell, no running glusterfsd
|
|
|
|
return 0
|
|
|
|
end
|
|
|
|
|
|
|
|
-- TODO: move this completely to a lua script
|
|
|
|
-- For now, we write a temporary bash script and execute that.
|
|
|
|
|
|
|
|
script = [[#!/bin/sh
|
|
|
|
pidof -c -o %PPID -x glusterfsd &>/dev/null
|
|
|
|
|
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
pushd . > /dev/null 2>&1
|
|
|
|
for volume in /var/lib/glusterd/vols/*; do cd $volume;
|
|
|
|
vol_type=`grep '^type=' info | awk -F'=' '{print $2}'`
|
|
|
|
volume_started=`grep '^status=' info | awk -F'=' '{print $2}'`
|
|
|
|
if [ $vol_type -eq 0 ] && [ $volume_started -eq 1 ] ; then
|
|
|
|
echo "ERROR: Distribute volumes detected. In-service rolling upgrade requires distribute volume(s) to be stopped."
|
|
|
|
echo "ERROR: Please stop distribute volume(s) before proceeding... exiting!"
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
popd > /dev/null 2>&1
|
|
|
|
echo "WARNING: Updating glusterfs requires its processes to be killed. This action does NOT incur downtime."
|
|
|
|
echo "WARNING: Ensure to wait for the upgraded server to finish healing before proceeding."
|
|
|
|
echo "WARNING: Refer upgrade section of install guide for more details"
|
|
|
|
echo "Please run # service glusterd stop; pkill glusterfs; pkill glusterfsd; pkill gsyncd.py;"
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
]]
|
|
|
|
|
2019-02-12 16:22:52 +00:00
|
|
|
ok, how, val = os.execute(script)
|
2017-11-15 13:56:13 +00:00
|
|
|
if not (ok == 0) then
|
|
|
|
error("Detected running glusterfs processes", ok)
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
%pretrans api -p <lua>
|
|
|
|
if not posix.access("/bin/bash", "x") then
|
|
|
|
-- initial installation, no shell, no running glusterfsd
|
|
|
|
return 0
|
|
|
|
end
|
|
|
|
|
|
|
|
-- TODO: move this completely to a lua script
|
|
|
|
-- For now, we write a temporary bash script and execute that.
|
|
|
|
|
|
|
|
script = [[#!/bin/sh
|
|
|
|
pidof -c -o %PPID -x glusterfsd &>/dev/null
|
|
|
|
|
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
pushd . > /dev/null 2>&1
|
|
|
|
for volume in /var/lib/glusterd/vols/*; do cd $volume;
|
|
|
|
vol_type=`grep '^type=' info | awk -F'=' '{print $2}'`
|
|
|
|
volume_started=`grep '^status=' info | awk -F'=' '{print $2}'`
|
|
|
|
if [ $vol_type -eq 0 ] && [ $volume_started -eq 1 ] ; then
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
popd > /dev/null 2>&1
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
]]
|
|
|
|
|
2019-02-12 16:22:52 +00:00
|
|
|
ok, how, val = os.execute(script)
|
2017-11-15 13:56:13 +00:00
|
|
|
if not (ok == 0) then
|
|
|
|
error("Detected running glusterfs processes", ok)
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
%pretrans api-devel -p <lua>
|
|
|
|
if not posix.access("/bin/bash", "x") then
|
|
|
|
-- initial installation, no shell, no running glusterfsd
|
|
|
|
return 0
|
|
|
|
end
|
|
|
|
|
|
|
|
-- TODO: move this completely to a lua script
|
|
|
|
-- For now, we write a temporary bash script and execute that.
|
|
|
|
|
|
|
|
script = [[#!/bin/sh
|
|
|
|
pidof -c -o %PPID -x glusterfsd &>/dev/null
|
|
|
|
|
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
pushd . > /dev/null 2>&1
|
|
|
|
for volume in /var/lib/glusterd/vols/*; do cd $volume;
|
|
|
|
vol_type=`grep '^type=' info | awk -F'=' '{print $2}'`
|
|
|
|
volume_started=`grep '^status=' info | awk -F'=' '{print $2}'`
|
|
|
|
if [ $vol_type -eq 0 ] && [ $volume_started -eq 1 ] ; then
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
popd > /dev/null 2>&1
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
]]
|
|
|
|
|
2019-02-12 16:22:52 +00:00
|
|
|
ok, how, val = os.execute(script)
|
2017-11-15 13:56:13 +00:00
|
|
|
if not (ok == 0) then
|
|
|
|
error("Detected running glusterfs processes", ok)
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
%pretrans cli -p <lua>
|
|
|
|
if not posix.access("/bin/bash", "x") then
|
|
|
|
-- initial installation, no shell, no running glusterfsd
|
|
|
|
return 0
|
|
|
|
end
|
|
|
|
|
|
|
|
-- TODO: move this completely to a lua script
|
|
|
|
-- For now, we write a temporary bash script and execute that.
|
|
|
|
|
|
|
|
script = [[#!/bin/sh
|
|
|
|
pidof -c -o %PPID -x glusterfsd &>/dev/null
|
|
|
|
|
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
pushd . > /dev/null 2>&1
|
|
|
|
for volume in /var/lib/glusterd/vols/*; do cd $volume;
|
|
|
|
vol_type=`grep '^type=' info | awk -F'=' '{print $2}'`
|
|
|
|
volume_started=`grep '^status=' info | awk -F'=' '{print $2}'`
|
|
|
|
if [ $vol_type -eq 0 ] && [ $volume_started -eq 1 ] ; then
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
popd > /dev/null 2>&1
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
]]
|
|
|
|
|
2019-02-12 16:22:52 +00:00
|
|
|
ok, how, val = os.execute(script)
|
2017-11-15 13:56:13 +00:00
|
|
|
if not (ok == 0) then
|
|
|
|
error("Detected running glusterfs processes", ok)
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
%pretrans client-xlators -p <lua>
|
|
|
|
if not posix.access("/bin/bash", "x") then
|
|
|
|
-- initial installation, no shell, no running glusterfsd
|
|
|
|
return 0
|
|
|
|
end
|
|
|
|
|
|
|
|
-- TODO: move this completely to a lua script
|
|
|
|
-- For now, we write a temporary bash script and execute that.
|
|
|
|
|
|
|
|
script = [[#!/bin/sh
|
|
|
|
pidof -c -o %PPID -x glusterfsd &>/dev/null
|
|
|
|
|
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
pushd . > /dev/null 2>&1
|
|
|
|
for volume in /var/lib/glusterd/vols/*; do cd $volume;
|
|
|
|
vol_type=`grep '^type=' info | awk -F'=' '{print $2}'`
|
|
|
|
volume_started=`grep '^status=' info | awk -F'=' '{print $2}'`
|
|
|
|
if [ $vol_type -eq 0 ] && [ $volume_started -eq 1 ] ; then
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
popd > /dev/null 2>&1
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
]]
|
|
|
|
|
2019-02-12 16:22:52 +00:00
|
|
|
ok, how, val = os.execute(script)
|
2017-11-15 13:56:13 +00:00
|
|
|
if not (ok == 0) then
|
|
|
|
error("Detected running glusterfs processes", ok)
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
%pretrans fuse -p <lua>
|
|
|
|
if not posix.access("/bin/bash", "x") then
|
|
|
|
-- initial installation, no shell, no running glusterfsd
|
|
|
|
return 0
|
|
|
|
end
|
|
|
|
|
|
|
|
-- TODO: move this completely to a lua script
|
|
|
|
-- For now, we write a temporary bash script and execute that.
|
|
|
|
|
|
|
|
script = [[#!/bin/sh
|
|
|
|
pidof -c -o %PPID -x glusterfsd &>/dev/null
|
|
|
|
|
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
pushd . > /dev/null 2>&1
|
|
|
|
for volume in /var/lib/glusterd/vols/*; do cd $volume;
|
|
|
|
vol_type=`grep '^type=' info | awk -F'=' '{print $2}'`
|
|
|
|
volume_started=`grep '^status=' info | awk -F'=' '{print $2}'`
|
|
|
|
if [ $vol_type -eq 0 ] && [ $volume_started -eq 1 ] ; then
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
popd > /dev/null 2>&1
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
]]
|
|
|
|
|
2019-02-12 16:22:52 +00:00
|
|
|
ok, how, val = os.execute(script)
|
2017-11-15 13:56:13 +00:00
|
|
|
if not (ok == 0) then
|
|
|
|
error("Detected running glusterfs processes", ok)
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
%if ( 0%{!?_without_georeplication:1} )
|
|
|
|
%pretrans geo-replication -p <lua>
|
|
|
|
if not posix.access("/bin/bash", "x") then
|
|
|
|
-- initial installation, no shell, no running glusterfsd
|
|
|
|
return 0
|
|
|
|
end
|
|
|
|
|
|
|
|
-- TODO: move this completely to a lua script
|
|
|
|
-- For now, we write a temporary bash script and execute that.
|
|
|
|
|
|
|
|
script = [[#!/bin/sh
|
|
|
|
pidof -c -o %PPID -x glusterfsd &>/dev/null
|
|
|
|
|
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
pushd . > /dev/null 2>&1
|
|
|
|
for volume in /var/lib/glusterd/vols/*; do cd $volume;
|
|
|
|
vol_type=`grep '^type=' info | awk -F'=' '{print $2}'`
|
|
|
|
volume_started=`grep '^status=' info | awk -F'=' '{print $2}'`
|
|
|
|
if [ $vol_type -eq 0 ] && [ $volume_started -eq 1 ] ; then
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
popd > /dev/null 2>&1
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
]]
|
|
|
|
|
2019-02-12 16:22:52 +00:00
|
|
|
ok, how, val = os.execute(script)
|
2017-11-15 13:56:13 +00:00
|
|
|
if not (ok == 0) then
|
|
|
|
error("Detected running glusterfs processes", ok)
|
|
|
|
end
|
|
|
|
%endif
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
%pretrans libs -p <lua>
|
|
|
|
if not posix.access("/bin/bash", "x") then
|
|
|
|
-- initial installation, no shell, no running glusterfsd
|
|
|
|
return 0
|
|
|
|
end
|
|
|
|
|
|
|
|
-- TODO: move this completely to a lua script
|
|
|
|
-- For now, we write a temporary bash script and execute that.
|
|
|
|
|
|
|
|
script = [[#!/bin/sh
|
|
|
|
pidof -c -o %PPID -x glusterfsd &>/dev/null
|
|
|
|
|
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
pushd . > /dev/null 2>&1
|
|
|
|
for volume in /var/lib/glusterd/vols/*; do cd $volume;
|
|
|
|
vol_type=`grep '^type=' info | awk -F'=' '{print $2}'`
|
|
|
|
volume_started=`grep '^status=' info | awk -F'=' '{print $2}'`
|
|
|
|
if [ $vol_type -eq 0 ] && [ $volume_started -eq 1 ] ; then
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
popd > /dev/null 2>&1
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
]]
|
|
|
|
|
2019-02-12 16:22:52 +00:00
|
|
|
ok, how, val = os.execute(script)
|
2017-11-15 13:56:13 +00:00
|
|
|
if not (ok == 0) then
|
|
|
|
error("Detected running glusterfs processes", ok)
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
%if ( 0%{!?_without_rdma:1} )
|
|
|
|
%pretrans rdma -p <lua>
|
|
|
|
if not posix.access("/bin/bash", "x") then
|
|
|
|
-- initial installation, no shell, no running glusterfsd
|
|
|
|
return 0
|
|
|
|
end
|
|
|
|
|
|
|
|
-- TODO: move this completely to a lua script
|
|
|
|
-- For now, we write a temporary bash script and execute that.
|
|
|
|
|
|
|
|
script = [[#!/bin/sh
|
|
|
|
pidof -c -o %PPID -x glusterfsd &>/dev/null
|
|
|
|
|
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
pushd . > /dev/null 2>&1
|
|
|
|
for volume in /var/lib/glusterd/vols/*; do cd $volume;
|
|
|
|
vol_type=`grep '^type=' info | awk -F'=' '{print $2}'`
|
|
|
|
volume_started=`grep '^status=' info | awk -F'=' '{print $2}'`
|
|
|
|
if [ $vol_type -eq 0 ] && [ $volume_started -eq 1 ] ; then
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
popd > /dev/null 2>&1
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
]]
|
|
|
|
|
2019-02-12 16:22:52 +00:00
|
|
|
ok, how, val = os.execute(script)
|
2017-11-15 13:56:13 +00:00
|
|
|
if not (ok == 0) then
|
|
|
|
error("Detected running glusterfs processes", ok)
|
|
|
|
end
|
|
|
|
%endif
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
%if ( 0%{!?_without_ocf:1} )
|
|
|
|
%pretrans resource-agents -p <lua>
|
|
|
|
if not posix.access("/bin/bash", "x") then
|
|
|
|
-- initial installation, no shell, no running glusterfsd
|
|
|
|
return 0
|
|
|
|
end
|
|
|
|
|
|
|
|
-- TODO: move this completely to a lua script
|
|
|
|
-- For now, we write a temporary bash script and execute that.
|
|
|
|
|
|
|
|
script = [[#!/bin/sh
|
|
|
|
pidof -c -o %PPID -x glusterfsd &>/dev/null
|
|
|
|
|
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
pushd . > /dev/null 2>&1
|
|
|
|
for volume in /var/lib/glusterd/vols/*; do cd $volume;
|
|
|
|
vol_type=`grep '^type=' info | awk -F'=' '{print $2}'`
|
|
|
|
volume_started=`grep '^status=' info | awk -F'=' '{print $2}'`
|
|
|
|
if [ $vol_type -eq 0 ] && [ $volume_started -eq 1 ] ; then
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
popd > /dev/null 2>&1
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
]]
|
|
|
|
|
2019-02-12 16:22:52 +00:00
|
|
|
ok, how, val = os.execute(script)
|
2017-11-15 13:56:13 +00:00
|
|
|
if not (ok == 0) then
|
|
|
|
error("Detected running glusterfs processes", ok)
|
|
|
|
end
|
|
|
|
%endif
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
%pretrans server -p <lua>
|
|
|
|
if not posix.access("/bin/bash", "x") then
|
|
|
|
-- initial installation, no shell, no running glusterfsd
|
|
|
|
return 0
|
|
|
|
end
|
|
|
|
|
|
|
|
-- TODO: move this completely to a lua script
|
|
|
|
-- For now, we write a temporary bash script and execute that.
|
|
|
|
|
|
|
|
script = [[#!/bin/sh
|
|
|
|
pidof -c -o %PPID -x glusterfsd &>/dev/null
|
|
|
|
|
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
pushd . > /dev/null 2>&1
|
|
|
|
for volume in /var/lib/glusterd/vols/*; do cd $volume;
|
|
|
|
vol_type=`grep '^type=' info | awk -F'=' '{print $2}'`
|
|
|
|
volume_started=`grep '^status=' info | awk -F'=' '{print $2}'`
|
|
|
|
if [ $vol_type -eq 0 ] && [ $volume_started -eq 1 ] ; then
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
popd > /dev/null 2>&1
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
]]
|
|
|
|
|
2019-02-12 16:22:52 +00:00
|
|
|
ok, how, val = os.execute(script)
|
2017-11-15 13:56:13 +00:00
|
|
|
if not (ok == 0) then
|
|
|
|
error("Detected running glusterfs processes", ok)
|
|
|
|
end
|
|
|
|
|
|
|
|
%posttrans server
|
|
|
|
pidof -c -o %PPID -x glusterd &> /dev/null
|
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
kill -9 `pgrep -f gsyncd.py` &> /dev/null
|
|
|
|
|
|
|
|
killall --wait -SIGTERM glusterd &> /dev/null
|
|
|
|
|
|
|
|
if [ "$?" != "0" ]; then
|
|
|
|
echo "killall failed while killing glusterd"
|
|
|
|
fi
|
|
|
|
|
|
|
|
glusterd --xlator-option *.upgrade=on -N
|
|
|
|
|
|
|
|
#Cleaning leftover glusterd socket file which is created by glusterd in
|
|
|
|
#rpm_script_t context.
|
|
|
|
rm -rf /var/run/glusterd.socket
|
|
|
|
|
|
|
|
# glusterd _was_ running, we killed it, it exited after *.upgrade=on,
|
|
|
|
# so start it again
|
2019-04-08 03:04:00 +00:00
|
|
|
%service_start glusterd
|
2017-11-15 13:56:13 +00:00
|
|
|
else
|
|
|
|
glusterd --xlator-option *.upgrade=on -N
|
|
|
|
|
|
|
|
#Cleaning leftover glusterd socket file which is created by glusterd in
|
|
|
|
#rpm_script_t context.
|
|
|
|
rm -rf /var/run/glusterd.socket
|
|
|
|
fi
|
|
|
|
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%changelog
|
2019-04-08 03:04:00 +00:00
|
|
|
* Mon Apr 08 2019 Milind Changire <mchangir@redhat.com> - 6.0-1
|
|
|
|
- rebase to upstream glusterfs at v6.0
|
|
|
|
- fixes bugs bz#1493284 bz#1578703 bz#1600918 bz#1670415 bz#1691620
|
|
|
|
bz#1693935 bz#1695057
|
2017-11-15 13:56:13 +00:00
|
|
|
|