1 # TODO: accelio libxio (BR: accelio libibverbs-devel librdmacm-devel
4 %bcond_without java # Java binding
5 %bcond_with kinetic # Kinetic storage support [needs update for internal API changes]
6 %bcond_with rocksdb # RocksDB storage support [needs update for internal API changes]
7 %bcond_with zfs # ZFS support
8 %bcond_without lttng # LTTng tracing
9 %bcond_without babeltrace # Babeltrace traces support
10 %bcond_without tcmalloc # tcmalloc allocator
13 %undefine with_tcmalloc
16 Summary: User space components of the Ceph file system
17 Summary(pl.UTF-8): Działające w przestrzeni użytkownika elementy systemu plików Ceph
21 License: LGPL v2.1 (libraries), GPL v2 (some programs)
23 Source0: http://ceph.com/download/%{name}-%{version}.tar.bz2
24 # Source0-md5: e4a625aa2c91fe5d3f0c62faa4716ca2
25 Patch0: %{name}-init-fix.patch
26 Patch1: %{name}.logrotate.patch
27 Patch2: %{name}-link.patch
28 Patch3: %{name}-ac.patch
30 BuildRequires: autoconf >= 2.59
31 BuildRequires: automake
32 %{?with_babeltrace:BuildRequires: babeltrace-devel}
33 BuildRequires: boost-devel >= 1.34
34 BuildRequires: curl-devel
35 BuildRequires: expat-devel >= 1.95
36 BuildRequires: fcgi-devel
37 BuildRequires: gdbm-devel
41 BuildRequires: keyutils-devel
42 %{?with_kinetic:BuildRequires: kinetic-cpp-client}
43 BuildRequires: leveldb-devel >= 1.2
44 BuildRequires: libaio-devel
45 BuildRequires: libatomic_ops
46 BuildRequires: libblkid-devel >= 2.17
47 BuildRequires: libedit-devel >= 2.11
48 BuildRequires: libfuse-devel
49 BuildRequires: libltdl-devel
50 BuildRequires: libs3-devel
51 BuildRequires: libstdc++-devel
52 %{?with_tcmalloc:BuildRequires: libtcmalloc-devel}
53 BuildRequires: libtool >= 2:1.5
54 BuildRequires: libuuid-devel
55 %{?with_lttng:BuildRequires: lttng-ust-devel}
56 BuildRequires: nss-devel
57 BuildRequires: perl-base
58 BuildRequires: pkgconfig
59 BuildRequires: python >= 1:2.4
60 %{?with_rocksdb:BuildRequires: rocksdb-devel}
61 BuildRequires: rpmbuild(macros) >= 1.228
62 BuildRequires: snappy-devel
63 BuildRequires: udev-devel
64 BuildRequires: xfsprogs-devel
68 %{?with_zfs:BuildRequires: zfs-devel}
69 Requires(post,preun): /sbin/chkconfig
70 Requires(preun): rc-scripts
71 Requires: %{name}-libs = %{version}-%{release}
72 Requires: python-%{name} = %{version}-%{release}
74 Obsoletes: hadoop-cephfs
75 BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
77 %define skip_post_check_so libcls_.*.so.* libec_.*.so.*
80 Ceph is a distributed network file system designed to provide
81 excellent performance, reliability, and scalability.
83 %description -l pl.UTF-8
84 Ceph to rozproszony sieciowy system plików zaprojektowany z myślą o
85 dobrej wydajności, wiarygodności i skalowalności.
88 Summary: Ceph shared libraries
89 Summary(pl.UTF-8): Biblioteki współdzielone Cepha
93 Ceph shared libraries.
95 %description libs -l pl.UTF-8
96 Biblioteki współdzielone Cepha.
99 Summary: Ceph header files
100 Summary(pl.UTF-8): Pliki nagłówkowe bibliotek Cepha
102 Group: Development/Libraries
103 Requires: %{name}-libs = %{version}-%{release}
104 Requires: boost-devel >= 1.34
106 Requires: leveldb-devel
107 Requires: libatomic_ops
108 Requires: libuuid-devel
111 This package contains the headers needed to develop programs that use
114 %description devel -l pl.UTF-8
115 Ten pakiet zawiera pliki nagłówkowe potrzebne do tworzenia programów
116 wykorzystujących Cepha.
119 Summary: Ceph static libraries
120 Summary(pl.UTF-8): Biblioteki statyczne Cepha
122 Group: Development/Libraries
123 Requires: %{name}-devel = %{version}-%{release}
126 This package contains static Ceph libraries.
128 %description static -l pl.UTF-8
129 Ten pakiet zawiera biblioteki statyczne Cepha.
131 %package -n python-ceph
132 Summary: Ceph Python bindings
133 Summary(pl.UTF-8): Wiązania Pythona do bibliotek Cepha
134 Group: Development/Languages/Python
135 Requires: %{name}-libs = %{version}-%{release}
137 %description -n python-ceph
138 Ceph Python bindings.
140 %description -n python-ceph -l pl.UTF-8
141 Wiązania Pythona do bibliotek Cepha.
143 %package -n java-cephfs
144 Summary: CephFS Java bindings
145 Summary(pl.UTF-8): Wiązania Javy do biblioteki CephFS
146 Group: Libraries/Java
147 Requires: %{name}-libs = %{version}-%{release}
149 %description -n java-cephfs
150 CephFS Java bindings.
152 %description -n java-cephfs -l pl.UTF-8
153 Wiązania Javy do biblioteki CephFS.
156 Summary: Ceph FUSE-based client
157 Summary(pl.UTF-8): Klient Cepha oparty na FUSE
159 Requires: %{name} = %{version}-%{release}
162 FUSE based client for Ceph distributed network file system.
164 %description fuse -l pl.UTF-8
165 Oparty na FUSE klient rozproszonego sieciowego systemu plików Ceph.
168 Summary: rados REST gateway
169 Summary(pl.UTF-8): Bramka REST-owa rados
170 Group: Applications/System
171 #Requires: apache-mod_fcgid
174 radosgw is an S3 HTTP REST gateway for the RADOS object store. It is
175 implemented as a FastCGI module using libfcgi, and can be used in
176 conjunction with any FastCGI capable web server.
178 %description radosgw -l pl.UTF-8
179 radosgw to REST-owa bramka HTTP S3 do przechowalni obiektów RADOS.
180 Jest zaimplementowana jako moduł FastCGI wykorzystujący libfcgi i może
181 być używana w połączeniu z dowolnym serwerem WWW obsługującym FastCGI.
183 %package resource-agents
184 Summary: OCF Resource Agents for Ceph processes
185 Summary(pl.UTF-8): Agenci OCF do monitorowania procesów Cepha
186 Group: Applications/System
187 Requires: %{name} = %{version}-%{release}
188 Requires: resource-agents
190 %description resource-agents
191 OCF Resource Agents for Ceph processes.
193 %description resource-agents -l pl.UTF-8
194 Agenci OCF do monitorowania procesów Cepha.
209 # ac_cv_prog_uudecode_base64=no is a hack to compile Test.class instead of
210 # using included one which fails with Sun/Oracle JDK 1.6
212 %{?with_java:JAVAC=/usr/bin/javac} \
213 %{?with_zfs:LIBZFS_CFLAGS="-I/usr/include/libzfs -I/usr/include/libspl"} \
214 ac_cv_prog_uudecode_base64=no \
216 %{!?with_babeltrace:--without-babeltrace} \
219 %{!?with_tcmalloc:--without-tcmalloc} \
220 %{?with_kinetic:--with-kinetic} \
221 %{?with_rocksdb:--with-librocksdb} \
222 %{?with_zfs:--with-libzfs} \
223 %{!?with_lttng:--without-lttng} \
226 --with-system-leveldb \
227 --with-system-libs3 \
228 %{?with_java:--enable-cephfs-java --with-jdk-dir=%{_jvmdir}/java} \
229 --disable-silent-rules
234 rm -rf $RPM_BUILD_ROOT
235 install -d $RPM_BUILD_ROOT%{_localstatedir}/{lib/ceph/tmp,log/ceph/stat} \
236 $RPM_BUILD_ROOT%{_sysconfdir}/{ceph,bash_completion.d,logrotate.d,rc.d/init.d}
239 DESTDIR=$RPM_BUILD_ROOT \
242 install -p src/init-ceph $RPM_BUILD_ROOT/etc/rc.d/init.d/ceph
243 install -p src/logrotate.conf $RPM_BUILD_ROOT%{_sysconfdir}/logrotate.d/ceph
246 %{__rm} $RPM_BUILD_ROOT%{_libdir}/ceph/erasure-code/*.{a,la}
247 %{__rm} $RPM_BUILD_ROOT%{_libdir}/rados-classes/*.{a,la}
249 %{__rm} $RPM_BUILD_ROOT%{_libdir}/libcephfs_jni.{la,a}
253 %{__rm} $RPM_BUILD_ROOT%{_docdir}/ceph/sample.{ceph.conf,fetch_config}
258 rm -rf $RPM_BUILD_ROOT
261 /sbin/chkconfig --add ceph
262 %service ceph restart
265 if [ "$1" = "0" ] ; then
267 /sbin/chkconfig --del ceph
270 %post libs -p /sbin/ldconfig
271 %postun libs -p /sbin/ldconfig
273 %post -n java-cephfs -p /sbin/ldconfig
274 %postun -n java-cephfs -p /sbin/ldconfig
277 %defattr(644,root,root,755)
278 # COPYING specifies licenses of individual parts
279 %doc AUTHORS COPYING README src/sample.ceph.conf src/sample.fetch_config
280 %attr(754,root,root) /etc/rc.d/init.d/ceph
281 %dir %{_sysconfdir}/ceph
282 %attr(755,root,root) %{_bindir}/ceph
283 %attr(755,root,root) %{_bindir}/ceph-authtool
284 %attr(755,root,root) %{_bindir}/ceph-brag
285 %attr(755,root,root) %{_bindir}/ceph-clsinfo
286 %attr(755,root,root) %{_bindir}/ceph-conf
287 %attr(755,root,root) %{_bindir}/ceph-coverage
288 %attr(755,root,root) %{_bindir}/ceph-crush-location
289 %attr(755,root,root) %{_bindir}/ceph-debugpack
290 %attr(755,root,root) %{_bindir}/ceph-dencoder
291 %attr(755,root,root) %{_bindir}/ceph-mds
292 %attr(755,root,root) %{_bindir}/ceph-mon
293 %attr(755,root,root) %{_bindir}/ceph-objectstore-tool
294 %attr(755,root,root) %{_bindir}/ceph-osd
295 %attr(755,root,root) %{_bindir}/ceph-post-file
296 %attr(755,root,root) %{_bindir}/ceph-rbdnamer
297 %attr(755,root,root) %{_bindir}/ceph-rest-api
298 %attr(755,root,root) %{_bindir}/ceph-run
299 %attr(755,root,root) %{_bindir}/ceph-syn
300 %attr(755,root,root) %{_bindir}/cephfs
301 %attr(755,root,root) %{_bindir}/cephfs-journal-tool
302 %attr(755,root,root) %{_bindir}/cephfs-table-tool
303 %attr(755,root,root) %{_bindir}/crushtool
304 %attr(755,root,root) %{_bindir}/librados-config
305 %attr(755,root,root) %{_bindir}/monmaptool
306 %attr(755,root,root) %{_bindir}/osdmaptool
307 %attr(755,root,root) %{_bindir}/rados
308 %attr(755,root,root) %{_bindir}/rbd
309 %attr(755,root,root) %{_bindir}/rbd-fuse
310 %attr(755,root,root) %{_bindir}/rbd-replay
311 %attr(755,root,root) %{_bindir}/rbd-replay-many
312 %attr(755,root,root) %{_bindir}/rbd-replay-prep
313 %attr(755,root,root) /sbin/ceph-create-keys
314 %attr(755,root,root) /sbin/ceph-disk
315 %attr(755,root,root) /sbin/ceph-disk-activate
316 %attr(755,root,root) /sbin/ceph-disk-prepare
317 %attr(755,root,root) /sbin/ceph-disk-udev
318 %attr(755,root,root) /sbin/mount.ceph
319 %attr(755,root,root) /sbin/mount.fuse.ceph
321 %attr(755,root,root) %{_libdir}/ceph/ceph-osd-prestart.sh
322 %{_libdir}/ceph/ceph_common.sh
323 %dir %{_libdir}/ceph/erasure-code
324 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_example.so*
325 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_fail_to_initialize.so*
326 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_fail_to_register.so*
327 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_hangs.so*
329 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_isa.so*
331 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_jerasure.so*
332 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_jerasure_generic.so*
334 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_jerasure_neon.so*
336 %ifarch %{ix86} %{x8664} x32
337 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_jerasure_sse3.so*
340 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_jerasure_sse4.so*
342 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_lrc.so*
343 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_missing_entry_point.so*
344 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_missing_version.so*
345 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_shec.so*
346 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_test_jerasure_generic.so*
347 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_test_jerasure_neon.so*
348 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_test_jerasure_sse3.so*
349 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_test_jerasure_sse4.so*
350 %dir %{_libdir}/rados-classes
351 %attr(755,root,root) %{_libdir}/rados-classes/libcls_hello.so*
352 %attr(755,root,root) %{_libdir}/rados-classes/libcls_kvs.so*
353 %attr(755,root,root) %{_libdir}/rados-classes/libcls_lock.so*
354 %attr(755,root,root) %{_libdir}/rados-classes/libcls_log.so*
355 %attr(755,root,root) %{_libdir}/rados-classes/libcls_rbd.so*
356 %attr(755,root,root) %{_libdir}/rados-classes/libcls_refcount.so*
357 %attr(755,root,root) %{_libdir}/rados-classes/libcls_replica_log.so*
358 %attr(755,root,root) %{_libdir}/rados-classes/libcls_rgw.so*
359 %attr(755,root,root) %{_libdir}/rados-classes/libcls_statelog.so*
360 %attr(755,root,root) %{_libdir}/rados-classes/libcls_user.so*
361 %attr(755,root,root) %{_libdir}/rados-classes/libcls_version.so*
363 %config(noreplace) /etc/logrotate.d/ceph
364 %config(noreplace) %{_sysconfdir}/bash_completion.d/rados
365 %config(noreplace) %{_sysconfdir}/bash_completion.d/ceph
366 %config(noreplace) %{_sysconfdir}/bash_completion.d/rbd
367 %{_mandir}/man8/ceph.8*
368 %{_mandir}/man8/ceph-authtool.8*
369 %{_mandir}/man8/ceph-clsinfo.8*
370 %{_mandir}/man8/ceph-conf.8*
371 %{_mandir}/man8/ceph-debugpack.8*
372 %{_mandir}/man8/ceph-dencoder.8*
373 %{_mandir}/man8/ceph-deploy.8*
374 %{_mandir}/man8/ceph-disk.8*
375 %{_mandir}/man8/ceph-mds.8*
376 %{_mandir}/man8/ceph-mon.8*
377 %{_mandir}/man8/ceph-osd.8*
378 %{_mandir}/man8/ceph-post-file.8*
379 %{_mandir}/man8/ceph-rbdnamer.8*
380 %{_mandir}/man8/ceph-rest-api.8*
381 %{_mandir}/man8/ceph-run.8*
382 %{_mandir}/man8/ceph-syn.8*
383 %{_mandir}/man8/cephfs.8*
384 %{_mandir}/man8/crushtool.8*
385 %{_mandir}/man8/librados-config.8*
386 %{_mandir}/man8/monmaptool.8*
387 %{_mandir}/man8/mount.ceph.8*
388 %{_mandir}/man8/osdmaptool.8*
389 %{_mandir}/man8/rados.8*
390 %{_mandir}/man8/radosgw.8*
391 %{_mandir}/man8/radosgw-admin.8*
392 %{_mandir}/man8/rbd.8*
393 %{_mandir}/man8/rbd-fuse.8*
394 %{_mandir}/man8/rbd-replay.8*
395 %{_mandir}/man8/rbd-replay-many.8*
396 %{_mandir}/man8/rbd-replay-prep.8*
398 %dir %{_localstatedir}/lib/ceph
399 %dir %{_localstatedir}/lib/ceph/tmp
400 %dir %{_localstatedir}/log/ceph
403 %defattr(644,root,root,755)
404 %attr(755,root,root) %{_libdir}/libcephfs.so.*.*.*
405 %attr(755,root,root) %ghost %{_libdir}/libcephfs.so.1
406 %attr(755,root,root) %{_libdir}/librados.so.*.*.*
407 %attr(755,root,root) %ghost %{_libdir}/librados.so.2
408 %attr(755,root,root) %{_libdir}/libradosstriper.so.*.*.*
409 %attr(755,root,root) %ghost %{_libdir}/libradosstriper.so.1
410 %attr(755,root,root) %{_libdir}/librbd.so.*.*.*
411 %attr(755,root,root) %ghost %{_libdir}/librbd.so.1
414 %defattr(644,root,root,755)
415 %attr(755,root,root) %{_libdir}/libcephfs.so
416 %attr(755,root,root) %{_libdir}/librados.so
417 %attr(755,root,root) %{_libdir}/libradosstriper.so
418 %attr(755,root,root) %{_libdir}/librbd.so
419 %{_libdir}/libcephfs.la
420 %{_libdir}/librados.la
421 %{_libdir}/libradosstriper.la
423 %{_includedir}/cephfs
425 %{_includedir}/radosstriper
429 %defattr(644,root,root,755)
430 %{_libdir}/libcephfs.a
431 %{_libdir}/librados.a
432 %{_libdir}/libradosstriper.a
435 %files -n python-ceph
436 %defattr(644,root,root,755)
437 %{py_sitescriptdir}/ceph_argparse.py[co]
438 %{py_sitescriptdir}/ceph_rest_api.py[co]
439 %{py_sitescriptdir}/cephfs.py[co]
440 %{py_sitescriptdir}/rados.py[co]
441 %{py_sitescriptdir}/rbd.py[co]
444 %files -n java-cephfs
445 %defattr(644,root,root,755)
446 %attr(755,root,root) %{_libdir}/libcephfs_jni.so.*.*.*
447 %attr(755,root,root) %ghost %{_libdir}/libcephfs_jni.so.1
448 %attr(755,root,root) %{_libdir}/libcephfs_jni.so
449 %{_javadir}/libcephfs.jar
453 %defattr(644,root,root,755)
454 %attr(755,root,root) %{_bindir}/ceph-fuse
455 %{_mandir}/man8/ceph-fuse.8*
458 %defattr(644,root,root,755)
459 %attr(755,root,root) %{_bindir}/radosgw
460 %attr(755,root,root) %{_bindir}/radosgw-admin
461 %{_sysconfdir}/bash_completion.d/radosgw-admin
463 %files resource-agents
464 %defattr(644,root,root,755)
465 %dir %{_prefix}/lib/ocf/resource.d/ceph
466 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/ceph
467 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/mds
468 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/mon
469 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/osd
470 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/rbd