2414 lines
95 KiB
RPMSpec
2414 lines
95 KiB
RPMSpec
%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
|
|
##
|
|
|
|
# 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}
|
|
|
|
%if ( 0%{?rhel} && 0%{?rhel} < 7 )
|
|
%global _with_asan %{nil}
|
|
%endif
|
|
|
|
# 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
|
|
# if you wish to compile an rpm with cmocka unit testing...
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --with cmocka
|
|
%{?_with_cmocka:%global _with_cmocka --enable-cmocka}
|
|
|
|
# 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}
|
|
|
|
# epoll
|
|
# if you wish to compile an rpm without epoll...
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --without epoll
|
|
%{?_without_epoll:%global _without_epoll --disable-epoll}
|
|
|
|
# fusermount
|
|
# if you wish to compile an rpm without fusermount...
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --without fusermount
|
|
%{?_without_fusermount:%global _without_fusermount --disable-fusermount}
|
|
|
|
# geo-rep
|
|
# if you wish to compile an rpm without geo-replication support, compile like this...
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --without georeplication
|
|
%{?_without_georeplication:%global _without_georeplication --disable-georeplication}
|
|
|
|
# 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
|
|
%endif
|
|
|
|
|
|
# ocf
|
|
# if you wish to compile an rpm without the OCF resource agents...
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --without ocf
|
|
%{?_without_ocf:%global _without_ocf --without-ocf}
|
|
|
|
# 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" ) || ( "%{?dist}" == ".el8rhgs" )))
|
|
%global _without_server --without-server
|
|
%endif
|
|
%endif
|
|
|
|
%global _without_extra_xlators 1
|
|
%global _without_regression_tests 1
|
|
|
|
# syslog
|
|
# if you wish to build rpms without syslog logging, compile like this
|
|
# rpmbuild -ta glusterfs-6.0.tar.gz --without syslog
|
|
%{?_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
|
|
|
|
# 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}
|
|
|
|
%if ( 0%{?rhel} && 0%{?rhel} < 7 )
|
|
%global _with_tsan %{nil}
|
|
%endif
|
|
|
|
# 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}
|
|
|
|
##-----------------------------------------------------------------------------
|
|
## All %%global definitions should be placed here and keep them sorted
|
|
##
|
|
|
|
%if ( 0%{?fedora} ) || ( 0%{?rhel} && 0%{?rhel} > 6 )
|
|
%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
|
|
|
|
# without server should also disable some server-only components
|
|
%if 0%{?_without_server:1}
|
|
%global _without_events --disable-events
|
|
%global _without_georeplication --disable-georeplication
|
|
%global _without_tiering --disable-tiering
|
|
%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
|
|
%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} )
|
|
%global service_enable() /bin/systemctl --quiet enable %1.service || : \
|
|
%{nil}
|
|
%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}
|
|
# can't seem to make a generic macro that works
|
|
%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
|
|
%else
|
|
%global service_enable() /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}
|
|
# can't seem to make a generic macro that works
|
|
%global glusterd_svcfile %{_sysconfdir}/init.d/glusterd
|
|
%global glusterfsd_svcfile %{_sysconfdir}/init.d/glusterfsd
|
|
%global glustereventsd_svcfile %{_sysconfdir}/init.d/glustereventsd
|
|
%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
|
|
Version: 6.0
|
|
Release: 20%{?dist}
|
|
ExcludeArch: i686
|
|
%endif
|
|
License: GPLv2 or LGPLv3+
|
|
URL: http://docs.gluster.org/
|
|
%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
|
|
Source0: glusterfs-6.0.tar.gz
|
|
%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
|
|
%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
|
|
BuildRequires: git
|
|
BuildRequires: bison flex
|
|
BuildRequires: gcc make libtool
|
|
BuildRequires: ncurses-devel readline-devel
|
|
BuildRequires: libxml2-devel openssl-devel
|
|
BuildRequires: libaio-devel libacl-devel
|
|
BuildRequires: python%{_pythonver}-devel
|
|
%if ( 0%{?rhel} && 0%{?rhel} < 8 )
|
|
BuildRequires: python-ctypes
|
|
%endif
|
|
%if ( 0%{?_with_ipv6default:1} ) || ( 0%{!?_without_libtirpc:1} ) || ( 0%{?rhel} && ( 0%{?rhel} >= 8 ) )
|
|
BuildRequires: libtirpc-devel
|
|
%endif
|
|
%if ( 0%{?fedora} && 0%{?fedora} > 27 ) || ( 0%{?rhel} && 0%{?rhel} > 7 )
|
|
BuildRequires: rpcgen
|
|
%endif
|
|
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_tiering:1} )
|
|
BuildRequires: sqlite-devel
|
|
%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
|
|
%if ( 0%{!?_with_gnfs:1} )
|
|
Obsoletes: %{name}-gnfs
|
|
%endif
|
|
%if ( 0%{?rhel} < 7 )
|
|
Obsoletes: %{name}-ganesha
|
|
%endif
|
|
Provides: %{name}-common = %{version}-%{release}
|
|
Provides: %{name}-core = %{version}-%{release}
|
|
|
|
# Patch0001: 0001-Update-rfc.sh-to-rhgs-3.5.0.patch
|
|
Patch0002: 0002-glusterd-fix-op-versions-for-RHS-backwards-compatabi.patch
|
|
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
|
|
Patch0053: 0053-Revert-packaging-ganesha-remove-glusterfs-ganesha-su.patch
|
|
Patch0054: 0054-Revert-glusterd-storhaug-remove-ganesha.patch
|
|
Patch0055: 0055-Revert-storhaug-HA-first-step-remove-resource-agents.patch
|
|
Patch0056: 0056-common-ha-fixes-for-Debian-based-systems.patch
|
|
Patch0057: 0057-ganesha-scripts-Remove-export-entries-from-ganesha.c.patch
|
|
Patch0058: 0058-glusterd-ganesha-During-volume-delete-remove-the-gan.patch
|
|
Patch0059: 0059-glusterd-ganesha-throw-proper-error-for-gluster-nfs-.patch
|
|
Patch0060: 0060-ganesha-scripts-Stop-ganesha-process-on-all-nodes-if.patch
|
|
Patch0061: 0061-ganesha-allow-refresh-config-and-volume-export-unexp.patch
|
|
Patch0062: 0062-glusterd-ganesha-perform-removal-of-ganesha.conf-on-.patch
|
|
Patch0063: 0063-glusterd-ganesha-update-cache-invalidation-properly-.patch
|
|
Patch0064: 0064-glusterd-ganesha-return-proper-value-in-pre_setup.patch
|
|
Patch0065: 0065-ganesha-scripts-remove-dependency-over-export-config.patch
|
|
Patch0066: 0066-glusterd-ganesha-add-proper-NULL-check-in-manage_exp.patch
|
|
Patch0067: 0067-ganesha-minor-improvments-for-commit-e91cdf4-17081.patch
|
|
Patch0068: 0068-common-ha-surviving-ganesha.nfsd-not-put-in-grace-on.patch
|
|
Patch0069: 0069-common-ha-enable-and-disable-selinux-ganesha_use_fus.patch
|
|
Patch0070: 0070-packaging-glusterfs-ganesha-update-sometimes-fails-s.patch
|
|
Patch0071: 0071-common-ha-enable-and-disable-selinux-gluster_use_exe.patch
|
|
Patch0072: 0072-ganesha-ha-don-t-set-SELinux-booleans-if-SELinux-is-.patch
|
|
Patch0073: 0073-build-remove-ganesha-dependency-on-selinux-policy.patch
|
|
Patch0074: 0074-common-ha-enable-pacemaker-at-end-of-setup.patch
|
|
Patch0075: 0075-common-ha-Fix-an-incorrect-syntax-during-setup.patch
|
|
Patch0076: 0076-glusterd-ganesha-change-voltype-for-ganesha.enable-i.patch
|
|
Patch0077: 0077-glusterd-ganesha-create-remove-export-file-only-from.patch
|
|
Patch0078: 0078-common-ha-scripts-pass-the-list-of-servers-properly-.patch
|
|
Patch0079: 0079-common-ha-All-statd-related-files-need-to-be-owned-b.patch
|
|
Patch0080: 0080-glusterd-ganesha-Skip-non-ganesha-nodes-properly-for.patch
|
|
Patch0081: 0081-ganesha-ha-ensure-pacemaker-is-enabled-after-setup.patch
|
|
Patch0082: 0082-build-Add-dependency-on-netstat-for-glusterfs-ganesh.patch
|
|
Patch0083: 0083-common-ha-enable-and-disable-selinux-ganesha_use_fus.patch
|
|
Patch0084: 0084-glusterd-Fix-duplicate-client_op_version-in-info-fil.patch
|
|
Patch0085: 0085-Revert-all-remove-code-which-is-not-being-considered.patch
|
|
Patch0086: 0086-Revert-tiering-remove-the-translator-from-build-and-.patch
|
|
Patch0087: 0087-ganesha-fixing-minor-issues-after-the-backport-from-.patch
|
|
Patch0088: 0088-tier-fix-failures-noticed-during-tier-start-and-tier.patch
|
|
Patch0089: 0089-glusterd-gNFS-On-post-upgrade-to-3.2-disable-gNFS-fo.patch
|
|
Patch0090: 0090-Revert-build-conditionally-build-legacy-gNFS-server-.patch
|
|
Patch0091: 0091-glusterd-gNFS-explicitly-set-nfs.disable-to-off-afte.patch
|
|
Patch0092: 0092-logging-Fix-GF_LOG_OCCASSIONALLY-API.patch
|
|
Patch0093: 0093-glusterd-Change-op-version-of-cache-invalidation-in-.patch
|
|
Patch0094: 0094-glusterd-load-ctime-in-the-client-graph-only-if-it-s.patch
|
|
Patch0095: 0095-cluster-afr-Remove-local-from-owners_list-on-failure.patch
|
|
Patch0096: 0096-core-Brick-is-not-able-to-detach-successfully-in-bri.patch
|
|
Patch0097: 0097-glusterd-tier-while-doing-an-attach-tier-the-self-he.patch
|
|
Patch0098: 0098-mgmt-shd-Implement-multiplexing-in-self-heal-daemon.patch
|
|
Patch0099: 0099-client-fini-return-fini-after-rpc-cleanup.patch
|
|
Patch0100: 0100-clnt-rpc-ref-leak-during-disconnect.patch
|
|
Patch0101: 0101-shd-mux-Fix-coverity-issues-introduced-by-shd-mux-pa.patch
|
|
Patch0102: 0102-rpc-transport-Missing-a-ref-on-dict-while-creating-t.patch
|
|
Patch0103: 0103-dht-NULL-check-before-setting-error-flag.patch
|
|
Patch0104: 0104-afr-shd-Cleanup-self-heal-daemon-resources-during-af.patch
|
|
Patch0105: 0105-core-Log-level-changes-do-not-effect-on-running-clie.patch
|
|
Patch0106: 0106-libgfchangelog-use-find_library-to-locate-shared-lib.patch
|
|
Patch0107: 0107-gfapi-add-function-to-set-client-pid.patch
|
|
Patch0108: 0108-afr-add-client-pid-to-all-gf_event-calls.patch
|
|
Patch0109: 0109-glusterd-Optimize-glusterd-handshaking-code-path.patch
|
|
Patch0110: 0110-tier-shd-glusterd-with-shd-mux-the-shd-volfile-path-.patch
|
|
Patch0111: 0111-glusterd-fix-loading-ctime-in-client-graph-logic.patch
|
|
Patch0112: 0112-geo-rep-fix-incorrectly-formatted-authorized_keys.patch
|
|
Patch0113: 0113-spec-Glusterd-did-not-start-by-default-after-node-re.patch
|
|
Patch0114: 0114-core-fix-hang-issue-in-__gf_free.patch
|
|
Patch0115: 0115-core-only-log-seek-errors-if-SEEK_HOLE-SEEK_DATA-is-.patch
|
|
Patch0116: 0116-cluster-ec-fix-fd-reopen.patch
|
|
Patch0117: 0117-spec-Remove-thin-arbiter-package.patch
|
|
Patch0118: 0118-tests-mark-thin-arbiter-test-ta.t-as-bad.patch
|
|
Patch0119: 0119-glusterd-provide-a-way-to-detach-failed-node.patch
|
|
Patch0120: 0120-glusterd-shd-Keep-a-ref-on-volinfo-until-attach-rpc-.patch
|
|
Patch0121: 0121-spec-glusterfs-devel-for-client-build-should-not-dep.patch
|
|
Patch0122: 0122-posix-ctime-Fix-stat-time-attributes-inconsistency-d.patch
|
|
Patch0123: 0123-ctime-Fix-log-repeated-logging-during-open.patch
|
|
Patch0124: 0124-spec-remove-duplicate-references-to-files.patch
|
|
Patch0125: 0125-glusterd-define-dumpops-in-the-xlator_api-of-gluster.patch
|
|
Patch0126: 0126-cluster-dht-refactor-dht-lookup-functions.patch
|
|
Patch0127: 0127-cluster-dht-Refactor-dht-lookup-functions.patch
|
|
Patch0128: 0128-glusterd-Fix-bulkvoldict-thread-logic-in-brick-multi.patch
|
|
Patch0129: 0129-core-handle-memory-accounting-correctly.patch
|
|
Patch0130: 0130-tier-test-new-tier-cmds.t-fails-after-a-glusterd-res.patch
|
|
Patch0131: 0131-tests-dht-Test-that-lookups-are-sent-post-brick-up.patch
|
|
Patch0132: 0132-glusterd-remove-duplicate-occurrence-of-features.sel.patch
|
|
Patch0133: 0133-glusterd-enable-fips-mode-rchecksum-for-new-volumes.patch
|
|
Patch0134: 0134-performance-write-behind-remove-request-from-wip-lis.patch
|
|
Patch0135: 0135-geo-rep-fix-incorrectly-formatted-authorized_keys.patch
|
|
Patch0136: 0136-glusterd-fix-inconsistent-global-option-output-in-vo.patch
|
|
Patch0137: 0137-shd-glusterd-Serialize-shd-manager-to-prevent-race-c.patch
|
|
Patch0138: 0138-glusterd-Add-gluster-volume-stop-operation-to-gluste.patch
|
|
Patch0139: 0139-ec-shd-Cleanup-self-heal-daemon-resources-during-ec-.patch
|
|
Patch0140: 0140-cluster-ec-Reopen-shouldn-t-happen-with-O_TRUNC.patch
|
|
Patch0141: 0141-socket-ssl-fix-crl-handling.patch
|
|
Patch0142: 0142-lock-check-null-value-of-dict-to-avoid-log-flooding.patch
|
|
Patch0143: 0143-packaging-Change-the-dependency-on-nfs-ganesha-to-2..patch
|
|
Patch0144: 0144-cluster-ec-honor-contention-notifications-for-partia.patch
|
|
Patch0145: 0145-core-Capture-process-memory-usage-at-the-time-of-cal.patch
|
|
Patch0146: 0146-dht-Custom-xattrs-are-not-healed-in-case-of-add-bric.patch
|
|
Patch0147: 0147-glusterd-bulkvoldict-thread-is-not-handling-all-volu.patch
|
|
Patch0148: 0148-cluster-dht-Lookup-all-files-when-processing-directo.patch
|
|
Patch0149: 0149-glusterd-Optimize-code-to-copy-dictionary-in-handsha.patch
|
|
Patch0150: 0150-libglusterfs-define-macros-needed-for-cloudsync.patch
|
|
Patch0151: 0151-mgmt-glusterd-Make-changes-related-to-cloudsync-xlat.patch
|
|
Patch0152: 0152-storage-posix-changes-with-respect-to-cloudsync.patch
|
|
Patch0153: 0153-features-cloudsync-Added-some-new-functions.patch
|
|
Patch0154: 0154-cloudsync-cvlt-Cloudsync-plugin-for-commvault-store.patch
|
|
Patch0155: 0155-cloudsync-Make-readdirp-return-stat-info-of-all-the-.patch
|
|
Patch0156: 0156-cloudsync-Fix-bug-in-cloudsync-fops-c.py.patch
|
|
Patch0157: 0157-afr-frame-Destroy-frame-after-afr_selfheal_entry_gra.patch
|
|
Patch0158: 0158-glusterfsd-cleanup-Protect-graph-object-under-a-lock.patch
|
|
Patch0159: 0159-glusterd-add-an-op-version-check.patch
|
|
Patch0160: 0160-geo-rep-Geo-rep-help-text-issue.patch
|
|
Patch0161: 0161-geo-rep-Fix-rename-with-existing-destination-with-sa.patch
|
|
Patch0162: 0162-geo-rep-Fix-sync-method-config.patch
|
|
Patch0163: 0163-geo-rep-Fix-sync-hang-with-tarssh.patch
|
|
Patch0164: 0164-cluster-ec-Fix-handling-of-heal-info-cases-without-l.patch
|
|
Patch0165: 0165-tests-shd-Add-test-coverage-for-shd-mux.patch
|
|
Patch0166: 0166-glusterd-svc-glusterd_svcs_stop-should-call-individu.patch
|
|
Patch0167: 0167-glusterd-shd-Optimize-the-glustershd-manager-to-send.patch
|
|
Patch0168: 0168-cluster-dht-Fix-directory-perms-during-selfheal.patch
|
|
Patch0169: 0169-Build-Fix-spec-to-enable-rhel8-client-build.patch
|
|
Patch0170: 0170-geo-rep-Convert-gfid-conflict-resolutiong-logs-into-.patch
|
|
Patch0171: 0171-posix-add-storage.reserve-size-option.patch
|
|
Patch0172: 0172-ec-fini-Fix-race-with-ec_fini-and-ec_notify.patch
|
|
Patch0173: 0173-glusterd-store-fips-mode-rchecksum-option-in-the-inf.patch
|
|
Patch0174: 0174-xlator-log-Add-more-logging-in-xlator_is_cleanup_sta.patch
|
|
Patch0175: 0175-ec-fini-Fix-race-between-xlator-cleanup-and-on-going.patch
|
|
Patch0176: 0176-features-shard-Fix-crash-during-background-shard-del.patch
|
|
Patch0177: 0177-features-shard-Fix-extra-unref-when-inode-object-is-.patch
|
|
Patch0178: 0178-Cluster-afr-Don-t-treat-all-bricks-having-metadata-p.patch
|
|
Patch0179: 0179-tests-Fix-split-brain-favorite-child-policy.t-failur.patch
|
|
Patch0180: 0180-ganesha-scripts-Make-generate-epoch.py-python3-compa.patch
|
|
Patch0181: 0181-afr-log-before-attempting-data-self-heal.patch
|
|
Patch0182: 0182-geo-rep-fix-mountbroker-setup.patch
|
|
Patch0183: 0183-glusterd-svc-Stop-stale-process-using-the-glusterd_p.patch
|
|
Patch0184: 0184-tests-Add-gating-configuration-file-for-rhel8.patch
|
|
Patch0185: 0185-gfapi-provide-an-api-for-setting-statedump-path.patch
|
|
Patch0186: 0186-cli-Remove-brick-warning-seems-unnecessary.patch
|
|
Patch0187: 0187-gfapi-statedump_path-add-proper-version-number.patch
|
|
Patch0188: 0188-features-shard-Fix-integer-overflow-in-block-count-a.patch
|
|
Patch0189: 0189-features-shard-Fix-block-count-accounting-upon-trunc.patch
|
|
Patch0190: 0190-Build-removing-the-hardcoded-usage-of-python3.patch
|
|
Patch0191: 0191-Build-Update-python-shebangs-based-on-version.patch
|
|
Patch0192: 0192-build-Ensure-gluster-cli-package-is-built-as-part-of.patch
|
|
Patch0193: 0193-spec-fixed-python-dependency-for-rhel6.patch
|
|
Patch0194: 0194-stack-Make-sure-to-have-unique-call-stacks-in-all-ca.patch
|
|
Patch0195: 0195-build-package-glusterfs-ganesha-for-rhel7-and-above.patch
|
|
Patch0196: 0196-posix-ctime-Fix-ctime-upgrade-issue.patch
|
|
Patch0197: 0197-posix-fix-crash-in-posix_cs_set_state.patch
|
|
Patch0198: 0198-cluster-ec-Prevent-double-pre-op-xattrops.patch
|
|
Patch0199: 0199-upcall-Avoid-sending-notifications-for-invalid-inode.patch
|
|
Patch0200: 0200-gfapi-fix-incorrect-initialization-of-upcall-syncop-.patch
|
|
Patch0201: 0201-geo-rep-Fix-permissions-for-GEOREP_DIR-in-non-root-s.patch
|
|
Patch0202: 0202-shd-mux-Fix-race-between-mux_proc-unlink-and-stop.patch
|
|
Patch0203: 0203-glusterd-shd-Change-shd-logfile-to-a-unique-name.patch
|
|
Patch0204: 0204-glusterd-conditionally-clear-txn_opinfo-in-stage-op.patch
|
|
Patch0205: 0205-glusterd-Can-t-run-rebalance-due-to-long-unix-socket.patch
|
|
Patch0206: 0206-glusterd-ignore-user.-options-from-compatibility-che.patch
|
|
Patch0207: 0207-glusterd-fix-use-after-free-of-a-dict_t.patch
|
|
Patch0208: 0208-mem-pool-remove-dead-code.patch
|
|
Patch0209: 0209-core-avoid-dynamic-TLS-allocation-when-possible.patch
|
|
Patch0210: 0210-mem-pool.-c-h-minor-changes.patch
|
|
Patch0211: 0211-libglusterfs-Fix-compilation-when-disable-mempool-is.patch
|
|
Patch0212: 0212-core-fix-memory-allocation-issues.patch
|
|
Patch0213: 0213-cluster-dht-Strip-out-dht-xattrs.patch
|
|
Patch0214: 0214-geo-rep-Upgrading-config-file-to-new-version.patch
|
|
Patch0215: 0215-posix-modify-storage.reserve-option-to-take-size-and.patch
|
|
Patch0216: 0216-Test-case-fixe-for-downstream-3.5.0.patch
|
|
Patch0217: 0217-uss-Fix-tar-issue-with-ctime-and-uss-enabled.patch
|
|
Patch0218: 0218-graph-shd-Use-glusterfs_graph_deactivate-to-free-the.patch
|
|
Patch0219: 0219-posix-add-posix_set_ctime-in-posix_ftruncate.patch
|
|
Patch0220: 0220-graph-shd-Use-top-down-approach-while-cleaning-xlato.patch
|
|
Patch0221: 0221-protocol-client-propagte-GF_EVENT_CHILD_PING-only-fo.patch
|
|
Patch0222: 0222-cluster-dht-Fixed-a-memleak-in-dht_rename_cbk.patch
|
|
Patch0223: 0223-change-get_real_filename-implementation-to-use-ENOAT.patch
|
|
Patch0224: 0224-core-replace-inet_addr-with-inet_pton.patch
|
|
Patch0225: 0225-tests-utils-Fix-py2-py3-util-python-scripts.patch
|
|
Patch0226: 0226-geo-rep-fix-gluster-command-path-for-non-root-sessio.patch
|
|
Patch0227: 0227-glusterd-svc-update-pid-of-mux-volumes-from-the-shd-.patch
|
|
Patch0228: 0228-locks-enable-notify-contention-by-default.patch
|
|
Patch0229: 0229-glusterd-Show-the-correct-brick-status-in-get-state.patch
|
|
Patch0230: 0230-Revert-glusterd-svc-update-pid-of-mux-volumes-from-t.patch
|
|
Patch0231: 0231-Revert-graph-shd-Use-top-down-approach-while-cleanin.patch
|
|
Patch0232: 0232-cluster-afr-Fix-incorrect-reporting-of-gfid-type-mis.patch
|
|
Patch0233: 0233-Revert-graph-shd-Use-glusterfs_graph_deactivate-to-f.patch
|
|
Patch0234: 0234-Revert-glusterd-shd-Change-shd-logfile-to-a-unique-n.patch
|
|
Patch0235: 0235-Revert-glusterd-svc-Stop-stale-process-using-the-glu.patch
|
|
Patch0236: 0236-Revert-shd-mux-Fix-race-between-mux_proc-unlink-and-.patch
|
|
Patch0237: 0237-Revert-ec-fini-Fix-race-between-xlator-cleanup-and-o.patch
|
|
Patch0238: 0238-Revert-xlator-log-Add-more-logging-in-xlator_is_clea.patch
|
|
Patch0239: 0239-Revert-ec-fini-Fix-race-with-ec_fini-and-ec_notify.patch
|
|
Patch0240: 0240-Revert-glusterd-shd-Optimize-the-glustershd-manager-.patch
|
|
Patch0241: 0241-Revert-glusterd-svc-glusterd_svcs_stop-should-call-i.patch
|
|
Patch0242: 0242-Revert-tests-shd-Add-test-coverage-for-shd-mux.patch
|
|
Patch0243: 0243-Revert-glusterfsd-cleanup-Protect-graph-object-under.patch
|
|
Patch0244: 0244-Revert-ec-shd-Cleanup-self-heal-daemon-resources-dur.patch
|
|
Patch0245: 0245-Revert-shd-glusterd-Serialize-shd-manager-to-prevent.patch
|
|
Patch0246: 0246-Revert-glusterd-shd-Keep-a-ref-on-volinfo-until-atta.patch
|
|
Patch0247: 0247-Revert-afr-shd-Cleanup-self-heal-daemon-resources-du.patch
|
|
Patch0248: 0248-Revert-shd-mux-Fix-coverity-issues-introduced-by-shd.patch
|
|
Patch0249: 0249-Revert-client-fini-return-fini-after-rpc-cleanup.patch
|
|
Patch0250: 0250-Revert-mgmt-shd-Implement-multiplexing-in-self-heal-.patch
|
|
Patch0251: 0251-tests-Fix-bug-1717819-metadata-split-brain-detection.patch
|
|
Patch0252: 0252-glusterd-do-not-mark-skip_locking-as-true-for-geo-re.patch
|
|
Patch0253: 0253-core-fix-deadlock-between-statedump-and-fd_anonymous.patch
|
|
Patch0254: 0254-Detach-iot_worker-to-release-its-resources.patch
|
|
Patch0255: 0255-Revert-tier-shd-glusterd-with-shd-mux-the-shd-volfil.patch
|
|
Patch0256: 0256-features-snapview-server-use-the-same-volfile-server.patch
|
|
Patch0257: 0257-geo-rep-Test-case-for-upgrading-config-file.patch
|
|
Patch0258: 0258-geo-rep-Fix-mount-broker-setup-issue.patch
|
|
Patch0259: 0259-gluster-block-tuning-perf-options.patch
|
|
Patch0260: 0260-ctime-Set-mdata-xattr-on-legacy-files.patch
|
|
Patch0261: 0261-features-utime-Fix-mem_put-crash.patch
|
|
Patch0262: 0262-glusterd-ctime-Disable-ctime-by-default.patch
|
|
Patch0263: 0263-tests-fix-ctime-related-tests.patch
|
|
Patch0264: 0264-gfapi-Fix-deadlock-while-processing-upcall.patch
|
|
Patch0265: 0265-fuse-add-missing-GF_FREE-to-fuse_interrupt.patch
|
|
Patch0266: 0266-geo-rep-Fix-mount-broker-setup-issue.patch
|
|
Patch0267: 0267-posix-ctime-Fix-race-during-lookup-ctime-xattr-heal.patch
|
|
Patch0268: 0268-rpc-transport-have-default-listen-port.patch
|
|
Patch0269: 0269-ec-fix-truncate-lock-to-cover-the-write-in-tuncate-c.patch
|
|
Patch0270: 0270-cluster-ec-inherit-healing-from-lock-when-it-has-inf.patch
|
|
Patch0271: 0271-cluster-ec-fix-EIO-error-for-concurrent-writes-on-sp.patch
|
|
Patch0272: 0272-cluster-ec-Always-read-from-good-mask.patch
|
|
Patch0273: 0273-cluster-ec-Fix-reopen-flags-to-avoid-misbehavior.patch
|
|
Patch0274: 0274-cluster-ec-Update-lock-good_mask-on-parent-fop-failu.patch
|
|
Patch0275: 0275-cluster-ec-Create-heal-task-with-heal-process-id.patch
|
|
Patch0276: 0276-features-utime-always-update-ctime-at-setattr.patch
|
|
Patch0277: 0277-geo-rep-Fix-Config-Get-Race.patch
|
|
Patch0278: 0278-geo-rep-Fix-worker-connection-issue.patch
|
|
Patch0279: 0279-posix-In-brick_mux-brick-is-crashed-while-start-stop.patch
|
|
Patch0280: 0280-performance-md-cache-Do-not-skip-caching-of-null-cha.patch
|
|
Patch0281: 0281-ctime-Fix-incorrect-realtime-passed-to-frame-root-ct.patch
|
|
Patch0282: 0282-geo-rep-Fix-the-name-of-changelog-archive-file.patch
|
|
Patch0283: 0283-ctime-Fix-ctime-issue-with-utime-family-of-syscalls.patch
|
|
Patch0284: 0284-posix-log-aio_error-return-codes-in-posix_fs_health_.patch
|
|
Patch0285: 0285-glusterd-glusterd-service-is-getting-timed-out-on-sc.patch
|
|
Patch0286: 0286-glusterfs.spec.in-added-script-files-for-machine-com.patch
|
|
Patch0287: 0287-cluster-ec-Fail-fsync-flush-for-files-on-update-size.patch
|
|
Patch0288: 0288-cluster-ec-Fix-coverity-issues.patch
|
|
Patch0289: 0289-cluster-ec-quorum-count-implementation.patch
|
|
Patch0290: 0290-glusterd-tag-disperse.quorum-count-for-31306.patch
|
|
Patch0291: 0291-cluster-ec-Mark-release-only-when-it-is-acquired.patch
|
|
Patch0292: 0292-rpc-Update-address-family-if-it-is-not-provide-in-cm.patch
|
|
Patch0293: 0293-glusterd-IPV6-hostname-address-is-not-parsed-correct.patch
|
|
Patch0294: 0294-eventsapi-Set-IPv4-IPv6-family-based-on-input-IP.patch
|
|
Patch0295: 0295-ctime-rebalance-Heal-ctime-xattr-on-directory-during.patch
|
|
Patch0296: 0296-glusterfind-pre-command-failure-on-a-modify.patch
|
|
Patch0297: 0297-rpmbuild-fixing-the-build-errors-with-2a905a8ae.patch
|
|
Patch0298: 0298-geo-rep-fix-sub-command-during-worker-connection.patch
|
|
Patch0299: 0299-geo-rep-performance-improvement-while-syncing-rename.patch
|
|
Patch0300: 0300-cli-remove-the-warning-displayed-when-remove-brick-s.patch
|
|
Patch0301: 0301-posix-Brick-is-going-down-unexpectedly.patch
|
|
Patch0302: 0302-cluster-ec-prevent-filling-shd-log-with-table-not-fo.patch
|
|
Patch0303: 0303-posix-heketidbstorage-bricks-go-down-during-PVC-crea.patch
|
|
Patch0304: 0304-cluster-dht-Correct-fd-processing-loop.patch
|
|
Patch0305: 0305-glusterd-rebalance-start-should-fail-when-quorum-is-.patch
|
|
Patch0306: 0306-cli-fix-distCount-value.patch
|
|
Patch0307: 0307-ssl-fix-RHEL8-regression-failure.patch
|
|
Patch0308: 0308-dht-Rebalance-causing-IO-Error-File-descriptor-in-ba.patch
|
|
Patch0309: 0309-geo-rep-Fix-config-upgrade-on-non-participating-node.patch
|
|
Patch0310: 0310-tests-test-case-for-non-root-geo-rep-setup.patch
|
|
Patch0311: 0311-geo-rep-Fix-Permission-denied-traceback-on-non-root-.patch
|
|
Patch0312: 0312-Scripts-quota_fsck-script-KeyError-contri_size.patch
|
|
Patch0313: 0313-extras-Cgroup-CPU-Mem-restriction-are-not-working-on.patch
|
|
|
|
%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}
|
|
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
|
|
|
%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
|
|
Requires: %{name}-api%{?_isa} = %{version}-%{release}
|
|
|
|
%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.
|
|
|
|
%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
|
|
|
|
%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.
|
|
|
|
%package devel
|
|
Summary: Development Libraries
|
|
Requires: %{name}%{?_isa} = %{version}-%{release}
|
|
# Needed for the Glupy examples to work
|
|
%if ( 0%{!?_without_extra_xlators:1} )
|
|
Requires: %{name}-extra-xlators%{?_isa} = %{version}-%{release}
|
|
%endif
|
|
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
|
%if ( 0%{!?_without_server:1} )
|
|
Requires: %{name}-server%{?_isa} = %{version}-%{release}
|
|
%endif
|
|
|
|
%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
|
|
Requires: python%{_pythonver}-gluster = %{version}-%{release}
|
|
Requires: python%{_pythonver}
|
|
|
|
%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}
|
|
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
|
|
|
%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_server:1} && 0%{?rhel} > 6 )
|
|
%package ganesha
|
|
Summary: NFS-Ganesha configuration
|
|
Group: Applications/File
|
|
|
|
Requires: %{name}-server%{?_isa} = %{version}-%{release}
|
|
Requires: nfs-ganesha-gluster >= 2.7.3
|
|
Requires: pcs, dbus
|
|
%if ( 0%{?rhel} && 0%{?rhel} == 6 )
|
|
Requires: cman, pacemaker, corosync
|
|
%endif
|
|
|
|
%if ( 0%{?fedora} ) || ( 0%{?rhel} && 0%{?rhel} > 5 )
|
|
# we need portblock resource-agent in 3.9.5 and later.
|
|
Requires: resource-agents >= 3.9.5
|
|
Requires: net-tools
|
|
%endif
|
|
|
|
%if ( 0%{?fedora} && 0%{?fedora} > 25 || ( 0%{?rhel} && 0%{?rhel} > 6 ) )
|
|
%if ( 0%{?rhel} )
|
|
Requires: selinux-policy >= 3.13.1-160
|
|
Requires(post): policycoreutils-python
|
|
Requires(postun): policycoreutils-python
|
|
%else
|
|
Requires(post): policycoreutils-python-utils
|
|
Requires(postun): policycoreutils-python-utils
|
|
%endif
|
|
%endif
|
|
|
|
%description ganesha
|
|
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 configuration and related files for using
|
|
NFS-Ganesha as the NFS server using GlusterFS
|
|
%endif
|
|
|
|
%if ( 0%{!?_without_georeplication:1} )
|
|
%package geo-replication
|
|
Summary: GlusterFS Geo-replication
|
|
Requires: %{name}%{?_isa} = %{version}-%{release}
|
|
Requires: %{name}-server%{?_isa} = %{version}-%{release}
|
|
Requires: python%{_pythonver}
|
|
%if ( 0%{?rhel} && 0%{?rhel} < 7 )
|
|
Requires: python-prettytable
|
|
%else
|
|
Requires: python%{_pythonver}-prettytable
|
|
%endif
|
|
Requires: python%{_pythonver}-gluster = %{version}-%{release}
|
|
|
|
Requires: rsync
|
|
Requires: util-linux
|
|
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
|
|
|
%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
|
|
|
|
%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
|
|
|
|
%package -n python%{_pythonver}-gluster
|
|
Summary: GlusterFS python library
|
|
Requires: python%{_pythonver}
|
|
%if ( ! %{_usepython3} )
|
|
%{?python_provide:%python_provide python-gluster}
|
|
Provides: python-gluster = %{version}-%{release}
|
|
Obsoletes: python-gluster < 3.10
|
|
%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.
|
|
|
|
This package contains the python modules of GlusterFS and own gluster
|
|
namespace.
|
|
|
|
%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}
|
|
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
|
|
|
%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
|
|
Requires: python%{_pythonver}
|
|
Requires: attr dbench file git libacl-devel net-tools
|
|
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
|
|
|
|
%if ( 0%{!?_without_server:1} )
|
|
%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
|
|
Requires: nfs-utils
|
|
%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
|
|
%if ( 0%{?fedora} && 0%{?fedora} > 27 ) || ( 0%{?rhel} && 0%{?rhel} > 7 )
|
|
Requires: python%{_pythonver}-pyxattr
|
|
%else
|
|
Requires: pyxattr
|
|
%endif
|
|
%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
|
|
|
|
%package client-xlators
|
|
Summary: GlusterFS client-side translators
|
|
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
|
|
|
%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}
|
|
Requires: python%{_pythonver} python%{_pythonver}-prettytable
|
|
Requires: python%{_pythonver}-gluster = %{version}-%{release}
|
|
%if ( 0%{?rhel} && 0%{?rhel} < 8 )
|
|
Requires: python-requests
|
|
%else
|
|
Requires: python%{_pythonver}-requests
|
|
%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
|
|
rename_to=( $(grep -i 'rename to' $p | cut -f 3 -d ' ') )
|
|
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
|
|
|
|
# HACK to fix build
|
|
bn=$(basename $p)
|
|
if [ "$bn" == "0085-Revert-all-remove-code-which-is-not-being-considered.patch" ]; then
|
|
(patch -p1 -u -F3 < $p || :)
|
|
if [ -f libglusterfs/Makefile.am.rej ]; then
|
|
sed -i -e 's/^SUBDIRS = src/SUBDIRS = src src\/gfdb/g;s/^CLEANFILES = /CLEANFILES =/g' libglusterfs/Makefile.am
|
|
fi
|
|
elif [ "$bn" == "0053-Revert-packaging-ganesha-remove-glusterfs-ganesha-su.patch" ]; then
|
|
(patch -p1 < $p || :)
|
|
elif [ "$bn" == "0055-Revert-storhaug-HA-first-step-remove-resource-agents.patch" ]; then
|
|
(patch -p1 < $p || :)
|
|
elif [ "$bn" == "0090-Revert-build-conditionally-build-legacy-gNFS-server-.patch" ]; then
|
|
(patch -p1 < $p || :)
|
|
elif [ "$bn" == "0117-spec-Remove-thin-arbiter-package.patch" ]; then
|
|
(patch -p1 < $p || :)
|
|
elif [ "$bn" == "0023-hooks-remove-selinux-hooks.patch" ]; then
|
|
(patch -p1 < $p || :)
|
|
elif [ "$bn" == "0042-spec-client-server-Builds-are-failing-on-rhel-6.patch" ]; then
|
|
(patch -p1 < $p || :)
|
|
else
|
|
# apply the patch with 'git apply'
|
|
git apply -p1 --exclude=rfc.sh \
|
|
--exclude=.gitignore \
|
|
--exclude=.testignore \
|
|
--exclude=MAINTAINERS \
|
|
--exclude=extras/checkpatch.pl \
|
|
--exclude=build-aux/checkpatch.pl \
|
|
--exclude='tests/*' \
|
|
${EXCLUDE_DOCS_OPT} \
|
|
$p
|
|
fi
|
|
|
|
done
|
|
|
|
echo "fixing python shebangs..."
|
|
%if ( %{_usepython3} )
|
|
for i in `find . -type f -exec bash -c "if file {} | grep 'Python script, ASCII text executable' >/dev/null; then echo {}; fi" ';'`; do
|
|
sed -i -e 's|^#!/usr/bin/python.*|#!%{__python3}|' -e 's|^#!/usr/bin/env python.*|#!%{__python3}|' $i
|
|
done
|
|
%else
|
|
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
|
|
|
|
%build
|
|
|
|
# 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 \
|
|
%{?_with_asan} \
|
|
%{?_with_cmocka} \
|
|
%{?_with_debug} \
|
|
%{?_with_firewalld} \
|
|
%{?_with_tmpfilesdir} \
|
|
%{?_with_tsan} \
|
|
%{?_with_valgrind} \
|
|
%{?_without_epoll} \
|
|
%{?_without_events} \
|
|
%{?_without_fusermount} \
|
|
%{?_without_georeplication} \
|
|
%{?_without_ocf} \
|
|
%{?_without_rdma} \
|
|
%{?_without_server} \
|
|
%{?_without_syslog} \
|
|
%{?_without_tiering} \
|
|
%{?_with_ipv6default} \
|
|
%{?_without_libtirpc}
|
|
|
|
# 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}
|
|
%if ( 0%{!?_without_server:1} )
|
|
%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
|
|
|
|
%if ( 0%{!?_without_server:1} )
|
|
# 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
|
|
%endif
|
|
|
|
# Install glusterfsd .service or init.d file
|
|
%if ( 0%{!?_without_server:1} )
|
|
%if ( 0%{_for_fedora_koji_builds} )
|
|
%service_install glusterfsd %{glusterfsd_svcfile}
|
|
%endif
|
|
%endif
|
|
|
|
install -D -p -m 0644 extras/glusterfs-logrotate \
|
|
%{buildroot}%{_sysconfdir}/logrotate.d/glusterfs
|
|
|
|
# ganesha ghosts
|
|
%if ( 0%{!?_without_server:1} && 0%{?rhel} > 6 )
|
|
mkdir -p %{buildroot}%{_sysconfdir}/ganesha
|
|
touch %{buildroot}%{_sysconfdir}/ganesha/ganesha-ha.conf
|
|
mkdir -p %{buildroot}%{_localstatedir}/run/gluster/shared_storage/nfs-ganesha/
|
|
touch %{buildroot}%{_localstatedir}/run/gluster/shared_storage/nfs-ganesha/ganesha.conf
|
|
touch %{buildroot}%{_localstatedir}/run/gluster/shared_storage/nfs-ganesha/ganesha-ha.conf
|
|
%endif
|
|
|
|
%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
|
|
|
|
%if ( 0%{!?_without_server:1} )
|
|
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
|
|
%endif
|
|
|
|
find ./tests ./run-tests.sh -type f | cpio -pd %{buildroot}%{_prefix}/share/glusterfs
|
|
|
|
## Install bash completion for cli
|
|
install -p -m 0744 -D extras/command-completion/gluster.bash \
|
|
%{buildroot}%{_sysconfdir}/bash_completion.d/gluster
|
|
|
|
%if ( 0%{!?_without_server:1} )
|
|
echo "RHGS 3.5" > %{buildroot}%{_datadir}/glusterfs/release
|
|
%endif
|
|
|
|
%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 )
|
|
%systemd_postun_with_restart rsyslog
|
|
%endif
|
|
%endif
|
|
exit 0
|
|
|
|
%post api
|
|
/sbin/ldconfig
|
|
|
|
%if ( 0%{!?_without_events:1} )
|
|
%post events
|
|
%service_enable glustereventsd
|
|
%endif
|
|
|
|
%if ( 0%{!?_without_server:1} )
|
|
%if ( 0%{?fedora} && 0%{?fedora} > 25 || ( 0%{?rhel} && 0%{?rhel} > 6 ) )
|
|
%post ganesha
|
|
semanage boolean -m ganesha_use_fusefs --on
|
|
exit 0
|
|
%endif
|
|
%endif
|
|
|
|
%if ( 0%{!?_without_georeplication:1} )
|
|
%post geo-replication
|
|
if [ $1 -ge 1 ]; then
|
|
%systemd_postun_with_restart glusterd
|
|
fi
|
|
exit 0
|
|
%endif
|
|
|
|
%post libs
|
|
/sbin/ldconfig
|
|
|
|
%if ( 0%{!?_without_server:1} )
|
|
%post server
|
|
# Legacy server
|
|
%service_enable glusterd
|
|
%if ( 0%{_for_fedora_koji_builds} )
|
|
%service_enable glusterfsd
|
|
%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
|
|
if [ -f %glustereventsd_svcfile ]; then
|
|
%service_stop glustereventsd
|
|
%systemd_preun glustereventsd
|
|
fi
|
|
fi
|
|
exit 0
|
|
%endif
|
|
|
|
%if ( 0%{!?_without_server:1} )
|
|
%preun server
|
|
if [ $1 -eq 0 ]; then
|
|
if [ -f %glusterfsd_svcfile ]; then
|
|
%service_stop glusterfsd
|
|
fi
|
|
%service_stop glusterd
|
|
if [ -f %glusterfsd_svcfile ]; then
|
|
%systemd_preun glusterfsd
|
|
fi
|
|
%systemd_preun glusterd
|
|
fi
|
|
if [ $1 -ge 1 ]; then
|
|
if [ -f %glusterfsd_svcfile ]; then
|
|
%systemd_postun_with_restart glusterfsd
|
|
fi
|
|
%systemd_postun_with_restart glusterd
|
|
fi
|
|
exit 0
|
|
%endif
|
|
|
|
##-----------------------------------------------------------------------------
|
|
## All %%postun should be placed here and keep them sorted
|
|
##
|
|
%postun
|
|
%if ( 0%{!?_without_syslog:1} )
|
|
%if ( 0%{?fedora} ) || ( 0%{?rhel} && 0%{?rhel} >= 6 )
|
|
%systemd_postun_with_restart rsyslog
|
|
%endif
|
|
%endif
|
|
|
|
%if ( 0%{!?_without_server:1} )
|
|
%postun server
|
|
%if (0%{?_with_firewalld:1})
|
|
%firewalld_reload
|
|
%endif
|
|
exit 0
|
|
%endif
|
|
|
|
%if ( 0%{!?_without_server:1} )
|
|
%if ( 0%{?fedora} && 0%{?fedora} > 25 || ( 0%{?rhel} && 0%{?rhel} > 6 ) )
|
|
%postun ganesha
|
|
semanage boolean -m ganesha_use_fusefs --off
|
|
exit 0
|
|
%endif
|
|
%endif
|
|
|
|
##-----------------------------------------------------------------------------
|
|
## All %%trigger should be placed here and keep them sorted
|
|
##
|
|
%if ( 0%{!?_without_server:1} )
|
|
%if ( 0%{?fedora} && 0%{?fedora} > 25 || ( 0%{?rhel} && 0%{?rhel} > 6 ) )
|
|
%trigger ganesha -- selinux-policy-targeted
|
|
semanage boolean -m ganesha_use_fusefs --on
|
|
exit 0
|
|
%endif
|
|
%endif
|
|
|
|
##-----------------------------------------------------------------------------
|
|
## All %%triggerun should be placed here and keep them sorted
|
|
##
|
|
%if ( 0%{!?_without_server:1} )
|
|
%if ( 0%{?fedora} && 0%{?fedora} > 25 || ( 0%{?rhel} && 0%{?rhel} > 6 ) )
|
|
%triggerun ganesha -- selinux-policy-targeted
|
|
semanage boolean -m ganesha_use_fusefs --off
|
|
exit 0
|
|
%endif
|
|
%endif
|
|
|
|
##-----------------------------------------------------------------------------
|
|
## All %%files should be placed here and keep them grouped
|
|
##
|
|
%files
|
|
%doc ChangeLog COPYING-GPLV2 COPYING-LGPLV3 INSTALL README.md THANKS COMMITMENT
|
|
%{_mandir}/man8/*gluster*.8*
|
|
%if ( 0%{!?_without_server:1} )
|
|
%exclude %{_mandir}/man8/gluster.8*
|
|
%endif
|
|
%dir %{_localstatedir}/log/glusterfs
|
|
%if ( 0%{!?_without_rdma:1} )
|
|
%exclude %{_libdir}/glusterfs/%{version}%{?prereltag}/rpc-transport/rdma*
|
|
%endif
|
|
%if 0%{?!_without_server:1}
|
|
%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
|
|
%endif
|
|
%{_datadir}/glusterfs/scripts/identify-hangs.sh
|
|
%{_datadir}/glusterfs/scripts/collect-system-stats.sh
|
|
%{_datadir}/glusterfs/scripts/log_accounting.sh
|
|
# 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
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/debug/delay-gen.so
|
|
%{_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
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/utime.so
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/gfid-access.so
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/namespace.so
|
|
%{_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
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/cloudsync.so
|
|
%{_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
|
|
%if 0%{?_tmpfilesdir:1} && 0%{!?_without_server:1}
|
|
%{_tmpfilesdir}/gluster.conf
|
|
%endif
|
|
%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}
|
|
%if ( 0%{?_with_systemd:1} )
|
|
%exclude %{_datadir}/glusterfs/scripts/control-cpu-load.sh
|
|
%exclude %{_datadir}/glusterfs/scripts/control-mem.sh
|
|
%endif
|
|
%endif
|
|
|
|
%if ( 0%{?_without_server:1} || 0%{?rhel} < 7 )
|
|
#exclude ganesha related files for rhel 6 and client builds
|
|
%exclude %{_sysconfdir}/ganesha/ganesha-ha.conf.sample
|
|
%exclude %{_libexecdir}/ganesha/*
|
|
%exclude %{_prefix}/lib/ocf/resource.d/heartbeat/*
|
|
%if ( 0%{!?_without_server:1} )
|
|
%{_sharedstatedir}/glusterd/hooks/1/start/post/S31ganesha-start.sh
|
|
%endif
|
|
%endif
|
|
|
|
%exclude %{_datadir}/glusterfs/scripts/setup-thin-arbiter.sh
|
|
|
|
%if ( 0%{?_without_server:1} )
|
|
%exclude %{_sysconfdir}/glusterfs/thin-arbiter.vol
|
|
%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/*
|
|
|
|
%files cli
|
|
%{_sbindir}/gluster
|
|
%{_mandir}/man8/gluster.8*
|
|
%{_sysconfdir}/bash_completion.d/gluster
|
|
|
|
%files cloudsync-plugins
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/cloudsync-plugins
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/cloudsync-plugins/cloudsyncs3.so
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/cloudsync-plugins/cloudsynccvlt.so
|
|
|
|
%files devel
|
|
%dir %{_includedir}/glusterfs
|
|
%{_includedir}/glusterfs/*
|
|
%exclude %{_includedir}/glusterfs/api
|
|
%exclude %{_libdir}/libgfapi.so
|
|
%{_libdir}/*.so
|
|
%if ( 0%{?_without_server:1} )
|
|
%exclude %{_libdir}/pkgconfig/libgfchangelog.pc
|
|
%exclude %{_libdir}/libgfchangelog.so
|
|
%if ( 0%{!?_without_tiering:1} )
|
|
%exclude %{_libdir}/pkgconfig/libgfdb.pc
|
|
%endif
|
|
%else
|
|
%{_libdir}/pkgconfig/libgfchangelog.pc
|
|
%if ( 0%{!?_without_tiering:1} )
|
|
%{_libdir}/pkgconfig/libgfdb.pc
|
|
%endif
|
|
%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
|
|
%dir %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/playground
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/playground/template.so
|
|
%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
|
|
|
|
%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.*
|
|
%if ( 0%{!?_without_tiering:1} )
|
|
# libgfdb is only needed server-side
|
|
%exclude %{_libdir}/libgfdb.*
|
|
%endif
|
|
|
|
%files -n python%{_pythonver}-gluster
|
|
# introducing glusterfs module in site packages.
|
|
# so that all other gluster submodules can reside in the same namespace.
|
|
%if ( %{_usepython3} )
|
|
%dir %{python3_sitelib}/gluster
|
|
%{python3_sitelib}/gluster/__init__.*
|
|
%{python3_sitelib}/gluster/__pycache__
|
|
%{python3_sitelib}/gluster/cliutils
|
|
%else
|
|
%dir %{python2_sitelib}/gluster
|
|
%{python2_sitelib}/gluster/__init__.*
|
|
%{python2_sitelib}/gluster/cliutils
|
|
%endif
|
|
|
|
%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_server:1} && 0%{?rhel} > 6 )
|
|
%files ganesha
|
|
%dir %{_libexecdir}/ganesha
|
|
%{_sysconfdir}/ganesha/ganesha-ha.conf.sample
|
|
%{_libexecdir}/ganesha/*
|
|
%{_prefix}/lib/ocf/resource.d/heartbeat/*
|
|
%{_sharedstatedir}/glusterd/hooks/1/start/post/S31ganesha-start.sh
|
|
%ghost %attr(0644,-,-) %config(noreplace) %{_sysconfdir}/ganesha/ganesha-ha.conf
|
|
%ghost %dir %attr(0755,-,-) %{_localstatedir}/run/gluster/shared_storage/nfs-ganesha
|
|
%ghost %attr(0644,-,-) %config(noreplace) %{_localstatedir}/run/gluster/shared_storage/nfs-ganesha/ganesha.conf
|
|
%ghost %attr(0644,-,-) %config(noreplace) %{_localstatedir}/run/gluster/shared_storage/nfs-ganesha/ganesha-ha.conf
|
|
%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
|
|
|
|
%if ( 0%{!?_without_server:1} )
|
|
%files server
|
|
%doc extras/clear_xattrs.sh
|
|
%{_datadir}/glusterfs/scripts/xattr_analysis.py*
|
|
%{_datadir}/glusterfs/scripts/quota_fsck.py*
|
|
# sysconf
|
|
%config(noreplace) %{_sysconfdir}/glusterfs
|
|
%exclude %{_sysconfdir}/glusterfs/thin-arbiter.vol
|
|
%exclude %{_sysconfdir}/glusterfs/eventsconfig.json
|
|
%config(noreplace) %{_sysconfdir}/sysconfig/glusterd
|
|
%if ( 0%{_for_fedora_koji_builds} )
|
|
%config(noreplace) %{_sysconfdir}/sysconfig/glusterfsd
|
|
%endif
|
|
|
|
# init files
|
|
%glusterd_svcfile
|
|
%if ( 0%{_for_fedora_koji_builds} )
|
|
%glusterfsd_svcfile
|
|
%endif
|
|
%if ( 0%{?_with_systemd:1} )
|
|
%glusterfssharedstorage_svcfile
|
|
%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
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/sdfs.so
|
|
%if ( 0%{!?_without_tiering:1} )
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/changetimerecorder.so
|
|
%{_libdir}/libgfdb.so.*
|
|
%endif
|
|
%{_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
|
|
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/nfs*
|
|
%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
|
|
%ghost %attr(0600,-,-) %config(noreplace) %{_sharedstatedir}/glusterd/options
|
|
%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
|
|
%attr(0644,-,-) %{_sharedstatedir}/glusterd/groups/nl-cache
|
|
%attr(0644,-,-) %{_sharedstatedir}/glusterd/groups/db-workload
|
|
%attr(0644,-,-) %{_sharedstatedir}/glusterd/groups/distributed-virt
|
|
%attr(0644,-,-) %{_sharedstatedir}/glusterd/groups/samba
|
|
%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
|
|
%attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/add-brick/post/S13create-subdir-mounts.sh
|
|
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/add-brick/pre
|
|
%attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/add-brick/pre/S28Quota-enable-root-xattr-heal.sh
|
|
%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
|
|
%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
|
|
%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
|
|
%{_datadir}/glusterfs/release
|
|
%dir %{_datadir}/glusterfs/scripts
|
|
%{_datadir}/glusterfs/scripts/stop-all-gluster-processes.sh
|
|
%if ( 0%{?_with_systemd:1} )
|
|
%{_libexecdir}/glusterfs/mount-shared-storage.sh
|
|
%{_datadir}/glusterfs/scripts/control-cpu-load.sh
|
|
%{_datadir}/glusterfs/scripts/control-mem.sh
|
|
%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
|
|
# end of server files
|
|
%endif
|
|
|
|
# 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
|
|
|
|
##-----------------------------------------------------------------------------
|
|
## All %pretrans should be placed here and keep them sorted
|
|
##
|
|
%if 0%{!?_without_server:1}
|
|
%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
|
|
]]
|
|
|
|
ok, how, val = os.execute(script)
|
|
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
|
|
]]
|
|
|
|
ok, how, val = os.execute(script)
|
|
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
|
|
]]
|
|
|
|
ok, how, val = os.execute(script)
|
|
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
|
|
]]
|
|
|
|
ok, how, val = os.execute(script)
|
|
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
|
|
]]
|
|
|
|
ok, how, val = os.execute(script)
|
|
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
|
|
]]
|
|
|
|
ok, how, val = os.execute(script)
|
|
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
|
|
]]
|
|
|
|
ok, how, val = os.execute(script)
|
|
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
|
|
]]
|
|
|
|
ok, how, val = os.execute(script)
|
|
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
|
|
]]
|
|
|
|
ok, how, val = os.execute(script)
|
|
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
|
|
]]
|
|
|
|
ok, how, val = os.execute(script)
|
|
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
|
|
]]
|
|
|
|
ok, how, val = os.execute(script)
|
|
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
|
|
%service_start glusterd
|
|
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
|
|
* Wed Oct 23 2019 Rinku Kothiya <rkothiya@redhat.com> - 6.0-20
|
|
- fixes bugs bz#1719171 bz#1763412 bz#1764202
|
|
|
|
* Thu Oct 17 2019 Rinku Kothiya <rkothiya@redhat.com> - 6.0-19
|
|
- fixes bugs bz#1760939
|
|
|
|
* Wed Oct 16 2019 Rinku Kothiya <rkothiya@redhat.com> - 6.0-18
|
|
- fixes bugs bz#1758432
|
|
|
|
* Fri Oct 11 2019 Rinku Kothiya <rkothiya@redhat.com> - 6.0-17
|
|
- fixes bugs bz#1704562 bz#1758618 bz#1760261
|
|
|
|
* Wed Oct 09 2019 Rinku Kothiya <rkothiya@redhat.com> - 6.0-16
|
|
- fixes bugs bz#1752713 bz#1756325
|
|
|
|
* Fri Sep 27 2019 Rinku Kothiya <rkothiya@redhat.com> - 6.0-15
|
|
- fixes bugs bz#1726000 bz#1731826 bz#1754407 bz#1754790 bz#1755227
|
|
|
|
* Fri Sep 20 2019 Sunil Kumar Acharya <sheggodu@redhat.com> - 6.0-14
|
|
- fixes bugs bz#1719171 bz#1728673 bz#1731896 bz#1732443 bz#1733970
|
|
bz#1745107 bz#1746027 bz#1748688 bz#1750241 bz#1572163
|
|
|
|
* Fri Aug 23 2019 Rinku Kothiya <rkothiya@redhat.com> - 6.0-13
|
|
- fixes bugs bz#1729915 bz#1732376 bz#1743611 bz#1743627 bz#1743634 bz#1744518
|
|
|
|
* Fri Aug 09 2019 Sunil Kumar Acharya <sheggodu@redhat.com> - 6.0-12
|
|
- fixes bugs bz#1730914 bz#1731448 bz#1732770 bz#1732792 bz#1733531
|
|
bz#1734305 bz#1734534 bz#1734734 bz#1735514 bz#1737705 bz#1732774
|
|
bz#1732793
|
|
|
|
* Tue Aug 06 2019 Sunil Kumar Acharya <sheggodu@redhat.com> - 6.0-11
|
|
- fixes bugs bz#1733520 bz#1734423
|
|
|
|
* Fri Aug 02 2019 Sunil Kumar Acharya <sheggodu@redhat.com> - 6.0-10
|
|
- fixes bugs bz#1713890
|
|
|
|
* Tue Jul 23 2019 Sunil Kumar Acharya <sheggodu@redhat.com> - 6.0-9
|
|
- fixes bugs bz#1708064 bz#1708180 bz#1715422 bz#1720992 bz#1722757
|
|
|
|
* Tue Jul 16 2019 Sunil Kumar Acharya <sheggodu@redhat.com> - 6.0-8
|
|
- fixes bugs bz#1698435 bz#1712591 bz#1715447 bz#1720488 bz#1722209
|
|
bz#1722512 bz#1724089 bz#1726991 bz#1727785 bz#1729108
|
|
|
|
* Fri Jun 28 2019 Sunil Kumar Acharya <sheggodu@redhat.com> - 6.0-7
|
|
- fixes bugs bz#1573077 bz#1600918 bz#1703423 bz#1704207 bz#1708064
|
|
bz#1709301 bz#1713664 bz#1716760 bz#1717784 bz#1720163 bz#1720192
|
|
bz#1720551 bz#1721351 bz#1721357 bz#1721477 bz#1722131 bz#1722331
|
|
bz#1722509 bz#1722801 bz#1720248
|
|
|
|
* Fri Jun 14 2019 Sunil Kumar Acharya <sheggodu@redhat.com> - 6.0-6
|
|
- fixes bugs bz#1668001 bz#1708043 bz#1708183 bz#1710701
|
|
bz#1719640 bz#1720079 bz#1720248 bz#1720318 bz#1720461
|
|
|
|
* Tue Jun 11 2019 Sunil Kumar Acharya <sheggodu@redhat.com> - 6.0-5
|
|
- fixes bugs bz#1573077 bz#1694595 bz#1703434 bz#1714536 bz#1714588
|
|
bz#1715407 bz#1715438 bz#1705018
|
|
|
|
* Fri Jun 07 2019 Rinku Kothiya <rkothiya@redhat.com> - 6.0-4
|
|
- fixes bugs bz#1480907 bz#1702298 bz#1703455 bz#1704181 bz#1707246
|
|
bz#1708067 bz#1708116 bz#1708121 bz#1709087 bz#1711249 bz#1711296
|
|
bz#1714078 bz#1714124 bz#1716385 bz#1716626 bz#1716821 bz#1716865 bz#1717927
|
|
|
|
* Tue May 14 2019 Rinku Kothiya <rkothiya@redhat.com> - 6.0-3
|
|
- fixes bugs bz#1583585 bz#1671862 bz#1702686 bz#1703434 bz#1703753
|
|
bz#1703897 bz#1704562 bz#1704769 bz#1704851 bz#1706683 bz#1706776 bz#1706893
|
|
|
|
* Thu Apr 25 2019 Milind Changire <mchangir@redhat.com> - 6.0-2
|
|
- fixes bugs bz#1471742 bz#1652461 bz#1671862 bz#1676495 bz#1691620
|
|
bz#1696334 bz#1696903 bz#1697820 bz#1698436 bz#1698728 bz#1699709 bz#1699835
|
|
bz#1702240
|
|
|
|
* 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
|
|
|