2 # - proper init scripts if non-systemd boot is too be supported
3 # (upstream scripts seem overcomplicated and hardly useful)
4 # - run as non-root user
6 # Note on versioning: http://docs.ceph.com/docs/master/releases/
9 %bcond_without java # Java binding
10 %bcond_with accelio # Accelio transport support
11 %bcond_with kinetic # Kinetic storage support [needs update for internal API changes]
12 %bcond_with rocksdb # RocksDB storage support [needs update for internal API changes]
13 %bcond_with zfs # ZFS support
14 %bcond_without lttng # LTTng tracing
15 %bcond_without babeltrace # Babeltrace traces support
16 %bcond_without tcmalloc # tcmalloc allocator
19 %undefine with_tcmalloc
22 Summary: User space components of the Ceph file system
23 Summary(pl.UTF-8): Działające w przestrzeni użytkownika elementy systemu plików Ceph
27 License: LGPL v2.1 (libraries), GPL v2 (some programs)
29 Source0: http://download.ceph.com/tarballs/%{name}-%{version}.tar.gz
30 # Source0-md5: 9bf0d6df74e6da3725dcc3b7adf3d849
31 Source1: ceph.sysconfig
32 # based on files from https://github.com/ceph/ceph/tree/master/systemd
34 Source11: ceph-mds@.service
35 Source12: ceph-mon@.service
36 Source13: ceph-osd@.service
38 Source15: ceph.tmpfiles
39 Patch0: %{name}-init-fix.patch
40 Patch1: %{name}.logrotate.patch
44 %{?with_accelio:BuildRequires: accelio-devel}
45 BuildRequires: autoconf >= 2.59
46 BuildRequires: automake
47 %{?with_babeltrace:BuildRequires: babeltrace-devel}
48 BuildRequires: boost-devel >= 1.34
49 BuildRequires: curl-devel
50 BuildRequires: expat-devel >= 1.95
51 BuildRequires: fcgi-devel
52 BuildRequires: gdbm-devel
56 BuildRequires: keyutils-devel
57 %{?with_kinetic:BuildRequires: kinetic-cpp-client}
58 BuildRequires: leveldb-devel >= 1.2
59 BuildRequires: libaio-devel
60 BuildRequires: libatomic_ops
61 BuildRequires: libblkid-devel >= 2.17
62 BuildRequires: libedit-devel >= 2.11
63 BuildRequires: libfuse-devel
64 %{?with_accelio:BuildRequires: libibverbs-devel}
65 BuildRequires: libltdl-devel
66 %{?with_accelio:BuildRequires: librdmacm-devel}
67 BuildRequires: libs3-devel
68 BuildRequires: libstdc++-devel
69 %{?with_tcmalloc:BuildRequires: libtcmalloc-devel}
70 BuildRequires: libtool >= 2:1.5
71 BuildRequires: libuuid-devel
72 %{?with_lttng:BuildRequires: lttng-ust-devel}
73 BuildRequires: nss-devel
74 BuildRequires: perl-base
75 BuildRequires: pkgconfig
76 BuildRequires: python >= 1:2.4
77 %{?with_rocksdb:BuildRequires: rocksdb-devel}
78 BuildRequires: rpmbuild(macros) >= 1.671
79 BuildRequires: sed >= 4.0
80 BuildRequires: snappy-devel
81 BuildRequires: udev-devel
82 BuildRequires: xfsprogs-devel
86 %{?with_zfs:BuildRequires: zfs-devel}
87 Requires(post,preun): /sbin/chkconfig
88 Requires(preun): rc-scripts
89 Requires: %{name}-libs = %{version}-%{release}
90 Requires: python-%{name} = %{version}-%{release}
91 Requires: systemd-units >= 38
93 Obsoletes: hadoop-cephfs
94 BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
96 %define skip_post_check_so libcls_.*.so.* libec_.*.so.*
99 Ceph is a distributed network file system designed to provide
100 excellent performance, reliability, and scalability.
102 %description -l pl.UTF-8
103 Ceph to rozproszony sieciowy system plików zaprojektowany z myślą o
104 dobrej wydajności, wiarygodności i skalowalności.
107 Summary: Ceph shared libraries
108 Summary(pl.UTF-8): Biblioteki współdzielone Cepha
112 Ceph shared libraries.
114 %description libs -l pl.UTF-8
115 Biblioteki współdzielone Cepha.
118 Summary: Ceph header files
119 Summary(pl.UTF-8): Pliki nagłówkowe bibliotek Cepha
121 Group: Development/Libraries
122 Requires: %{name}-libs = %{version}-%{release}
123 Requires: boost-devel >= 1.34
125 Requires: leveldb-devel
126 Requires: libatomic_ops
127 Requires: libuuid-devel
130 This package contains the headers needed to develop programs that use
133 %description devel -l pl.UTF-8
134 Ten pakiet zawiera pliki nagłówkowe potrzebne do tworzenia programów
135 wykorzystujących Cepha.
138 Summary: Ceph static libraries
139 Summary(pl.UTF-8): Biblioteki statyczne Cepha
141 Group: Development/Libraries
142 Requires: %{name}-devel = %{version}-%{release}
145 This package contains static Ceph libraries.
147 %description static -l pl.UTF-8
148 Ten pakiet zawiera biblioteki statyczne Cepha.
150 %package -n python-ceph
151 Summary: Ceph Python bindings
152 Summary(pl.UTF-8): Wiązania Pythona do bibliotek Cepha
153 Group: Development/Languages/Python
154 Requires: %{name}-libs = %{version}-%{release}
156 %description -n python-ceph
157 Ceph Python bindings.
159 %description -n python-ceph -l pl.UTF-8
160 Wiązania Pythona do bibliotek Cepha.
162 %package -n java-cephfs
163 Summary: CephFS Java bindings
164 Summary(pl.UTF-8): Wiązania Javy do biblioteki CephFS
165 Group: Libraries/Java
166 Requires: %{name}-libs = %{version}-%{release}
168 %description -n java-cephfs
169 CephFS Java bindings.
171 %description -n java-cephfs -l pl.UTF-8
172 Wiązania Javy do biblioteki CephFS.
175 Summary: Ceph FUSE-based client
176 Summary(pl.UTF-8): Klient Cepha oparty na FUSE
178 Requires: %{name} = %{version}-%{release}
181 FUSE based client for Ceph distributed network file system.
183 %description fuse -l pl.UTF-8
184 Oparty na FUSE klient rozproszonego sieciowego systemu plików Ceph.
187 Summary: rados REST gateway
188 Summary(pl.UTF-8): Bramka REST-owa rados
189 Group: Applications/System
190 #Requires: apache-mod_fcgid
193 radosgw is an S3 HTTP REST gateway for the RADOS object store. It is
194 implemented as a FastCGI module using libfcgi, and can be used in
195 conjunction with any FastCGI capable web server.
197 %description radosgw -l pl.UTF-8
198 radosgw to REST-owa bramka HTTP S3 do przechowalni obiektów RADOS.
199 Jest zaimplementowana jako moduł FastCGI wykorzystujący libfcgi i może
200 być używana w połączeniu z dowolnym serwerem WWW obsługującym FastCGI.
202 %package resource-agents
203 Summary: OCF Resource Agents for Ceph processes
204 Summary(pl.UTF-8): Agenci OCF do monitorowania procesów Cepha
205 Group: Applications/System
206 Requires: %{name} = %{version}-%{release}
207 Requires: resource-agents
209 %description resource-agents
210 OCF Resource Agents for Ceph processes.
212 %description resource-agents -l pl.UTF-8
213 Agenci OCF do monitorowania procesów Cepha.
222 %{__sed} -i -e '1s,/usr/bin/env python$,%{__python},' \
223 src/{ceph-create-keys,ceph-disk,ceph-rest-api} \
224 src/brag/client/ceph-brag
226 # adjust rule used to create ceph from ceph.in
227 %{__sed} -i -e 's,"#!/usr/bin/env python","#!%{__python}",' src/Makefile-client.am
235 # required by xfs headers (for off64_t)
236 CPPFLAGS="%{rpmcppflags} -D_FILE_OFFSET_BITS=64"
237 # ac_cv_prog_uudecode_base64=no is a hack to compile Test.class instead of
238 # using included one which fails with Sun/Oracle JDK 1.6
240 %{?with_java:JAVAC=/usr/bin/javac} \
241 %{?with_zfs:LIBZFS_CFLAGS="-I/usr/include/libzfs -I/usr/include/libspl"} \
242 ac_cv_prog_uudecode_base64=no \
244 %{!?with_babeltrace:--without-babeltrace} \
247 %{!?with_tcmalloc:--without-tcmalloc} \
248 %{?with_kinetic:--with-kinetic} \
249 %{?with_rocksdb:--with-librocksdb} \
250 %{?with_zfs:--with-libzfs} \
251 %{!?with_lttng:--without-lttng} \
254 --with-system-leveldb \
255 --with-system-libs3 \
256 %{?with_java:--enable-cephfs-java --with-jdk-dir=%{_jvmdir}/java} \
257 --disable-silent-rules \
258 %{?with_accelio:--enable-xio}
263 rm -rf $RPM_BUILD_ROOT
264 install -d $RPM_BUILD_ROOT%{_localstatedir}/{lib/ceph/{tmp,mon,osd,mds},log/ceph/stat,run/ceph} \
265 $RPM_BUILD_ROOT%{_sysconfdir}/{ceph,bash_completion.d,logrotate.d,rc.d/init.d,sysconfig} \
266 $RPM_BUILD_ROOT{%{systemdunitdir},%{systemdtmpfilesdir},/etc/systemd/system/ceph.target.wants}
269 DESTDIR=$RPM_BUILD_ROOT \
272 install -p src/init-ceph $RPM_BUILD_ROOT/etc/rc.d/init.d/ceph
273 install -p src/logrotate.conf $RPM_BUILD_ROOT%{_sysconfdir}/logrotate.d/ceph
275 install %{SOURCE1} $RPM_BUILD_ROOT/etc/sysconfig/ceph
276 install %{SOURCE10} $RPM_BUILD_ROOT%{_bindir}
277 install %{SOURCE11} %{SOURCE12} %{SOURCE13} %{SOURCE14} $RPM_BUILD_ROOT%{systemdunitdir}
278 ln -sf /dev/null $RPM_BUILD_ROOT%{systemdunitdir}/ceph.service
279 install %{SOURCE15} $RPM_BUILD_ROOT%{systemdtmpfilesdir}/ceph.conf
282 %{__rm} $RPM_BUILD_ROOT%{_libdir}/ceph/erasure-code/*.{a,la}
283 %{__rm} $RPM_BUILD_ROOT%{_libdir}/rados-classes/*.{a,la}
285 %{__rm} $RPM_BUILD_ROOT%{_libdir}/libcephfs_jni.{la,a}
289 %{__rm} $RPM_BUILD_ROOT%{_docdir}/ceph/sample.{ceph.conf,fetch_config}
294 rm -rf $RPM_BUILD_ROOT
297 /sbin/chkconfig --add ceph
298 %service ceph restart
300 # actual services are to be enabled on cluster deployment
301 %systemd_post %{name}.target
304 if [ "$1" = "0" ] ; then
306 /sbin/chkconfig --del ceph
308 %systemd_preun %{name}.target
313 %post libs -p /sbin/ldconfig
314 %postun libs -p /sbin/ldconfig
316 %post -n java-cephfs -p /sbin/ldconfig
317 %postun -n java-cephfs -p /sbin/ldconfig
320 %defattr(644,root,root,755)
321 # COPYING specifies licenses of individual parts
322 %doc AUTHORS COPYING README src/sample.ceph.conf src/sample.fetch_config
323 %attr(754,root,root) /etc/rc.d/init.d/ceph
324 %config(noreplace) /etc/sysconfig/ceph
325 %dir /etc/systemd/system/ceph.target.wants
326 %{systemdunitdir}/ceph-mds@.service
327 %{systemdunitdir}/ceph-mon@.service
328 %{systemdunitdir}/ceph-osd@.service
329 %{systemdunitdir}/ceph.service
330 %{systemdunitdir}/ceph.target
331 %{systemdtmpfilesdir}/ceph.conf
332 %dir %{_sysconfdir}/ceph
333 %attr(755,root,root) %{_bindir}/ceph
334 %attr(755,root,root) %{_bindir}/ceph-authtool
335 %attr(755,root,root) %{_bindir}/ceph-brag
336 %attr(755,root,root) %{_bindir}/ceph-clsinfo
337 %attr(755,root,root) %{_bindir}/ceph-conf
338 %attr(755,root,root) %{_bindir}/ceph-coverage
339 %attr(755,root,root) %{_bindir}/ceph-crush-location
340 %attr(755,root,root) %{_bindir}/ceph-debugpack
341 %attr(755,root,root) %{_bindir}/ceph-dencoder
342 %attr(755,root,root) %{_bindir}/ceph-mds
343 %attr(755,root,root) %{_bindir}/ceph-mon
344 %attr(755,root,root) %{_bindir}/ceph-objectstore-tool
345 %attr(755,root,root) %{_bindir}/ceph-osd
346 %attr(755,root,root) %{_bindir}/ceph-post-file
347 %attr(755,root,root) %{_bindir}/ceph-rbdnamer
348 %attr(755,root,root) %{_bindir}/ceph-rest-api
349 %attr(755,root,root) %{_bindir}/ceph-run
350 %attr(755,root,root) %{_bindir}/ceph-syn
351 %attr(755,root,root) %{_bindir}/cephctl
352 %attr(755,root,root) %{_bindir}/cephfs
353 %attr(755,root,root) %{_bindir}/cephfs-journal-tool
354 %attr(755,root,root) %{_bindir}/cephfs-table-tool
355 %attr(755,root,root) %{_bindir}/crushtool
356 %attr(755,root,root) %{_bindir}/librados-config
357 %attr(755,root,root) %{_bindir}/monmaptool
358 %attr(755,root,root) %{_bindir}/osdmaptool
359 %attr(755,root,root) %{_bindir}/rados
360 %attr(755,root,root) %{_bindir}/rbd
361 %attr(755,root,root) %{_bindir}/rbd-fuse
362 %attr(755,root,root) %{_bindir}/rbd-replay
363 %attr(755,root,root) %{_bindir}/rbd-replay-many
364 %attr(755,root,root) %{_bindir}/rbd-replay-prep
365 %attr(755,root,root) /sbin/ceph-create-keys
366 %attr(755,root,root) /sbin/ceph-disk
367 %attr(755,root,root) /sbin/ceph-disk-activate
368 %attr(755,root,root) /sbin/ceph-disk-prepare
369 %attr(755,root,root) /sbin/ceph-disk-udev
370 %attr(755,root,root) /sbin/mount.ceph
371 %attr(755,root,root) /sbin/mount.fuse.ceph
372 %if "%{_libexecdir}" != "%{_libdir}"
373 %dir %{_libexecdir}/ceph
375 %attr(755,root,root) %{_libexecdir}/ceph/ceph-osd-prestart.sh
377 %{_libdir}/ceph/ceph_common.sh
378 %dir %{_libdir}/ceph/erasure-code
379 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_example.so*
380 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_fail_to_initialize.so*
381 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_fail_to_register.so*
382 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_hangs.so*
384 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_isa.so*
386 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_jerasure.so*
387 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_jerasure_generic.so*
389 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_jerasure_neon.so*
391 %ifarch %{ix86} %{x8664} x32
392 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_jerasure_sse3.so*
395 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_jerasure_sse4.so*
397 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_lrc.so*
398 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_missing_entry_point.so*
399 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_missing_version.so*
400 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_shec.so*
401 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_test_jerasure_generic.so*
402 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_test_jerasure_neon.so*
403 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_test_jerasure_sse3.so*
404 %attr(755,root,root) %{_libdir}/ceph/erasure-code/libec_test_jerasure_sse4.so*
405 %dir %{_libdir}/rados-classes
406 %attr(755,root,root) %{_libdir}/rados-classes/libcls_hello.so*
407 %attr(755,root,root) %{_libdir}/rados-classes/libcls_kvs.so*
408 %attr(755,root,root) %{_libdir}/rados-classes/libcls_lock.so*
409 %attr(755,root,root) %{_libdir}/rados-classes/libcls_log.so*
410 %attr(755,root,root) %{_libdir}/rados-classes/libcls_rbd.so*
411 %attr(755,root,root) %{_libdir}/rados-classes/libcls_refcount.so*
412 %attr(755,root,root) %{_libdir}/rados-classes/libcls_replica_log.so*
413 %attr(755,root,root) %{_libdir}/rados-classes/libcls_rgw.so*
414 %attr(755,root,root) %{_libdir}/rados-classes/libcls_statelog.so*
415 %attr(755,root,root) %{_libdir}/rados-classes/libcls_user.so*
416 %attr(755,root,root) %{_libdir}/rados-classes/libcls_version.so*
418 %config(noreplace) /etc/logrotate.d/ceph
419 %config(noreplace) %{_sysconfdir}/bash_completion.d/rados
420 %config(noreplace) %{_sysconfdir}/bash_completion.d/ceph
421 %config(noreplace) %{_sysconfdir}/bash_completion.d/rbd
422 %{_mandir}/man8/ceph.8*
423 %{_mandir}/man8/ceph-authtool.8*
424 %{_mandir}/man8/ceph-clsinfo.8*
425 %{_mandir}/man8/ceph-conf.8*
426 %{_mandir}/man8/ceph-create-keys.8*
427 %{_mandir}/man8/ceph-debugpack.8*
428 %{_mandir}/man8/ceph-dencoder.8*
429 %{_mandir}/man8/ceph-deploy.8*
430 %{_mandir}/man8/ceph-disk.8*
431 %{_mandir}/man8/ceph-mds.8*
432 %{_mandir}/man8/ceph-mon.8*
433 %{_mandir}/man8/ceph-osd.8*
434 %{_mandir}/man8/ceph-post-file.8*
435 %{_mandir}/man8/ceph-rbdnamer.8*
436 %{_mandir}/man8/ceph-rest-api.8*
437 %{_mandir}/man8/ceph-run.8*
438 %{_mandir}/man8/ceph-syn.8*
439 %{_mandir}/man8/cephfs.8*
440 %{_mandir}/man8/crushtool.8*
441 %{_mandir}/man8/librados-config.8*
442 %{_mandir}/man8/monmaptool.8*
443 %{_mandir}/man8/mount.ceph.8*
444 %{_mandir}/man8/osdmaptool.8*
445 %{_mandir}/man8/rados.8*
446 %{_mandir}/man8/radosgw.8*
447 %{_mandir}/man8/radosgw-admin.8*
448 %{_mandir}/man8/rbd.8*
449 %{_mandir}/man8/rbd-fuse.8*
450 %{_mandir}/man8/rbd-replay.8*
451 %{_mandir}/man8/rbd-replay-many.8*
452 %{_mandir}/man8/rbd-replay-prep.8*
454 %dir %{_localstatedir}/lib/ceph
455 %dir %{_localstatedir}/lib/ceph/mds
456 %dir %{_localstatedir}/lib/ceph/mon
457 %dir %{_localstatedir}/lib/ceph/osd
458 %dir %{_localstatedir}/lib/ceph/tmp
459 %dir %{_localstatedir}/log/ceph
460 %dir %{_localstatedir}/run/ceph
463 %defattr(644,root,root,755)
464 %attr(755,root,root) %{_libdir}/libcephfs.so.*.*.*
465 %attr(755,root,root) %ghost %{_libdir}/libcephfs.so.1
466 %attr(755,root,root) %{_libdir}/libos_tp.so.*.*.*
467 %attr(755,root,root) %ghost %{_libdir}/libos_tp.so.1
468 %attr(755,root,root) %{_libdir}/libosd_tp.so.*.*.*
469 %attr(755,root,root) %ghost %{_libdir}/libosd_tp.so.1
470 %attr(755,root,root) %{_libdir}/librados.so.*.*.*
471 %attr(755,root,root) %ghost %{_libdir}/librados.so.2
472 %attr(755,root,root) %{_libdir}/librados_tp.so.*.*.*
473 %attr(755,root,root) %ghost %{_libdir}/librados_tp.so.2
474 %attr(755,root,root) %{_libdir}/libradosstriper.so.*.*.*
475 %attr(755,root,root) %ghost %{_libdir}/libradosstriper.so.1
476 %attr(755,root,root) %{_libdir}/librbd.so.*.*.*
477 %attr(755,root,root) %ghost %{_libdir}/librbd.so.1
478 %attr(755,root,root) %{_libdir}/librbd_tp.so.*.*.*
479 %attr(755,root,root) %ghost %{_libdir}/librbd_tp.so.1
482 %defattr(644,root,root,755)
483 %attr(755,root,root) %{_libdir}/libcephfs.so
484 %attr(755,root,root) %{_libdir}/libos_tp.so
485 %attr(755,root,root) %{_libdir}/libosd_tp.so
486 %attr(755,root,root) %{_libdir}/librados.so
487 %attr(755,root,root) %{_libdir}/librados_tp.so
488 %attr(755,root,root) %{_libdir}/libradosstriper.so
489 %attr(755,root,root) %{_libdir}/librbd.so
490 %attr(755,root,root) %{_libdir}/librbd_tp.so
491 %{_libdir}/libcephfs.la
492 %{_libdir}/libos_tp.la
493 %{_libdir}/libosd_tp.la
494 %{_libdir}/librados.la
495 %{_libdir}/librados_tp.la
496 %{_libdir}/libradosstriper.la
498 %{_libdir}/librbd_tp.la
499 %{_includedir}/cephfs
501 %{_includedir}/radosstriper
505 %defattr(644,root,root,755)
506 %{_libdir}/libcephfs.a
507 %{_libdir}/libos_tp.a
508 %{_libdir}/libosd_tp.a
509 %{_libdir}/librados.a
510 %{_libdir}/librados_tp.a
511 %{_libdir}/libradosstriper.a
513 %{_libdir}/librbd_tp.a
515 %files -n python-ceph
516 %defattr(644,root,root,755)
517 %{py_sitescriptdir}/ceph_argparse.py[co]
518 %{py_sitescriptdir}/ceph_rest_api.py[co]
519 %{py_sitescriptdir}/cephfs.py[co]
520 %{py_sitescriptdir}/rados.py[co]
521 %{py_sitescriptdir}/rbd.py[co]
524 %files -n java-cephfs
525 %defattr(644,root,root,755)
526 %attr(755,root,root) %{_libdir}/libcephfs_jni.so.*.*.*
527 %attr(755,root,root) %ghost %{_libdir}/libcephfs_jni.so.1
528 %attr(755,root,root) %{_libdir}/libcephfs_jni.so
529 %{_javadir}/libcephfs.jar
533 %defattr(644,root,root,755)
534 %attr(755,root,root) %{_bindir}/ceph-fuse
535 %{_mandir}/man8/ceph-fuse.8*
538 %defattr(644,root,root,755)
539 %attr(755,root,root) %{_bindir}/radosgw
540 %attr(755,root,root) %{_bindir}/radosgw-admin
541 %{_sysconfdir}/bash_completion.d/radosgw-admin
543 %files resource-agents
544 %defattr(644,root,root,755)
545 %dir %{_prefix}/lib/ocf/resource.d/ceph
546 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/ceph
547 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/mds
548 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/mon
549 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/osd
550 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/rbd