3 %bcond_with hadoop # Hadoop client (requires JNI)
4 %bcond_without java # Java binding
5 %bcond_with zfs # ZFS support [needs zfs.pc, not provided yet(?)]
7 Summary: User space components of the Ceph file system
8 Summary(pl.UTF-8): Działające w przestrzeni użytkownika elementy systemu plików Ceph
12 License: LGPL v2.1 (libraries), GPL v2 (some programs)
14 Source0: http://ceph.newdream.net/download/%{name}-%{version}.tar.bz2
15 # Source0-md5: 27a91c715f00e88940f0b2f0bdcd1633
16 Patch0: %{name}-init-fix.patch
17 Patch1: %{name}.logrotate.patch
18 Patch2: %{name}-link.patch
19 URL: http://ceph.newdream.net/
20 BuildRequires: autoconf >= 2.59
21 BuildRequires: automake
22 BuildRequires: boost-devel >= 1.34
23 BuildRequires: cryptopp-devel
24 BuildRequires: curl-devel
25 BuildRequires: expat-devel >= 1.95
26 BuildRequires: fcgi-devel
27 BuildRequires: gdbm-devel
28 %if %{with java} || %{with hadoop}
31 BuildRequires: keyutils-devel
32 BuildRequires: leveldb-devel
33 BuildRequires: libaio-devel
34 BuildRequires: libatomic_ops
35 BuildRequires: libedit-devel >= 2.11
36 BuildRequires: libfuse-devel
37 BuildRequires: libltdl-devel
38 BuildRequires: libs3-devel
39 BuildRequires: libstdc++-devel
40 BuildRequires: libtcmalloc-devel
41 BuildRequires: libtool >= 2:1.5
42 BuildRequires: libuuid-devel
43 BuildRequires: perl-base
44 BuildRequires: pkgconfig
45 BuildRequires: python >= 1:2.4
46 BuildRequires: rpmbuild(macros) >= 1.228
47 BuildRequires: snappy-devel
48 %{?with_zfs:BuildRequires: zfs-devel}
49 Requires(post,preun): /sbin/chkconfig
50 Requires(preun): rc-scripts
51 Requires: %{name}-libs = %{version}-%{release}
53 BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
55 %define skip_post_check_so libcls_.*.so.*
58 Ceph is a distributed network file system designed to provide
59 excellent performance, reliability, and scalability.
61 %description -l pl.UTF-8
62 Ceph to rozproszony sieciowy system plików zaprojektowany z myślą o
63 dobrej wydajności, wiarygodności i skalowalności.
66 Summary: Ceph shared libraries
67 Summary(pl.UTF-8): Biblioteki współdzielone Cepha
71 Ceph shared libraries.
73 %description libs -l pl.UTF-8
74 Biblioteki współdzielone Cepha.
77 Summary: Ceph header files
78 Summary(pl.UTF-8): Pliki nagłówkowe bibliotek Cepha
80 Group: Development/Libraries
81 Requires: %{name}-libs = %{version}-%{release}
82 Requires: boost-devel >= 1.34
83 Requires: cryptopp-devel
84 Requires: leveldb-devel
85 Requires: libatomic_ops
86 Requires: libuuid-devel
89 This package contains the headers needed to develop programs that use
92 %description devel -l pl.UTF-8
93 Ten pakiet zawiera pliki nagłówkowe potrzebne do tworzenia programów
94 wykorzystujących Cepha.
97 Summary: Ceph static libraries
98 Summary(pl.UTF-8): Biblioteki statyczne Cepha
100 Group: Development/Libraries
101 Requires: %{name}-devel = %{version}-%{release}
104 This package contains static Ceph libraries.
106 %description static -l pl.UTF-8
107 Ten pakiet zawiera biblioteki statyczne Cepha.
109 %package -n python-ceph
110 Summary: Ceph Python bindings
111 Summary(pl.UTF-8): Wiązania Pythona do bibliotek Cepha
112 Group: Development/Languages/Python
113 Requires: %{name}-libs = %{version}-%{release}
115 %description -n python-ceph
116 Ceph Python bindings.
118 %description -n python-ceph -l pl.UTF-8
119 Wiązania Pythona do bibliotek Cepha.
121 %package -n java-cephfs
122 Summary: CephFS Java bindings
123 Summary(pl.UTF-8): Wiązania Javy do biblioteki CephFS
124 Group: Libraries/Java
125 Requires: %{name}-libs = %{version}-%{release}
127 %description -n java-cephfs
128 CephFS Java bindings.
130 %description -n java-cephfs -l pl.UTF-8
131 Wiązania Javy do biblioteki CephFS.
134 Summary: Ceph FUSE-based client
135 Summary(pl.UTF-8): Klient Cepha oparty na FUSE
137 Requires: %{name} = %{version}-%{release}
140 FUSE based client for Ceph distributed network file system.
142 %description fuse -l pl.UTF-8
143 Oparty na FUSE klient rozproszonego sieciowego systemu plików Ceph.
146 Summary: rados REST gateway
147 Summary(pl.UTF-8): Bramka REST-owa rados
148 Group: Applications/System
149 #Requires: apache-mod_fcgid
152 radosgw is an S3 HTTP REST gateway for the RADOS object store. It is
153 implemented as a FastCGI module using libfcgi, and can be used in
154 conjunction with any FastCGI capable web server.
156 %description radosgw -l pl.UTF-8
157 radosgw to REST-owa bramka HTTP S3 do przechowalni obiektów RADOS.
158 Jest zaimplementowana jako moduł FastCGI wykorzystujący libfcgi i może
159 być używana w połączeniu z dowolnym serwerem WWW obsługującym FastCGI.
161 %package resource-agents
162 Summary: OCF Resource Agents for Ceph processes
163 Summary(pl.UTF-8): Agenci OCF do monitorowania procesów Cepha
164 Group: Applications/System
165 Requires: %{name} = %{version}-%{release}
166 Requires: resource-agents
168 %description resource-agents
169 OCF Resource Agents for Ceph processes.
171 %description resource-agents -l pl.UTF-8
172 Agenci OCF do monitorowania procesów Cepha.
174 %package -n hadoop-cephfs
175 Summary: Hadoop client for Ceph filesystem
176 Summary(pl.UTF-8): Klient Hadoopa dla systemu plików Ceph
178 Requires: %{name} = %{version}-%{release}
181 %description -n hadoop-cephfs
182 Hadoop client for Ceph filesystem.
184 %description -n hadoop-cephfs -l pl.UTF-8
185 Klient Hadoopa dla systemu plików Ceph.
199 %{?with_hadoop:CPPFLAGS="%{rpmcppflags} -I%{_jvmdir}/java/include -I%{_jvmdir}/java/include/linux"}
200 # ac_cv_prog_uudecode_base64=no is a hack to compile Test.class instead of
201 # using included one which fails with Sun/Oracle JDK 1.6
203 %{?with_java:JAVAC=/usr/bin/javac} \
204 ac_cv_prog_uudecode_base64=no \
207 --with-hadoop%{!?with_hadoop:=no} \
208 %{?with_zfs:--with-libzfs} \
211 --with-system-leveldb \
212 --with-system-libs3 \
213 %{?with_java:--enable-cephfs-java --with-jdk-dir=%{_jvmdir}/java} \
214 --disable-silent-rules
219 rm -rf $RPM_BUILD_ROOT
220 install -d $RPM_BUILD_ROOT%{_localstatedir}/{lib/ceph/tmp,log/ceph/stat} \
221 $RPM_BUILD_ROOT%{_sysconfdir}/{ceph,bash_completion.d,logrotate.d,rc.d/init.d}
224 DESTDIR=$RPM_BUILD_ROOT \
227 install -p src/init-ceph $RPM_BUILD_ROOT/etc/rc.d/init.d/ceph
228 install -p src/logrotate.conf $RPM_BUILD_ROOT%{_sysconfdir}/logrotate.d/ceph
231 %{__rm} $RPM_BUILD_ROOT%{_libdir}/rados-classes/*.{a,la}
233 %{__rm} $RPM_BUILD_ROOT%{_libdir}/libhadoopcephfs.{la,a}
236 %{__rm} $RPM_BUILD_ROOT%{_libdir}/libcephfs_jni.{la,a}
240 %{__rm} $RPM_BUILD_ROOT%{_docdir}/ceph/sample.{ceph.conf,fetch_config}
245 rm -rf $RPM_BUILD_ROOT
248 /sbin/chkconfig --add ceph
249 %service ceph restart
252 if [ "$1" = "0" ] ; then
254 /sbin/chkconfig --del ceph
257 %post libs -p /sbin/ldconfig
258 %postun libs -p /sbin/ldconfig
260 %post -n java-cephfs -p /sbin/ldconfig
261 %postun -n java-cephfs -p /sbin/ldconfig
263 %post -n hadoop-cephfs -p /sbin/ldconfig
264 %postun -n hadoop-cephfs -p /sbin/ldconfig
267 %defattr(644,root,root,755)
268 # COPYING specifies licenses of individual parts
269 %doc AUTHORS COPYING README src/sample.ceph.conf src/sample.fetch_config
270 %attr(754,root,root) /etc/rc.d/init.d/ceph
271 %dir %{_sysconfdir}/ceph
272 %attr(755,root,root) %{_bindir}/ceph
273 %attr(755,root,root) %{_bindir}/ceph-authtool
274 %attr(755,root,root) %{_bindir}/ceph-clsinfo
275 %attr(755,root,root) %{_bindir}/ceph-conf
276 %attr(755,root,root) %{_bindir}/ceph-coverage
277 %attr(755,root,root) %{_bindir}/ceph-debugpack
278 %attr(755,root,root) %{_bindir}/ceph-dencoder
279 %attr(755,root,root) %{_bindir}/ceph-mds
280 %attr(755,root,root) %{_bindir}/ceph-mon
281 %attr(755,root,root) %{_bindir}/ceph-osd
282 %attr(755,root,root) %{_bindir}/ceph-post-file
283 %attr(755,root,root) %{_bindir}/ceph-rbdnamer
284 %attr(755,root,root) %{_bindir}/ceph-rest-api
285 %attr(755,root,root) %{_bindir}/ceph-run
286 %attr(755,root,root) %{_bindir}/ceph-syn
287 %attr(755,root,root) %{_bindir}/ceph_filestore_dump
288 %attr(755,root,root) %{_bindir}/ceph_mon_store_converter
289 %attr(755,root,root) %{_bindir}/cephfs
290 %attr(755,root,root) %{_bindir}/crushtool
291 %attr(755,root,root) %{_bindir}/librados-config
292 %attr(755,root,root) %{_bindir}/monmaptool
293 %attr(755,root,root) %{_bindir}/osdmaptool
294 %attr(755,root,root) %{_bindir}/rados
295 %attr(755,root,root) %{_bindir}/rbd
296 %attr(755,root,root) %{_bindir}/rbd-fuse
297 %attr(755,root,root) %{_sbindir}/ceph-create-keys
298 %attr(755,root,root) %{_sbindir}/ceph-disk
299 %attr(755,root,root) %{_sbindir}/ceph-disk-activate
300 %attr(755,root,root) %{_sbindir}/ceph-disk-prepare
301 %attr(755,root,root) %{_sbindir}/ceph-disk-udev
302 %attr(755,root,root) /sbin/mkcephfs
303 %attr(755,root,root) /sbin/mount.ceph
304 %attr(755,root,root) /sbin/mount.fuse.ceph
305 %dir %{_libdir}/rados-classes
306 %attr(755,root,root) %{_libdir}/rados-classes/libcls_hello.so*
307 %attr(755,root,root) %{_libdir}/rados-classes/libcls_kvs.so*
308 %attr(755,root,root) %{_libdir}/rados-classes/libcls_lock.so*
309 %attr(755,root,root) %{_libdir}/rados-classes/libcls_log.so*
310 %attr(755,root,root) %{_libdir}/rados-classes/libcls_rbd.so*
311 %attr(755,root,root) %{_libdir}/rados-classes/libcls_refcount.so*
312 %attr(755,root,root) %{_libdir}/rados-classes/libcls_replica_log.so*
313 %attr(755,root,root) %{_libdir}/rados-classes/libcls_rgw.so*
314 %attr(755,root,root) %{_libdir}/rados-classes/libcls_statelog.so*
315 %attr(755,root,root) %{_libdir}/rados-classes/libcls_version.so*
317 %attr(755,root,root) %{_libdir}/ceph/ceph_common.sh
319 %config(noreplace) /etc/logrotate.d/ceph
320 %config(noreplace) %{_sysconfdir}/bash_completion.d/rados
321 %config(noreplace) %{_sysconfdir}/bash_completion.d/ceph
322 %config(noreplace) %{_sysconfdir}/bash_completion.d/rbd
323 %{_mandir}/man8/ceph.8*
324 %{_mandir}/man8/ceph-authtool.8*
325 %{_mandir}/man8/ceph-clsinfo.8*
326 %{_mandir}/man8/ceph-conf.8*
327 %{_mandir}/man8/ceph-debugpack.8*
328 %{_mandir}/man8/ceph-dencoder.8*
329 %{_mandir}/man8/ceph-mds.8*
330 %{_mandir}/man8/ceph-mon.8*
331 %{_mandir}/man8/ceph-osd.8*
332 %{_mandir}/man8/ceph-post-file.8*
333 %{_mandir}/man8/ceph-rbdnamer.8*
334 %{_mandir}/man8/ceph-rest-api.8*
335 %{_mandir}/man8/ceph-run.8*
336 %{_mandir}/man8/ceph-syn.8*
337 %{_mandir}/man8/cephfs.8*
338 %{_mandir}/man8/crushtool.8*
339 %{_mandir}/man8/librados-config.8*
340 %{_mandir}/man8/mkcephfs.8*
341 %{_mandir}/man8/monmaptool.8*
342 %{_mandir}/man8/mount.ceph.8*
343 %{_mandir}/man8/osdmaptool.8*
344 %{_mandir}/man8/rados.8*
345 %{_mandir}/man8/radosgw.8*
346 %{_mandir}/man8/radosgw-admin.8*
347 %{_mandir}/man8/rbd.8*
348 %{_mandir}/man8/rbd-fuse.8*
350 %dir %{_localstatedir}/lib/ceph
351 %dir %{_localstatedir}/lib/ceph/tmp
352 %dir %{_localstatedir}/log/ceph
355 %defattr(644,root,root,755)
356 %attr(755,root,root) %{_libdir}/libcephfs.so.*.*.*
357 %attr(755,root,root) %ghost %{_libdir}/libcephfs.so.1
358 %attr(755,root,root) %{_libdir}/librados.so.*.*.*
359 %attr(755,root,root) %ghost %{_libdir}/librados.so.2
360 %attr(755,root,root) %{_libdir}/librbd.so.*.*.*
361 %attr(755,root,root) %ghost %{_libdir}/librbd.so.1
364 %defattr(644,root,root,755)
365 %attr(755,root,root) %{_libdir}/libcephfs.so
366 %attr(755,root,root) %{_libdir}/librados.so
367 %attr(755,root,root) %{_libdir}/librbd.so
368 %{_libdir}/libcephfs.la
369 %{_libdir}/librados.la
371 %{_includedir}/cephfs
376 %defattr(644,root,root,755)
377 %{_libdir}/libcephfs.a
378 %{_libdir}/librados.a
381 %files -n python-ceph
382 %defattr(644,root,root,755)
383 %{py_sitescriptdir}/ceph_argparse.py[co]
384 %{py_sitescriptdir}/ceph_rest_api.py[co]
385 %{py_sitescriptdir}/cephfs.py[co]
386 %{py_sitescriptdir}/rados.py[co]
387 %{py_sitescriptdir}/rbd.py[co]
390 %files -n java-cephfs
391 %defattr(644,root,root,755)
392 %attr(755,root,root) %{_libdir}/libcephfs_jni.so.*.*.*
393 %attr(755,root,root) %ghost %{_libdir}/libcephfs_jni.so.1
394 %attr(755,root,root) %{_libdir}/libcephfs_jni.so
395 %{_javadir}/libcephfs.jar
399 %defattr(644,root,root,755)
400 %attr(755,root,root) %{_bindir}/ceph-fuse
401 %{_mandir}/man8/ceph-fuse.8*
404 %defattr(644,root,root,755)
405 %attr(755,root,root) %{_bindir}/radosgw
406 %attr(755,root,root) %{_bindir}/radosgw-admin
407 %{_sysconfdir}/bash_completion.d/radosgw-admin
409 %files resource-agents
410 %defattr(644,root,root,755)
411 %dir %{_prefix}/lib/ocf/resource.d/ceph
412 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/ceph
413 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/mds
414 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/mon
415 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/osd
416 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/rbd
419 %files -n hadoop-cephfs
420 %defattr(644,root,root,755)
421 %attr(755,root,root) %{_libdir}/libhadoopcephfs.so.*.*.*
422 %attr(755,root,root) %ghost %{_libdir}/libhadoopcephfs.so.1
423 %attr(755,root,root) %{_libdir}/libhadoopcephfs.so