ceph/doc/cephfs/experimental-features.rst
Jeff Layton 9c406d0ab3 mon: deprecate CephFS inline_data support
The plan is to start deprecating this feature now so that we can remove
it in a future release. Change it to require the
--yes-i-really-really-mean-it flag, and to emit a custom
warning when that isn't specified.

For now, we leave the testing in place since we do want to be notified
if something breaks before we're ready to rip it out completely.

Fixes: https://tracker.ceph.com/issues/41311
Signed-off-by: Jeff Layton <jlayton@redhat.com>
2019-09-19 09:15:13 -04:00

115 lines
4.8 KiB
ReStructuredText

Experimental Features
=====================
CephFS includes a number of experimental features which are not fully stabilized
or qualified for users to turn on in real deployments. We generally do our best
to clearly demarcate these and fence them off so they cannot be used by mistake.
Some of these features are closer to being done than others, though. We describe
each of them with an approximation of how risky they are and briefly describe
what is required to enable them. Note that doing so will *irrevocably* flag maps
in the monitor as having once enabled this flag to improve debugging and
support processes.
Inline data
-----------
By default, all CephFS file data is stored in RADOS objects. The inline data
feature enables small files (generally <2KB) to be stored in the inode
and served out of the MDS. This may improve small-file performance but increases
load on the MDS. It is not sufficiently tested to support at this time, although
failures within it are unlikely to make non-inlined data inaccessible
Inline data has always been off by default and requires setting
the ``inline_data`` flag.
Inline data has been declared deprecated for the Octopus release, and will
likely be removed altogether in the Q release.
Mantle: Programmable Metadata Load Balancer
-------------------------------------------
Mantle is a programmable metadata balancer built into the MDS. The idea is to
protect the mechanisms for balancing load (migration, replication,
fragmentation) but stub out the balancing policies using Lua. For details, see
:doc:`/cephfs/mantle`.
Snapshots
---------
Like multiple active MDSes, CephFS is designed from the ground up to support
snapshotting of arbitrary directories. There are no known bugs at the time of
writing, but there is insufficient testing to provide stability guarantees and
every expansion of testing has generally revealed new issues. If you do enable
snapshots and experience failure, manual intervention will be needed.
Snapshots are known not to work properly with multiple file systems (below) in
some cases. Specifically, if you share a pool for multiple FSes and delete
a snapshot in one FS, expect to lose snapshotted file data in any other FS using
snapshots. See the :doc:`/dev/cephfs-snapshots` page for more information.
For somewhat obscure implementation reasons, the kernel client only supports up
to 400 snapshots (http://tracker.ceph.com/issues/21420).
Snapshotting was blocked off with the ``allow_new_snaps`` flag prior to Mimic.
Multiple file systems within a Ceph cluster
-------------------------------------------
Code was merged prior to the Jewel release which enables administrators
to create multiple independent CephFS file systems within a single Ceph cluster.
These independent file systems have their own set of active MDSes, cluster maps,
and data. But the feature required extensive changes to data structures which
are not yet fully qualified, and has security implications which are not all
apparent nor resolved.
There are no known bugs, but any failures which do result from having multiple
active file systems in your cluster will require manual intervention and, so far,
will not have been experienced by anybody else -- knowledgeable help will be
extremely limited. You also probably do not have the security or isolation
guarantees you want or think you have upon doing so.
Note that snapshots and multiple file systems are *not* tested in combination
and may not work together; see above.
Multiple file systems were available starting in the Jewel release candidates
but must be turned on via the ``enable_multiple`` flag until declared stable.
LazyIO
------
LazyIO relaxes POSIX semantics. Buffered reads/writes are allowed even when a
file is opened by multiple applications on multiple clients. Applications are
responsible for managing cache coherency themselves.
Previously experimental features
================================
Directory Fragmentation
-----------------------
Directory fragmentation was considered experimental prior to the *Luminous*
(12.2.x). It is now enabled by default on new file systems. To enable directory
fragmentation on file systems created with older versions of Ceph, set
the ``allow_dirfrags`` flag on the file system:
::
ceph fs set <file system name> allow_dirfrags 1
Multiple active metadata servers
--------------------------------
Prior to the *Luminous* (12.2.x) release, running multiple active metadata
servers within a single file system was considered experimental. Creating
multiple active metadata servers is now permitted by default on new
file systems.
File Systems created with older versions of Ceph still require explicitly
enabling multiple active metadata servers as follows:
::
ceph fs set <file system name> allow_multimds 1
Note that the default size of the active mds cluster (``max_mds``) is
still set to 1 initially.