9180e7df84
Support the following lock updates in DCManager: - Provide a function decorator in common/utility.py for a synchronized lock that supports both external locks and internal fair locks. This decorator is setup, by default, for external locks. - Refactor update_subcloud_endpoint_status() so that a common private method is provided that is suitable for locking. - Update subcloud_manager.py to provide a function decorator to produce an internal fair lock based on a unique subcloud name. This decorator is specifically designed to be used with _update_subcloud_endpoint_status(). This will ensure that the multi-threaded DCManager process will only update subcloud endpoint information in a synchronized manner. - Provide an API lock to the SubcloudsController for the post, patch, and delete operations Update distributedcloud requirements and spec file to require oslo.concurrency >= 3.29.1. This is the latest version supported by the Openstack Stein and is a version containing fair lock support. Update unit tests: - Added unit test for update_subcloud_endpoint_status. This verifies high level functionality and the calling of fair locks based on the unique subcloud name. - Fixed intermittent failure seen when executing the add_subcloud unit test by mocking thread.Threading. - Leverage the use of oslo_concurrency's behavior to use the OSLO_LOCK_PATH environment variable if the lock_path config option is not set. Currently this is not set as we specify a hard coded external lock path at runtime. This allows us to set the lock path for tox tests via the test environment. Change-Id: Id1902e8553408cbdd60b648efc39d59e8edcdb55 Depends-On: https://review.opendev.org/#/c/707188/ Closes-Bug: #1855359 Signed-off-by: Robert Church <robert.church@windriver.com>
244 lines
9.1 KiB
RPMSpec
244 lines
9.1 KiB
RPMSpec
%global pypi_name distributedcloud
|
|
|
|
%global with_doc %{!?_without_doc:1}%{?_without_doc:0}
|
|
%{!?upstream_version: %global upstream_version %{version}%{?milestone}}
|
|
|
|
%if 0%{?fedora}
|
|
%global with_python3 1
|
|
%{!?python3_shortver: %global python3_shortver %(%{__python3} -c 'import sys; print(str(sys.version_info.major) + "." + str(sys.version_info.minor))')}
|
|
%endif
|
|
|
|
Name: %{pypi_name}
|
|
Version: 1.0.0
|
|
Release: 1%{?_tis_dist}.%{tis_patch_ver}
|
|
Summary: Distributed Cloud Services
|
|
|
|
License: ASL 2.0
|
|
URL: unknown
|
|
Source0: %{pypi_name}-%{version}.tar.gz
|
|
Source1: dcmanager-api.service
|
|
Source2: dcmanager-manager.service
|
|
Source3: dcorch-api.service
|
|
Source4: dcorch-engine.service
|
|
Source5: dcorch-sysinv-api-proxy.service
|
|
Source6: dcorch-snmp.service
|
|
Source7: dcorch-identity-api-proxy.service
|
|
Source8: dcdbsync-api.service
|
|
Source9: dcdbsync-openstack-api.service
|
|
Source10: dcmanager.conf
|
|
Source11: dcorch.conf
|
|
Source12: dcdbsync.conf
|
|
|
|
BuildArch: noarch
|
|
|
|
BuildRequires: python-crypto
|
|
BuildRequires: python-cryptography
|
|
BuildRequires: python2-devel
|
|
BuildRequires: python-eventlet
|
|
BuildRequires: python-setuptools
|
|
BuildRequires: python2-pip
|
|
BuildRequires: python2-wheel
|
|
BuildRequires: python-jsonschema >= 2.0.0
|
|
BuildRequires: python-keyring
|
|
BuildRequires: python-keystonemiddleware
|
|
BuildRequires: python-keystoneauth1 >= 3.1.0
|
|
BuildRequires: python-netaddr
|
|
BuildRequires: python-oslo-concurrency >= 3.29.1
|
|
BuildRequires: python-oslo-config
|
|
BuildRequires: python-oslo-context
|
|
BuildRequires: python-oslo-db
|
|
BuildRequires: python-oslo-i18n
|
|
BuildRequires: python-oslo-log
|
|
BuildRequires: python-oslo-messaging
|
|
BuildRequires: python-oslo-middleware
|
|
BuildRequires: python-oslo-policy
|
|
BuildRequires: python-oslo-rootwrap
|
|
BuildRequires: python-oslo-serialization
|
|
BuildRequires: python-oslo-service
|
|
BuildRequires: python-oslo-utils
|
|
BuildRequires: python-oslo-versionedobjects
|
|
BuildRequires: python-pbr >= 1.8
|
|
BuildRequires: python-pecan >= 1.0.0
|
|
BuildRequires: python-routes >= 1.12.3
|
|
BuildRequires: python-sphinx
|
|
BuildRequires: python-sphinxcontrib-httpdomain
|
|
BuildRequires: pyOpenSSL
|
|
BuildRequires: systemd
|
|
# Required to compile translation files
|
|
BuildRequires: python-babel
|
|
|
|
%description
|
|
Distributed Cloud provides configuration and management of distributed clouds
|
|
|
|
# DC Manager
|
|
%package dcmanager
|
|
Summary: DC Manager
|
|
|
|
%description dcmanager
|
|
Distributed Cloud Manager
|
|
|
|
%package dcorch
|
|
Summary: DC Orchestrator
|
|
# TODO(John): should we add Requires lines?
|
|
Requires: openstack-ras
|
|
|
|
%description dcorch
|
|
Distributed Cloud Orchestrator
|
|
|
|
%package dcdbsync
|
|
Summary: DC DCorch DBsync Agent
|
|
|
|
%description dcdbsync
|
|
Distributed Cloud DCorch DBsync Agent
|
|
|
|
%prep
|
|
%autosetup -n %{pypi_name}-%{version}
|
|
|
|
# Remove the requirements file so that pbr hooks don't add it
|
|
# to distutils requires_dist config
|
|
rm -rf {test-,}requirements.txt tools/{pip,test}-requires
|
|
|
|
%build
|
|
export PBR_VERSION=%{version}
|
|
%{__python2} setup.py build
|
|
%py2_build_wheel
|
|
# Generate sample config and add the current directory to PYTHONPATH so
|
|
# oslo-config-generator doesn't skip heat's entry points.
|
|
PYTHONPATH=. oslo-config-generator --config-file=./dcmanager/config-generator.conf
|
|
PYTHONPATH=. oslo-config-generator --config-file=./dcorch/config-generator.conf
|
|
PYTHONPATH=. oslo-config-generator --config-file=./dcdbsync/config-generator.conf
|
|
|
|
|
|
%install
|
|
export PBR_VERSION=%{version}
|
|
%{__python2} setup.py install -O1 --skip-build --root %{buildroot} \
|
|
--single-version-externally-managed
|
|
install -d $RPM_BUILD_ROOT/wheels
|
|
install -m 644 dist/*.whl $RPM_BUILD_ROOT/wheels/
|
|
install -d -m 755 %{buildroot}%{_tmpfilesdir}
|
|
install -d -m 755 %{buildroot}/var/log/dcmanager
|
|
install -d -m 755 %{buildroot}/var/cache/dcmanager
|
|
install -d -m 755 %{buildroot}%{_sysconfdir}/dcmanager/
|
|
# install systemd unit files
|
|
install -p -D -m 644 %{SOURCE1} %{buildroot}%{_unitdir}/dcmanager-api.service
|
|
install -p -D -m 644 %{SOURCE2} %{buildroot}%{_unitdir}/dcmanager-manager.service
|
|
install -p -D -m 644 %{SOURCE10} %{buildroot}%{_tmpfilesdir}
|
|
# install default config files
|
|
cd %{_builddir}/%{pypi_name}-%{version} && oslo-config-generator --config-file ./dcmanager/config-generator.conf --output-file %{_builddir}/%{pypi_name}-%{version}%{_sysconfdir}/dcmanager/dcmanager.conf.sample
|
|
install -p -D -m 640 %{_builddir}/%{pypi_name}-%{version}%{_sysconfdir}/dcmanager/dcmanager.conf.sample %{buildroot}%{_sysconfdir}/dcmanager/dcmanager.conf
|
|
|
|
|
|
install -d -m 755 %{buildroot}/var/log/dcorch
|
|
install -d -m 755 %{buildroot}/var/cache/dcorch
|
|
install -d -m 755 %{buildroot}%{_sysconfdir}/dcorch/
|
|
# install systemd unit files
|
|
install -p -D -m 644 %{SOURCE3} %{buildroot}%{_unitdir}/dcorch-api.service
|
|
install -p -D -m 644 %{SOURCE4} %{buildroot}%{_unitdir}/dcorch-engine.service
|
|
install -p -D -m 644 %{SOURCE5} %{buildroot}%{_unitdir}/dcorch-sysinv-api-proxy.service
|
|
install -p -D -m 644 %{SOURCE6} %{buildroot}%{_unitdir}/dcorch-snmp.service
|
|
install -p -D -m 644 %{SOURCE7} %{buildroot}%{_unitdir}/dcorch-identity-api-proxy.service
|
|
install -p -D -m 644 %{SOURCE11} %{buildroot}%{_tmpfilesdir}
|
|
|
|
# install ocf scripts
|
|
install -d -m 755 ${RPM_BUILD_ROOT}/usr/lib/ocf/resource.d/openstack
|
|
install -p -D -m 755 ocf/* ${RPM_BUILD_ROOT}/usr/lib/ocf/resource.d/openstack/
|
|
|
|
# install default config files
|
|
cd %{_builddir}/%{pypi_name}-%{version} && oslo-config-generator --config-file ./dcorch/config-generator.conf --output-file %{_builddir}/%{pypi_name}-%{version}%{_sysconfdir}/dcorch/dcorch.conf.sample
|
|
install -p -D -m 640 %{_builddir}/%{pypi_name}-%{version}%{_sysconfdir}/dcorch/dcorch.conf.sample %{buildroot}%{_sysconfdir}/dcorch/dcorch.conf
|
|
|
|
# dc dbsync agent
|
|
install -d -m 755 %{buildroot}/var/log/dcdbsync
|
|
install -d -m 755 %{buildroot}/var/cache/dcdbsync
|
|
install -d -m 755 %{buildroot}%{_sysconfdir}/dcdbsync/
|
|
# install systemd unit files
|
|
install -p -D -m 644 %{SOURCE8} %{buildroot}%{_unitdir}/dcdbsync-api.service
|
|
# install systemd unit files for optional second instance
|
|
install -p -D -m 644 %{SOURCE9} %{buildroot}%{_unitdir}/dcdbsync-openstack-api.service
|
|
install -p -D -m 644 %{SOURCE12} %{buildroot}%{_tmpfilesdir}
|
|
# install default config files
|
|
cd %{_builddir}/%{pypi_name}-%{version} && oslo-config-generator --config-file ./dcdbsync/config-generator.conf --output-file %{_builddir}/%{pypi_name}-%{version}%{_sysconfdir}/dcdbsync/dcdbsync.conf.sample
|
|
install -p -D -m 640 %{_builddir}/%{pypi_name}-%{version}%{_sysconfdir}/dcdbsync/dcdbsync.conf.sample %{buildroot}%{_sysconfdir}/dcdbsync/dcdbsync.conf
|
|
|
|
# install ansible overrides dir
|
|
install -d -m 600 ${RPM_BUILD_ROOT}/opt/dc/ansible
|
|
|
|
%files dcmanager
|
|
%license LICENSE
|
|
%{python2_sitelib}/dcmanager*
|
|
%{python2_sitelib}/distributedcloud-*.egg-info
|
|
%exclude %{python2_sitelib}/dcmanager/tests
|
|
%{_bindir}/dcmanager-api
|
|
%{_unitdir}/dcmanager-api.service
|
|
%{_bindir}/dcmanager-manager
|
|
%{_unitdir}/dcmanager-manager.service
|
|
%{_bindir}/dcmanager-manage
|
|
%{_tmpfilesdir}/dcmanager.conf
|
|
%dir %attr(0755,root,root) %{_localstatedir}/log/dcmanager
|
|
%dir %attr(0755,root,root) %{_localstatedir}/cache/dcmanager
|
|
%dir %attr(0755,root,root) %{_sysconfdir}/dcmanager
|
|
%config(noreplace) %attr(-, root, root) %{_sysconfdir}/dcmanager/dcmanager.conf
|
|
%dir %attr(0755,root,root) /usr/lib/ocf/resource.d/openstack
|
|
%dir %attr(0600,root,root) /opt/dc/ansible
|
|
%defattr(-,root,root,-)
|
|
/usr/lib/ocf/resource.d/openstack/dcmanager-*
|
|
|
|
|
|
%files dcorch
|
|
%license LICENSE
|
|
%{python2_sitelib}/dcorch*
|
|
%{python2_sitelib}/distributedcloud-*.egg-info
|
|
%exclude %{python2_sitelib}/dcorch/tests
|
|
%{_bindir}/dcorch-api
|
|
%{_unitdir}/dcorch-api.service
|
|
%{_bindir}/dcorch-engine
|
|
%{_unitdir}/dcorch-engine.service
|
|
%{_bindir}/dcorch-api-proxy
|
|
%{_unitdir}/dcorch-sysinv-api-proxy.service
|
|
%{_unitdir}/dcorch-identity-api-proxy.service
|
|
%{_bindir}/dcorch-manage
|
|
%{_bindir}/dcorch-snmp
|
|
%{_unitdir}/dcorch-snmp.service
|
|
%{_tmpfilesdir}/dcorch.conf
|
|
%dir %attr(0755,root,root) %{_localstatedir}/log/dcorch
|
|
%dir %attr(0755,root,root) %{_localstatedir}/cache/dcorch
|
|
%dir %attr(0755,root,root) %{_sysconfdir}/dcorch
|
|
%config(noreplace) %attr(-, dcorch, dcorch) %{_sysconfdir}/dcorch/dcorch.conf
|
|
%dir %attr(0755,root,root) /usr/lib/ocf/resource.d/openstack
|
|
%defattr(-,root,root,-)
|
|
/usr/lib/ocf/resource.d/openstack/dcorch-*
|
|
|
|
|
|
%files dcdbsync
|
|
%license LICENSE
|
|
%{python2_sitelib}/dcdbsync*
|
|
%{python2_sitelib}/distributedcloud-*.egg-info
|
|
%exclude %{python2_sitelib}/dcdbsync/tests
|
|
%{_bindir}/dcdbsync-api
|
|
%{_unitdir}/dcdbsync-api.service
|
|
%{_unitdir}/dcdbsync-openstack-api.service
|
|
%{_tmpfilesdir}/dcdbsync.conf
|
|
%dir %attr(0755,root,root) %{_localstatedir}/log/dcdbsync
|
|
%dir %attr(0755,root,root) %{_localstatedir}/cache/dcdbsync
|
|
%dir %attr(0755,root,root) %{_sysconfdir}/dcdbsync
|
|
%config(noreplace) %attr(-, root, root) %{_sysconfdir}/dcdbsync/dcdbsync.conf
|
|
%dir %attr(0755,root,root) /usr/lib/ocf/resource.d/openstack
|
|
%defattr(-,root,root,-)
|
|
/usr/lib/ocf/resource.d/openstack/dcdbsync-*
|
|
|
|
%pre dcorch
|
|
getent group dcorch >/dev/null || groupadd -r --gid 173 dcorch
|
|
getent passwd dcorch >/dev/null || \
|
|
useradd --uid 173 -r -g dcorch -d /var/lib/dcorch -s /sbin/nologin \
|
|
-c "dcorch Daemons" dcorch
|
|
exit 0
|
|
|
|
%package wheels
|
|
Summary: %{name} wheels
|
|
|
|
%description wheels
|
|
Contains python wheels for %{name}
|
|
|
|
%files wheels
|
|
/wheels/*
|