%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: 12%{?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 %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 # 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 # 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 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 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 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 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 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 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 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 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 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 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 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 * Tue Oct 29 2019 CentOS Sources - 6.0-12.el7.centos - remove vendor and/or packager lines * Fri Aug 09 2019 Sunil Kumar Acharya - 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 - 6.0-11 - fixes bugs bz#1733520 bz#1734423 * Fri Aug 02 2019 Sunil Kumar Acharya - 6.0-10 - fixes bugs bz#1713890 * Tue Jul 23 2019 Sunil Kumar Acharya - 6.0-9 - fixes bugs bz#1708064 bz#1708180 bz#1715422 bz#1720992 bz#1722757 * Tue Jul 16 2019 Sunil Kumar Acharya - 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 - 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 - 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 - 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 - 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 - 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 - 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 - 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