Ceph is a distributed object, block, and file storage platform
Go to file
Sage Weil 9391465910 mds: treat open requests as non-idempotent
The problem is that the reply contains a capability, and as such
is statefull and can't be lost.  Forwards by the MDS on behalf of
the client, however, introduce the possibility of multiple copies
or a request in flight if one of the MDSs fails, and the client
will drop any duplicate replies it receives.

Alternatively, the client could _also_ parse duplicate responses
(i.e. call fill_trace).  I'm not sure if that's a good idea.  In
any case, MDS forwarded requests are only really important for
dealing with flash flood scenarios on extremely large clusters,
so let's just set this aside for now.
2008-11-13 13:30:26 -08:00
branches/aleung/security1
debian debian: include debian dir in usr/src/modules/ceph 2008-10-16 18:27:57 -07:00
fusetrace
src mds: treat open requests as non-idempotent 2008-11-13 13:30:26 -08:00
web
.gitignore debian: fix kernel module in source package 2008-10-16 13:53:56 -07:00
AUTHORS
autogen.sh
ceph.spec.in ceph.spec.in: include crun 2008-10-08 09:28:32 -07:00
ChangeLog
configure.ac makefile: make --with-debug work, fix build errors 2008-10-31 12:49:46 -07:00
COPYING
INSTALL
Makefile.am debian: fix debian-doc; include debian dir in dist tarball 2008-10-09 13:34:32 -07:00
NEWS
README

Ceph - a scalable distributed file system
-----------------------------------------

Please see http://ceph.newdream.net/ for current info.

----

To build the Linux kernel client,

$ cd src/kernel
$ make
or
$ make KERNELDIR=/path/to/linux
$ insmod ceph.ko
$ mount -t ceph 1.2.3.4:/ /mnt/ceph
...

----

To build the server daemons, and FUSE client,

$ ./autogen.sh
$ ./configure
$ cd src
$ make

(Note that the FUSE client will only be built if libfuse is present.)

----

A quick summary of binaries that will be built in src/

daemons:
 cmon -- monitor daemon.  handles cluster state and configuration
         information.
 cosd -- storage daemon.  stores objects on a given block device.
 cmds -- metadata daemon.  handles file system namespace.
 cmonctl -- send commands to the monitor cluster.

userland clients:
 cfuse -- fuse client.
 csyn -- synthetic workload generator client.

tools:
 mkmonfs -- create a fresh monfs (for a new filesystem)
 monmaptool -- create/edit mon map
 osdmaptool -- create/edit osd map 
 crushtool -- create/edit crush map
 dupstore -- duplicate an osd object store (offline)

development/debugging:
 fakesyn -- simulator with synthetic workload
 fakefuse -- simulator that mounts with fuse

----

see also src/README