2 # - accelio libxio (BR: accelio libibverbs-devel librdmacm-devel
3 # - proper init scripts if non-systemd boot is too be supported
4 # (upstream scripts seem overcomplicated and hardly useful)
8 %bcond_without java # Java binding
9 %bcond_with kinetic # Kinetic storage support [needs update for internal API changes]
10 %bcond_with rocksdb # RocksDB storage support [needs update for internal API changes]
11 %bcond_with zfs # ZFS support
12 %bcond_without lttng # LTTng tracing
13 %bcond_without babeltrace # Babeltrace traces support
14 %bcond_without tcmalloc # tcmalloc allocator
17 %undefine with_tcmalloc
20 Summary: User space components of the Ceph file system
21 Summary(pl.UTF-8): Działające w przestrzeni użytkownika elementy systemu plików Ceph
25 License: LGPL v2.1 (libraries), GPL v2 (some programs)
27 Source0: http://ceph.com/download/%{name}-%{version}.tar.bz2
28 # Source0-md5: e4a625aa2c91fe5d3f0c62faa4716ca2
29 Source1: ceph.sysconfig
30 # based on files from https://github.com/ceph/ceph/tree/master/systemd
32 Source11: ceph-mds@.service
33 Source12: ceph-mon@.service
34 Source13: ceph-osd@.service
36 Source15: ceph.tmpfiles
37 Patch0: %{name}-init-fix.patch
38 Patch1: %{name}.logrotate.patch
39 Patch2: %{name}-link.patch
40 Patch3: %{name}-ac.patch
42 BuildRequires: autoconf >= 2.59
43 BuildRequires: automake
44 %{?with_babeltrace:BuildRequires: babeltrace-devel}
45 BuildRequires: boost-devel >= 1.34
46 BuildRequires: curl-devel
47 BuildRequires: expat-devel >= 1.95
48 BuildRequires: fcgi-devel
49 BuildRequires: gdbm-devel
53 BuildRequires: keyutils-devel
54 %{?with_kinetic:BuildRequires: kinetic-cpp-client}
55 BuildRequires: leveldb-devel >= 1.2
56 BuildRequires: libaio-devel
57 BuildRequires: libatomic_ops
58 BuildRequires: libblkid-devel >= 2.17
59 BuildRequires: libedit-devel >= 2.11
60 BuildRequires: libfuse-devel
61 BuildRequires: libltdl-devel
62 BuildRequires: libs3-devel
63 BuildRequires: libstdc++-devel
64 %{?with_tcmalloc:BuildRequires: libtcmalloc-devel}
65 BuildRequires: libtool >= 2:1.5
66 BuildRequires: libuuid-devel
67 %{?with_lttng:BuildRequires: lttng-ust-devel}
68 BuildRequires: nss-devel
69 BuildRequires: perl-base
70 BuildRequires: pkgconfig
71 BuildRequires: python >= 1:2.4
72 %{?with_rocksdb:BuildRequires: rocksdb-devel}
73 BuildRequires: rpmbuild(macros) >= 1.228
74 BuildRequires: snappy-devel
75 BuildRequires: udev-devel
76 BuildRequires: xfsprogs-devel
80 %{?with_zfs:BuildRequires: zfs-devel}
81 Requires(post,preun): /sbin/chkconfig
82 Requires(preun): rc-scripts
83 Requires: %{name}-libs = %{version}-%{release}
84 Requires: python-%{name} = %{version}-%{release}
86 Obsoletes: hadoop-cephfs
87 BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
89 %define skip_post_check_so libcls_.*.so.* libec_.*.so.*
92 Ceph is a distributed network file system designed to provide
93 excellent performance, reliability, and scalability.
95 %description -l pl.UTF-8
96 Ceph to rozproszony sieciowy system plików zaprojektowany z myślą o
97 dobrej wydajności, wiarygodności i skalowalności.
100 Summary: Ceph shared libraries
101 Summary(pl.UTF-8): Biblioteki współdzielone Cepha
105 Ceph shared libraries.
107 %description libs -l pl.UTF-8
108 Biblioteki współdzielone Cepha.
111 Summary: Ceph header files
112 Summary(pl.UTF-8): Pliki nagłówkowe bibliotek Cepha
114 Group: Development/Libraries
115 Requires: %{name}-libs = %{version}-%{release}
116 Requires: boost-devel >= 1.34
118 Requires: leveldb-devel
119 Requires: libatomic_ops
120 Requires: libuuid-devel
123 This package contains the headers needed to develop programs that use
126 %description devel -l pl.UTF-8
127 Ten pakiet zawiera pliki nagłówkowe potrzebne do tworzenia programów
128 wykorzystujących Cepha.
131 Summary: Ceph static libraries
132 Summary(pl.UTF-8): Biblioteki statyczne Cepha
134 Group: Development/Libraries
135 Requires: %{name}-devel = %{version}-%{release}
138 This package contains static Ceph libraries.
140 %description static -l pl.UTF-8
141 Ten pakiet zawiera biblioteki statyczne Cepha.
143 %package -n python-ceph
144 Summary: Ceph Python bindings
145 Summary(pl.UTF-8): Wiązania Pythona do bibliotek Cepha
146 Group: Development/Languages/Python
147 Requires: %{name}-libs = %{version}-%{release}
149 %description -n python-ceph
150 Ceph Python bindings.
152 %description -n python-ceph -l pl.UTF-8
153 Wiązania Pythona do bibliotek Cepha.
155 %package -n java-cephfs
156 Summary: CephFS Java bindings
157 Summary(pl.UTF-8): Wiązania Javy do biblioteki CephFS
158 Group: Libraries/Java
159 Requires: %{name}-libs = %{version}-%{release}
161 %description -n java-cephfs
162 CephFS Java bindings.
164 %description -n java-cephfs -l pl.UTF-8
165 Wiązania Javy do biblioteki CephFS.
168 Summary: Ceph FUSE-based client
169 Summary(pl.UTF-8): Klient Cepha oparty na FUSE
171 Requires: %{name} = %{version}-%{release}
174 FUSE based client for Ceph distributed network file system.
176 %description fuse -l pl.UTF-8
177 Oparty na FUSE klient rozproszonego sieciowego systemu plików Ceph.
180 Summary: rados REST gateway
181 Summary(pl.UTF-8): Bramka REST-owa rados
182 Group: Applications/System
183 #Requires: apache-mod_fcgid
186 radosgw is an S3 HTTP REST gateway for the RADOS object store. It is
187 implemented as a FastCGI module using libfcgi, and can be used in
188 conjunction with any FastCGI capable web server.
190 %description radosgw -l pl.UTF-8
191 radosgw to REST-owa bramka HTTP S3 do przechowalni obiektów RADOS.
192 Jest zaimplementowana jako moduł FastCGI wykorzystujący libfcgi i może
193 być używana w połączeniu z dowolnym serwerem WWW obsługującym FastCGI.
195 %package resource-agents
196 Summary: OCF Resource Agents for Ceph processes
197 Summary(pl.UTF-8): Agenci OCF do monitorowania procesów Cepha
198 Group: Applications/System
199 Requires: %{name} = %{version}-%{release}
200 Requires: resource-agents
202 %description resource-agents
203 OCF Resource Agents for Ceph processes.
205 %description resource-agents -l pl.UTF-8
206 Agenci OCF do monitorowania procesów Cepha.
221 # ac_cv_prog_uudecode_base64=no is a hack to compile Test.class instead of
222 # using included one which fails with Sun/Oracle JDK 1.6
224 %{?with_java:JAVAC=/usr/bin/javac} \
225 %{?with_zfs:LIBZFS_CFLAGS="-I/usr/include/libzfs -I/usr/include/libspl"} \
226 ac_cv_prog_uudecode_base64=no \
228 %{!?with_babeltrace:--without-babeltrace} \
231 %{!?with_tcmalloc:--without-tcmalloc} \
232 %{?with_kinetic:--with-kinetic} \
233 %{?with_rocksdb:--with-librocksdb} \
234 %{?with_zfs:--with-libzfs} \
235 %{!?with_lttng:--without-lttng} \
238 --with-system-leveldb \
239 --with-system-libs3 \
240 %{?with_java:--enable-cephfs-java --with-jdk-dir=%{_jvmdir}/java} \
241 --disable-silent-rules
246 rm -rf $RPM_BUILD_ROOT
247 install -d $RPM_BUILD_ROOT%{_localstatedir}/{lib/ceph/{tmp,mon,osd,mds},log/ceph/stat} \
248 $RPM_BUILD_ROOT%{_sysconfdir}/{ceph,bash_completion.d,logrotate.d,rc.d/init.d} \
249 $RPM_BUILD_ROOT{%{systemdunitdir},%{systemdtmpfilesdir}}
252 DESTDIR=$RPM_BUILD_ROOT \
255 install -p src/init-ceph $RPM_BUILD_ROOT/etc/rc.d/init.d/ceph
256 install -p src/logrotate.conf $RPM_BUILD_ROOT%{_sysconfdir}/logrotate.d/ceph
258 install %{SOURCE10} $RPM_BUILD_ROOT%{_bindir}
259 install %{SOURCE11} %{SOURCE12} %{SOURCE13} %{SOURCE14} $RPM_BUILD_ROOT%{systemdunitdir}
260 ln -sf /dev/null $RPM_BUILD_ROOT%{systemdunitdir}/ceph.service
261 install %{SOURCE15} $RPM_BUILD_ROOT%{systemdtmpfilesdir}/ceph.conf
264 %{__rm} $RPM_BUILD_ROOT%{_libdir}/ceph/erasure-code/*.{a,la}
265 %{__rm} $RPM_BUILD_ROOT%{_libdir}/rados-classes/*.{a,la}
267 %{__rm} $RPM_BUILD_ROOT%{_libdir}/libcephfs_jni.{la,a}
271 %{__rm} $RPM_BUILD_ROOT%{_docdir}/ceph/sample.{ceph.conf,fetch_config}
276 rm -rf $RPM_BUILD_ROOT
279 /sbin/chkconfig --add ceph
280 %service ceph restart
283 if [ "$1" = "0" ] ; then
285 /sbin/chkconfig --del ceph
288 %post libs -p /sbin/ldconfig
289 %postun libs -p /sbin/ldconfig
291 %post -n java-cephfs -p /sbin/ldconfig
292 %postun -n java-cephfs -p /sbin/ldconfig
295 %defattr(644,root,root,755)
296 # COPYING specifies licenses of individual parts
297 %doc AUTHORS COPYING README src/sample.ceph.conf src/sample.fetch_config
298 %attr(754,root,root) /etc/rc.d/init.d/ceph
299 %dir %{_sysconfdir}/ceph
300 %attr(755,root,root) %{_bindir}/ceph
301 %attr(755,root,root) %{_bindir}/ceph-authtool
302 %attr(755,root,root) %{_bindir}/ceph-brag
303 %attr(755,root,root) %{_bindir}/ceph-clsinfo
304 %attr(755,root,root) %{_bindir}/ceph-conf
305 %attr(755,root,root) %{_bindir}/ceph-coverage
306 %attr(755,root,root) %{_bindir}/ceph-crush-location
307 %attr(755,root,root) %{_bindir}/ceph-debugpack
308 %attr(755,root,root) %{_bindir}/ceph-dencoder
309 %attr(755,root,root) %{_bindir}/ceph-mds
310 %attr(755,root,root) %{_bindir}/ceph-mon
311 %attr(755,root,root) %{_bindir}/ceph-objectstore-tool
312 %attr(755,root,root) %{_bindir}/ceph-osd
313 %attr(755,root,root) %{_bindir}/ceph-post-file
314 %attr(755,root,root) %{_bindir}/ceph-rbdnamer
315 %attr(755,root,root) %{_bindir}/ceph-rest-api
316 %attr(755,root,root) %{_bindir}/ceph-run
317 %attr(755,root,root) %{_bindir}/ceph-syn
318 %attr(755,root,root) %{_bindir}/cephfs
319 %attr(755,root,root) %{_bindir}/cephfs-journal-tool
320 %attr(755,root,root) %{_bindir}/cephfs-table-tool
321 %attr(755,root,root) %{_bindir}/crushtool
322 %attr(755,root,root) %{_bindir}/librados-config
323 %attr(755,root,root) %{_bindir}/monmaptool
324 %attr(755,root,root) %{_bindir}/osdmaptool
325 %attr(755,root,root) %{_bindir}/rados
326 %attr(755,root,root) %{_bindir}/rbd
327 %attr(755,root,root) %{_bindir}/rbd-fuse
328 %attr(755,root,root) %{_bindir}/rbd-replay
329 %attr(755,root,root) %{_bindir}/rbd-replay-many
330 %attr(755,root,root) %{_bindir}/rbd-replay-prep
331 %attr(755,root,root) /sbin/ceph-create-keys
332 %attr(755,root,root) /sbin/ceph-disk
333 %attr(755,root,root) /sbin/ceph-disk-activate
334 %attr(755,root,root) /sbin/ceph-disk-prepare
335 %attr(755,root,root) /sbin/ceph-disk-udev
336 %attr(755,root,root) /sbin/mount.ceph
337 %attr(755,root,root) /sbin/mount.fuse.ceph
339 %attr(755,root,root) %{_libdir}/ceph/ceph-osd-prestart.sh
340 %{_libdir}/ceph/ceph_common.sh
341 %dir %{_libdir}/ceph/erasure-code
342 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_example.so*
343 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_fail_to_initialize.so*
344 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_fail_to_register.so*
345 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_hangs.so*
347 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_isa.so*
349 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_jerasure.so*
350 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_jerasure_generic.so*
352 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_jerasure_neon.so*
354 %ifarch %{ix86} %{x8664} x32
355 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_jerasure_sse3.so*
358 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_jerasure_sse4.so*
360 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_lrc.so*
361 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_missing_entry_point.so*
362 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_missing_version.so*
363 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_shec.so*
364 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_test_jerasure_generic.so*
365 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_test_jerasure_neon.so*
366 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_test_jerasure_sse3.so*
367 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_test_jerasure_sse4.so*
368 %dir %{_libdir}/rados-classes
369 %attr(755,root,root) %{_libdir}/rados-classes/libcls_hello.so*
370 %attr(755,root,root) %{_libdir}/rados-classes/libcls_kvs.so*
371 %attr(755,root,root) %{_libdir}/rados-classes/libcls_lock.so*
372 %attr(755,root,root) %{_libdir}/rados-classes/libcls_log.so*
373 %attr(755,root,root) %{_libdir}/rados-classes/libcls_rbd.so*
374 %attr(755,root,root) %{_libdir}/rados-classes/libcls_refcount.so*
375 %attr(755,root,root) %{_libdir}/rados-classes/libcls_replica_log.so*
376 %attr(755,root,root) %{_libdir}/rados-classes/libcls_rgw.so*
377 %attr(755,root,root) %{_libdir}/rados-classes/libcls_statelog.so*
378 %attr(755,root,root) %{_libdir}/rados-classes/libcls_user.so*
379 %attr(755,root,root) %{_libdir}/rados-classes/libcls_version.so*
381 %config(noreplace) /etc/logrotate.d/ceph
382 %config(noreplace) %{_sysconfdir}/bash_completion.d/rados
383 %config(noreplace) %{_sysconfdir}/bash_completion.d/ceph
384 %config(noreplace) %{_sysconfdir}/bash_completion.d/rbd
385 %{_mandir}/man8/ceph.8*
386 %{_mandir}/man8/ceph-authtool.8*
387 %{_mandir}/man8/ceph-clsinfo.8*
388 %{_mandir}/man8/ceph-conf.8*
389 %{_mandir}/man8/ceph-debugpack.8*
390 %{_mandir}/man8/ceph-dencoder.8*
391 %{_mandir}/man8/ceph-deploy.8*
392 %{_mandir}/man8/ceph-disk.8*
393 %{_mandir}/man8/ceph-mds.8*
394 %{_mandir}/man8/ceph-mon.8*
395 %{_mandir}/man8/ceph-osd.8*
396 %{_mandir}/man8/ceph-post-file.8*
397 %{_mandir}/man8/ceph-rbdnamer.8*
398 %{_mandir}/man8/ceph-rest-api.8*
399 %{_mandir}/man8/ceph-run.8*
400 %{_mandir}/man8/ceph-syn.8*
401 %{_mandir}/man8/cephfs.8*
402 %{_mandir}/man8/crushtool.8*
403 %{_mandir}/man8/librados-config.8*
404 %{_mandir}/man8/monmaptool.8*
405 %{_mandir}/man8/mount.ceph.8*
406 %{_mandir}/man8/osdmaptool.8*
407 %{_mandir}/man8/rados.8*
408 %{_mandir}/man8/radosgw.8*
409 %{_mandir}/man8/radosgw-admin.8*
410 %{_mandir}/man8/rbd.8*
411 %{_mandir}/man8/rbd-fuse.8*
412 %{_mandir}/man8/rbd-replay.8*
413 %{_mandir}/man8/rbd-replay-many.8*
414 %{_mandir}/man8/rbd-replay-prep.8*
416 %dir %{_localstatedir}/lib/ceph
417 %dir %{_localstatedir}/lib/ceph/mds
418 %dir %{_localstatedir}/lib/ceph/mon
419 %dir %{_localstatedir}/lib/ceph/osd
420 %dir %{_localstatedir}/lib/ceph/tmp
421 %dir %{_localstatedir}/log/ceph
424 %defattr(644,root,root,755)
425 %attr(755,root,root) %{_libdir}/libcephfs.so.*.*.*
426 %attr(755,root,root) %ghost %{_libdir}/libcephfs.so.1
427 %attr(755,root,root) %{_libdir}/librados.so.*.*.*
428 %attr(755,root,root) %ghost %{_libdir}/librados.so.2
429 %attr(755,root,root) %{_libdir}/libradosstriper.so.*.*.*
430 %attr(755,root,root) %ghost %{_libdir}/libradosstriper.so.1
431 %attr(755,root,root) %{_libdir}/librbd.so.*.*.*
432 %attr(755,root,root) %ghost %{_libdir}/librbd.so.1
435 %defattr(644,root,root,755)
436 %attr(755,root,root) %{_libdir}/libcephfs.so
437 %attr(755,root,root) %{_libdir}/librados.so
438 %attr(755,root,root) %{_libdir}/libradosstriper.so
439 %attr(755,root,root) %{_libdir}/librbd.so
440 %{_libdir}/libcephfs.la
441 %{_libdir}/librados.la
442 %{_libdir}/libradosstriper.la
444 %{_includedir}/cephfs
446 %{_includedir}/radosstriper
450 %defattr(644,root,root,755)
451 %{_libdir}/libcephfs.a
452 %{_libdir}/librados.a
453 %{_libdir}/libradosstriper.a
456 %files -n python-ceph
457 %defattr(644,root,root,755)
458 %{py_sitescriptdir}/ceph_argparse.py[co]
459 %{py_sitescriptdir}/ceph_rest_api.py[co]
460 %{py_sitescriptdir}/cephfs.py[co]
461 %{py_sitescriptdir}/rados.py[co]
462 %{py_sitescriptdir}/rbd.py[co]
465 %files -n java-cephfs
466 %defattr(644,root,root,755)
467 %attr(755,root,root) %{_libdir}/libcephfs_jni.so.*.*.*
468 %attr(755,root,root) %ghost %{_libdir}/libcephfs_jni.so.1
469 %attr(755,root,root) %{_libdir}/libcephfs_jni.so
470 %{_javadir}/libcephfs.jar
474 %defattr(644,root,root,755)
475 %attr(755,root,root) %{_bindir}/ceph-fuse
476 %{_mandir}/man8/ceph-fuse.8*
479 %defattr(644,root,root,755)
480 %attr(755,root,root) %{_bindir}/radosgw
481 %attr(755,root,root) %{_bindir}/radosgw-admin
482 %{_sysconfdir}/bash_completion.d/radosgw-admin
484 %files resource-agents
485 %defattr(644,root,root,755)
486 %dir %{_prefix}/lib/ocf/resource.d/ceph
487 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/ceph
488 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/mds
489 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/mon
490 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/osd
491 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/rbd