mirror of
https://github.com/ceph/ceph-csi.git
synced 2024-11-10 00:10:20 +00:00
doc: documentation updates on capabilities
Documents exact capabilities a id requires against a Ceph cluster for RBD and CephFS plugins. Signed-off-by: yati1998 <ypadia@redhat.com>
This commit is contained in:
parent
aa5b53fcce
commit
75d800c07e
88
docs/capabilities.md
Normal file
88
docs/capabilities.md
Normal file
@ -0,0 +1,88 @@
|
|||||||
|
# Capabilities of an user required for a ceph-csi in an Ceph cluster
|
||||||
|
|
||||||
|
Ceph uses the term capabilities to describe authorizing an authenticated user
|
||||||
|
to exercise the functionality of the monitors, OSDs and metadata servers.
|
||||||
|
Capabilities can also restrict access to data within a pool or pool namespace.
|
||||||
|
A Ceph administrative user sets a user's capabilities when creating or
|
||||||
|
updating a user. In secret we have user id and user key and in order to
|
||||||
|
perform certain actions, the user needs to have some specific capabilities.
|
||||||
|
Hence, those capabilities are documented below.
|
||||||
|
|
||||||
|
## RBD
|
||||||
|
|
||||||
|
We have provisioner, controller expand and node stage secrets in storage class.
|
||||||
|
For the provisioner and controller expand stage secret in storageclass, the
|
||||||
|
user needs to have the below mentioned ceph capabilities.
|
||||||
|
|
||||||
|
```text
|
||||||
|
"mon", "profile rbd",
|
||||||
|
"mgr", "allow rw",
|
||||||
|
"osd", "profile rbd"
|
||||||
|
```
|
||||||
|
|
||||||
|
And for the node stage secret in storageclass, the user needs to have the
|
||||||
|
below mentioned ceph capabilities.
|
||||||
|
|
||||||
|
```text
|
||||||
|
"mon", "profile rbd",
|
||||||
|
"osd", "profile rbd",
|
||||||
|
"mgr", "allow rw"
|
||||||
|
```
|
||||||
|
|
||||||
|
## CephFS
|
||||||
|
|
||||||
|
Similarly in CephFS, for the provisioner and controller expand stage secret in
|
||||||
|
storageclass, the user needs to have the below mentioned ceph capabilities.
|
||||||
|
|
||||||
|
```text
|
||||||
|
"mon", "allow r",
|
||||||
|
"mgr", "allow rw",
|
||||||
|
"osd", "allow rw tag cephfs metadata=*"
|
||||||
|
```
|
||||||
|
|
||||||
|
And for node stage secret in storageclass, the user needs to have
|
||||||
|
the below mentioned ceph capabilities.
|
||||||
|
|
||||||
|
```text
|
||||||
|
"mon", "allow r",
|
||||||
|
"mgr", "allow rw",
|
||||||
|
"osd", "allow rw tag cephfs *=*",
|
||||||
|
"mds", "allow rw"
|
||||||
|
```
|
||||||
|
|
||||||
|
To get more insights on capabilities of cephfs you can refer
|
||||||
|
[this document](https://ceph.readthedocs.io/en/latest/cephfs/client-auth/)
|
||||||
|
|
||||||
|
## Command to a create user with required capabilities
|
||||||
|
|
||||||
|
`kubernetes` in the below commands represents an user which is subjected
|
||||||
|
to change as per your requirement.
|
||||||
|
|
||||||
|
### create user for RBD
|
||||||
|
|
||||||
|
The command for provisioner and node stage secret for rbd will be same as
|
||||||
|
they have similiar capability requirements.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
ceph auth get-or-create client.kubernetes \
|
||||||
|
mon 'profile rbd' \
|
||||||
|
osd 'profile rbd' \
|
||||||
|
mgr 'allow rw'
|
||||||
|
```
|
||||||
|
|
||||||
|
### create user for CephFS
|
||||||
|
|
||||||
|
```bash
|
||||||
|
ceph auth get-or-create client.kubernetes \
|
||||||
|
mon 'allow r' \
|
||||||
|
osd 'allow rw tag cephfs metadata=*' \
|
||||||
|
mgr 'allow rw'
|
||||||
|
```
|
||||||
|
|
||||||
|
```bash
|
||||||
|
ceph auth get-or-create client.kubernetes \
|
||||||
|
mon 'allow r' \
|
||||||
|
osd 'allow rw tag cephfs *=*' \
|
||||||
|
mgr 'allow rw' \
|
||||||
|
mds 'allow rw'
|
||||||
|
```
|
Loading…
Reference in New Issue
Block a user