2014-09-13 22:58:13 +00:00
|
|
|
=======================
|
|
|
|
ISA erasure code plugin
|
|
|
|
=======================
|
|
|
|
|
2015-02-18 11:42:50 +00:00
|
|
|
The *isa* plugin encapsulates the `ISA
|
2014-09-13 22:58:13 +00:00
|
|
|
<https://01.org/intel%C2%AE-storage-acceleration-library-open-source-version/>`_
|
|
|
|
library. It only runs on Intel processors.
|
|
|
|
|
|
|
|
Create an isa profile
|
|
|
|
=====================
|
|
|
|
|
2015-02-18 11:42:50 +00:00
|
|
|
To create a new *isa* erasure code profile::
|
2014-09-13 22:58:13 +00:00
|
|
|
|
|
|
|
ceph osd erasure-code-profile set {name} \
|
|
|
|
plugin=isa \
|
|
|
|
technique={reed_sol_van|cauchy} \
|
2014-09-25 09:56:32 +00:00
|
|
|
[k={data-chunks}] \
|
|
|
|
[m={coding-chunks}] \
|
2017-06-30 18:59:39 +00:00
|
|
|
[crush-root={root}] \
|
|
|
|
[crush-failure-domain={bucket-type}] \
|
|
|
|
[crush-device-class={device-class}] \
|
2014-09-13 22:58:13 +00:00
|
|
|
[directory={directory}] \
|
|
|
|
[--force]
|
|
|
|
|
|
|
|
Where:
|
|
|
|
|
|
|
|
``k={data chunks}``
|
|
|
|
|
|
|
|
:Description: Each object is split in **data-chunks** parts,
|
|
|
|
each stored on a different OSD.
|
|
|
|
|
|
|
|
:Type: Integer
|
2014-09-25 09:56:32 +00:00
|
|
|
:Required: No.
|
|
|
|
:Default: 7
|
2014-09-13 22:58:13 +00:00
|
|
|
|
|
|
|
``m={coding-chunks}``
|
|
|
|
|
|
|
|
:Description: Compute **coding chunks** for each object and store them
|
|
|
|
on different OSDs. The number of coding chunks is also
|
|
|
|
the number of OSDs that can be down without losing data.
|
|
|
|
|
|
|
|
:Type: Integer
|
2014-09-25 09:56:32 +00:00
|
|
|
:Required: No.
|
|
|
|
:Default: 3
|
2014-09-13 22:58:13 +00:00
|
|
|
|
|
|
|
``technique={reed_sol_van|cauchy}``
|
|
|
|
|
|
|
|
:Description: The ISA plugin comes in two `Reed Solomon
|
|
|
|
<https://en.wikipedia.org/wiki/Reed%E2%80%93Solomon_error_correction>`_
|
|
|
|
forms. If *reed_sol_van* is set, it is `Vandermonde
|
|
|
|
<https://en.wikipedia.org/wiki/Vandermonde_matrix>`_, if
|
|
|
|
*cauchy* is set, it is `Cauchy
|
|
|
|
<https://en.wikipedia.org/wiki/Cauchy_matrix>`_.
|
|
|
|
|
|
|
|
:Type: String
|
|
|
|
:Required: No.
|
|
|
|
:Default: reed_sol_van
|
|
|
|
|
2017-06-30 18:59:39 +00:00
|
|
|
``crush-root={root}``
|
2014-09-13 22:58:13 +00:00
|
|
|
|
|
|
|
:Description: The name of the crush bucket used for the first step of
|
|
|
|
the ruleset. For intance **step take default**.
|
|
|
|
|
|
|
|
:Type: String
|
|
|
|
:Required: No.
|
|
|
|
:Default: default
|
|
|
|
|
2017-06-30 18:59:39 +00:00
|
|
|
``crush-failure-domain={bucket-type}``
|
2014-09-13 22:58:13 +00:00
|
|
|
|
|
|
|
:Description: Ensure that no two chunks are in a bucket with the same
|
|
|
|
failure domain. For instance, if the failure domain is
|
|
|
|
**host** no two chunks will be stored on the same
|
|
|
|
host. It is used to create a ruleset step such as **step
|
|
|
|
chooseleaf host**.
|
|
|
|
|
|
|
|
:Type: String
|
|
|
|
:Required: No.
|
|
|
|
:Default: host
|
|
|
|
|
2017-06-30 18:59:39 +00:00
|
|
|
``crush-device-class={device-class}``
|
|
|
|
|
|
|
|
:Description: Restrict placement to devices of a specific class (e.g.,
|
|
|
|
``ssd`` or ``hdd``), using the crush device class names
|
|
|
|
in the CRUSH map.
|
|
|
|
|
|
|
|
:Type: String
|
|
|
|
:Required: No.
|
|
|
|
:Default:
|
|
|
|
|
2014-09-13 22:58:13 +00:00
|
|
|
``directory={directory}``
|
|
|
|
|
|
|
|
:Description: Set the **directory** name from which the erasure code
|
|
|
|
plugin is loaded.
|
|
|
|
|
|
|
|
:Type: String
|
|
|
|
:Required: No.
|
|
|
|
:Default: /usr/lib/ceph/erasure-code
|
|
|
|
|
|
|
|
``--force``
|
|
|
|
|
|
|
|
:Description: Override an existing profile by the same name.
|
|
|
|
|
|
|
|
:Type: String
|
|
|
|
:Required: No.
|
|
|
|
|