3 %bcond_with hadoop # Hadoop client (requires JNI)
4 %bcond_without java # Java binding
6 Summary: User space components of the Ceph file system
7 Summary(pl.UTF-8): Działające w przestrzeni użytkownika elementy systemu plików Ceph
11 License: LGPL v2.1 (libraries), GPL v2 (some programs)
13 Source0: http://ceph.newdream.net/download/%{name}-%{version}.tar.bz2
14 # Source0-md5: edd313833a4bc1057d59a593fb3a0c12
15 Patch0: %{name}-init-fix.patch
16 Patch1: %{name}.logrotate.patch
17 Patch2: %{name}-link.patch
18 URL: http://ceph.newdream.net/
19 BuildRequires: autoconf >= 2.59
20 BuildRequires: automake
21 BuildRequires: boost-devel >= 1.34
22 BuildRequires: cryptopp-devel
23 BuildRequires: curl-devel
24 BuildRequires: expat-devel >= 1.95
25 BuildRequires: fcgi-devel
26 BuildRequires: gdbm-devel
27 %if %{with java} || %{with hadoop}
30 BuildRequires: keyutils-devel
31 BuildRequires: leveldb-devel
32 BuildRequires: libaio-devel
33 BuildRequires: libatomic_ops
34 BuildRequires: libedit-devel >= 2.11
35 BuildRequires: libfuse-devel
36 BuildRequires: libltdl-devel
37 BuildRequires: libs3-devel
38 BuildRequires: libstdc++-devel
39 BuildRequires: libtcmalloc-devel
40 BuildRequires: libtool >= 2:1.5
41 BuildRequires: libuuid-devel
42 BuildRequires: perl-base
43 BuildRequires: pkgconfig
44 BuildRequires: python >= 1:2.4
45 BuildRequires: rpmbuild(macros) >= 1.228
46 BuildRequires: snappy-devel
47 Requires(post,preun): /sbin/chkconfig
48 Requires(preun): rc-scripts
49 Requires: %{name}-libs = %{version}-%{release}
51 BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
53 %define skip_post_check_so libcls_.*.so.*
56 Ceph is a distributed network file system designed to provide
57 excellent performance, reliability, and scalability.
59 %description -l pl.UTF-8
60 Ceph to rozproszony sieciowy system plików zaprojektowany z myślą o
61 dobrej wydajności, wiarygodności i skalowalności.
64 Summary: Ceph shared libraries
65 Summary(pl.UTF-8): Biblioteki współdzielone Cepha
69 Ceph shared libraries.
71 %description libs -l pl.UTF-8
72 Biblioteki współdzielone Cepha.
75 Summary: Ceph header files
76 Summary(pl.UTF-8): Pliki nagłówkowe bibliotek Cepha
78 Group: Development/Libraries
79 Requires: %{name}-libs = %{version}-%{release}
80 Requires: boost-devel >= 1.34
81 Requires: cryptopp-devel
82 Requires: leveldb-devel
83 Requires: libatomic_ops
84 Requires: libuuid-devel
87 This package contains the headers needed to develop programs that use
90 %description devel -l pl.UTF-8
91 Ten pakiet zawiera pliki nagłówkowe potrzebne do tworzenia programów
92 wykorzystujących Cepha.
95 Summary: Ceph static libraries
96 Summary(pl.UTF-8): Biblioteki statyczne Cepha
98 Group: Development/Libraries
99 Requires: %{name}-devel = %{version}-%{release}
102 This package contains static Ceph libraries.
104 %description static -l pl.UTF-8
105 Ten pakiet zawiera biblioteki statyczne Cepha.
107 %package -n python-ceph
108 Summary: Ceph Python bindings
109 Summary(pl.UTF-8): Wiązania Pythona do bibliotek Cepha
110 Group: Development/Languages/Python
111 Requires: %{name}-libs = %{version}-%{release}
113 %description -n python-ceph
114 Ceph Python bindings.
116 %description -n python-ceph -l pl.UTF-8
117 Wiązania Pythona do bibliotek Cepha.
119 %package -n java-cephfs
120 Summary: CephFS Java bindings
121 Summary(pl.UTF-8): Wiązania Javy do biblioteki CephFS
122 Group: Libraries/Java
123 Requires: %{name}-libs = %{version}-%{release}
125 %description -n java-cephfs
126 CephFS Java bindings.
128 %description -n java-cephfs -l pl.UTF-8
129 Wiązania Javy do biblioteki CephFS.
132 Summary: Ceph FUSE-based client
133 Summary(pl.UTF-8): Klient Cepha oparty na FUSE
135 Requires: %{name} = %{version}-%{release}
138 FUSE based client for Ceph distributed network file system.
140 %description fuse -l pl.UTF-8
141 Oparty na FUSE klient rozproszonego sieciowego systemu plików Ceph.
144 Summary: rados REST gateway
145 Summary(pl.UTF-8): Bramka REST-owa rados
146 Group: Applications/System
147 #Requires: apache-mod_fcgid
150 radosgw is an S3 HTTP REST gateway for the RADOS object store. It is
151 implemented as a FastCGI module using libfcgi, and can be used in
152 conjunction with any FastCGI capable web server.
154 %description radosgw -l pl.UTF-8
155 radosgw to REST-owa bramka HTTP S3 do przechowalni obiektów RADOS.
156 Jest zaimplementowana jako moduł FastCGI wykorzystujący libfcgi i może
157 być używana w połączeniu z dowolnym serwerem WWW obsługującym FastCGI.
159 %package resource-agents
160 Summary: OCF Resource Agents for Ceph processes
161 Summary(pl.UTF-8): Agenci OCF do monitorowania procesów Cepha
162 Group: Applications/System
163 Requires: %{name} = %{version}-%{release}
164 Requires: resource-agents
166 %description resource-agents
167 OCF Resource Agents for Ceph processes.
169 %description resource-agents -l pl.UTF-8
170 Agenci OCF do monitorowania procesów Cepha.
172 %package -n hadoop-cephfs
173 Summary: Hadoop client for Ceph filesystem
174 Summary(pl.UTF-8): Klient Hadoopa dla systemu plików Ceph
176 Requires: %{name} = %{version}-%{release}
179 %description -n hadoop-cephfs
180 Hadoop client for Ceph filesystem.
182 %description -n hadoop-cephfs -l pl.UTF-8
183 Klient Hadoopa dla systemu plików Ceph.
197 %{?with_hadoop:CPPFLAGS="%{rpmcppflags} -I%{_jvmdir}/java/include -I%{_jvmdir}/java/include/linux"}
198 # ac_cv_prog_uudecode_base64=no is a hack to compile Test.class instead of
199 # using included one which fails with Sun/Oracle JDK 1.6
201 ac_cv_prog_uudecode_base64=no \
204 --with-hadoop%{!?with_hadoop:=no} \
207 --with-system-leveldb \
208 --with-system-libs3 \
209 %{?with_java:--enable-cephfs-java --with-jdk-dir=%{_jvmdir}/java} \
210 --disable-silent-rules
215 rm -rf $RPM_BUILD_ROOT
216 install -d $RPM_BUILD_ROOT%{_localstatedir}/{lib/ceph/tmp,log/ceph/stat} \
217 $RPM_BUILD_ROOT%{_sysconfdir}/{ceph,bash_completion.d,logrotate.d,rc.d/init.d}
220 DESTDIR=$RPM_BUILD_ROOT \
223 install -p src/init-ceph $RPM_BUILD_ROOT/etc/rc.d/init.d/ceph
224 install -p src/logrotate.conf $RPM_BUILD_ROOT%{_sysconfdir}/logrotate.d/ceph
227 %{__rm} $RPM_BUILD_ROOT%{_libdir}/rados-classes/*.{a,la}
229 %{__rm} $RPM_BUILD_ROOT%{_libdir}/libhadoopcephfs.{la,a}
232 %{__rm} $RPM_BUILD_ROOT%{_libdir}/libcephfs_jni.{la,a}
236 %{__rm} $RPM_BUILD_ROOT%{_docdir}/ceph/sample.{ceph.conf,fetch_config}
241 rm -rf $RPM_BUILD_ROOT
244 /sbin/chkconfig --add ceph
245 %service ceph restart
248 if [ "$1" = "0" ] ; then
250 /sbin/chkconfig --del ceph
253 %post libs -p /sbin/ldconfig
254 %postun libs -p /sbin/ldconfig
256 %post -n java-cephfs -p /sbin/ldconfig
257 %postun -n java-cephfs -p /sbin/ldconfig
259 %post -n hadoop-cephfs -p /sbin/ldconfig
260 %postun -n hadoop-cephfs -p /sbin/ldconfig
263 %defattr(644,root,root,755)
264 # COPYING specifies licenses of individual parts
265 %doc AUTHORS COPYING README src/sample.ceph.conf src/sample.fetch_config
266 %attr(754,root,root) /etc/rc.d/init.d/ceph
267 %dir %{_sysconfdir}/ceph
268 %attr(755,root,root) %{_bindir}/ceph
269 %attr(755,root,root) %{_bindir}/ceph-authtool
270 %attr(755,root,root) %{_bindir}/ceph-clsinfo
271 %attr(755,root,root) %{_bindir}/ceph-conf
272 %attr(755,root,root) %{_bindir}/ceph-coverage
273 %attr(755,root,root) %{_bindir}/ceph-debugpack
274 %attr(755,root,root) %{_bindir}/ceph-dencoder
275 %attr(755,root,root) %{_bindir}/ceph-mds
276 %attr(755,root,root) %{_bindir}/ceph-mon
277 %attr(755,root,root) %{_bindir}/ceph-osd
278 %attr(755,root,root) %{_bindir}/ceph-rbdnamer
279 %attr(755,root,root) %{_bindir}/ceph-run
280 %attr(755,root,root) %{_bindir}/ceph-syn
281 %attr(755,root,root) %{_bindir}/ceph_filestore_dump
282 %attr(755,root,root) %{_bindir}/ceph_mon_store_converter
283 %attr(755,root,root) %{_bindir}/cephfs
284 %attr(755,root,root) %{_bindir}/crushtool
285 %attr(755,root,root) %{_bindir}/librados-config
286 %attr(755,root,root) %{_bindir}/monmaptool
287 %attr(755,root,root) %{_bindir}/osdmaptool
288 %attr(755,root,root) %{_bindir}/rados
289 %attr(755,root,root) %{_bindir}/rbd
290 %attr(755,root,root) %{_bindir}/rbd-fuse
291 %attr(755,root,root) %{_sbindir}/ceph-create-keys
292 %attr(755,root,root) %{_sbindir}/ceph-disk
293 %attr(755,root,root) %{_sbindir}/ceph-disk-activate
294 %attr(755,root,root) %{_sbindir}/ceph-disk-prepare
295 %attr(755,root,root) %{_sbindir}/ceph-disk-udev
296 %attr(755,root,root) /sbin/mkcephfs
297 %attr(755,root,root) /sbin/mount.ceph
298 %attr(755,root,root) /sbin/mount.fuse.ceph
299 %dir %{_libdir}/rados-classes
300 %attr(755,root,root) %{_libdir}/rados-classes/libcls_kvs.so*
301 %attr(755,root,root) %{_libdir}/rados-classes/libcls_lock.so*
302 %attr(755,root,root) %{_libdir}/rados-classes/libcls_rbd.so*
303 %attr(755,root,root) %{_libdir}/rados-classes/libcls_refcount.so*
304 %attr(755,root,root) %{_libdir}/rados-classes/libcls_rgw.so*
306 %attr(755,root,root) %{_libdir}/ceph/ceph_common.sh
307 %config(noreplace) /etc/logrotate.d/ceph
308 %config(noreplace) %{_sysconfdir}/bash_completion.d/rados
309 %config(noreplace) %{_sysconfdir}/bash_completion.d/ceph
310 %config(noreplace) %{_sysconfdir}/bash_completion.d/rbd
311 %{_mandir}/man8/ceph.8*
312 %{_mandir}/man8/ceph-authtool.8*
313 %{_mandir}/man8/ceph-clsinfo.8*
314 %{_mandir}/man8/ceph-conf.8*
315 %{_mandir}/man8/ceph-debugpack.8*
316 %{_mandir}/man8/ceph-dencoder.8*
317 %{_mandir}/man8/ceph-mds.8*
318 %{_mandir}/man8/ceph-mon.8*
319 %{_mandir}/man8/ceph-osd.8*
320 %{_mandir}/man8/ceph-rbdnamer.8*
321 %{_mandir}/man8/ceph-run.8*
322 %{_mandir}/man8/ceph-syn.8*
323 %{_mandir}/man8/cephfs.8*
324 %{_mandir}/man8/crushtool.8*
325 %{_mandir}/man8/librados-config.8*
326 %{_mandir}/man8/mkcephfs.8*
327 %{_mandir}/man8/monmaptool.8*
328 %{_mandir}/man8/mount.ceph.8*
329 %{_mandir}/man8/osdmaptool.8*
330 %{_mandir}/man8/rados.8*
331 %{_mandir}/man8/radosgw.8*
332 %{_mandir}/man8/radosgw-admin.8*
333 %{_mandir}/man8/rbd.8*
334 %{_mandir}/man8/rbd-fuse.8*
336 %dir %{_localstatedir}/lib/ceph
337 %dir %{_localstatedir}/lib/ceph/tmp
338 %dir %{_localstatedir}/log/ceph
341 %defattr(644,root,root,755)
342 %attr(755,root,root) %{_libdir}/libcephfs.so.*.*.*
343 %attr(755,root,root) %ghost %{_libdir}/libcephfs.so.1
344 %attr(755,root,root) %{_libdir}/librados.so.*.*.*
345 %attr(755,root,root) %ghost %{_libdir}/librados.so.2
346 %attr(755,root,root) %{_libdir}/librbd.so.*.*.*
347 %attr(755,root,root) %ghost %{_libdir}/librbd.so.1
350 %defattr(644,root,root,755)
351 %attr(755,root,root) %{_libdir}/libcephfs.so
352 %attr(755,root,root) %{_libdir}/librados.so
353 %attr(755,root,root) %{_libdir}/librbd.so
354 %{_libdir}/libcephfs.la
355 %{_libdir}/librados.la
357 %{_includedir}/cephfs
362 %defattr(644,root,root,755)
363 %{_libdir}/libcephfs.a
364 %{_libdir}/librados.a
367 %files -n python-ceph
368 %defattr(644,root,root,755)
369 %{py_sitescriptdir}/cephfs.py[co]
370 %{py_sitescriptdir}/rados.py[co]
371 %{py_sitescriptdir}/rbd.py[co]
374 %files -n java-cephfs
375 %defattr(644,root,root,755)
376 %attr(755,root,root) %{_libdir}/libcephfs_jni.so.*.*.*
377 %attr(755,root,root) %ghost %{_libdir}/libcephfs_jni.so.1
378 %attr(755,root,root) %{_libdir}/libcephfs_jni.so
379 %{_javadir}/libcephfs.jar
383 %defattr(644,root,root,755)
384 %attr(755,root,root) %{_bindir}/ceph-fuse
385 %{_mandir}/man8/ceph-fuse.8*
388 %defattr(644,root,root,755)
389 %attr(755,root,root) %{_bindir}/radosgw
390 %attr(755,root,root) %{_bindir}/radosgw-admin
391 %{_sysconfdir}/bash_completion.d/radosgw-admin
393 %files resource-agents
394 %defattr(644,root,root,755)
395 %dir %{_prefix}/lib/ocf/resource.d/ceph
396 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/ceph
397 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/mds
398 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/mon
399 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/osd
400 %attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/rbd
403 %files -n hadoop-cephfs
404 %defattr(644,root,root,755)
405 %attr(755,root,root) %{_libdir}/libhadoopcephfs.so.*.*.*
406 %attr(755,root,root) %ghost %{_libdir}/libhadoopcephfs.so.1
407 %attr(755,root,root) %{_libdir}/libhadoopcephfs.so