2020-02-25 14:21:06 +00:00
|
|
|
=======================
|
|
|
|
CephFS Exports over NFS
|
|
|
|
=======================
|
|
|
|
|
|
|
|
CephFS namespaces can be exported over NFS protocol using the
|
|
|
|
`NFS-Ganesha NFS server <https://github.com/nfs-ganesha/nfs-ganesha/wiki>`_.
|
|
|
|
|
|
|
|
Requirements
|
|
|
|
============
|
|
|
|
|
2020-07-10 11:25:41 +00:00
|
|
|
- Latest Ceph file system with mgr enabled
|
|
|
|
- 'nfs-ganesha', 'nfs-ganesha-ceph', 'nfs-ganesha-rados-grace' and
|
|
|
|
'nfs-ganesha-rados-urls' packages (version 3.3 and above)
|
2020-02-25 14:21:06 +00:00
|
|
|
|
|
|
|
Create NFS Ganesha Cluster
|
|
|
|
==========================
|
|
|
|
|
|
|
|
.. code:: bash
|
|
|
|
|
2020-04-21 12:53:04 +00:00
|
|
|
$ ceph nfs cluster create <type=cephfs> <clusterid> [<placement>]
|
2020-02-25 14:21:06 +00:00
|
|
|
|
|
|
|
This creates a common recovery pool for all Ganesha daemons, new user based on
|
|
|
|
cluster_id and common ganesha config rados object.
|
|
|
|
|
2020-04-21 12:53:04 +00:00
|
|
|
Here type is export type and placement specifies the size of cluster and hosts.
|
|
|
|
For more details on placement specification refer the `orchestrator doc
|
|
|
|
<https://docs.ceph.com/docs/master/mgr/orchestrator/#placement-specification>`_.
|
|
|
|
Currently only CephFS export type is supported.
|
2020-02-25 14:21:06 +00:00
|
|
|
|
2020-04-23 13:40:48 +00:00
|
|
|
Update NFS Ganesha Cluster
|
|
|
|
==========================
|
|
|
|
|
|
|
|
.. code:: bash
|
|
|
|
|
|
|
|
$ ceph nfs cluster update <clusterid> <placement>
|
|
|
|
|
|
|
|
This updates the deployed cluster according to the placement value.
|
|
|
|
|
2020-04-23 15:46:16 +00:00
|
|
|
Delete NFS Ganesha Cluster
|
|
|
|
==========================
|
|
|
|
|
|
|
|
.. code:: bash
|
|
|
|
|
|
|
|
$ ceph nfs cluster delete <clusterid>
|
|
|
|
|
|
|
|
This deletes the deployed cluster.
|
|
|
|
|
2020-06-11 05:18:56 +00:00
|
|
|
List NFS Ganesha Cluster
|
|
|
|
========================
|
|
|
|
|
|
|
|
.. code:: bash
|
|
|
|
|
|
|
|
$ ceph nfs cluster ls
|
|
|
|
|
|
|
|
This lists deployed clusters.
|
|
|
|
|
2020-06-22 18:38:28 +00:00
|
|
|
Show NFS Ganesha Cluster Information
|
|
|
|
====================================
|
|
|
|
|
|
|
|
.. code:: bash
|
|
|
|
|
|
|
|
$ ceph nfs cluster info [<clusterid>]
|
|
|
|
|
|
|
|
This displays ip and port of deployed cluster.
|
|
|
|
|
2020-07-29 13:48:06 +00:00
|
|
|
Set Customized Ganesha Configuration
|
|
|
|
====================================
|
|
|
|
|
|
|
|
.. code:: bash
|
|
|
|
|
|
|
|
$ ceph nfs cluster config set <clusterid> -i <config_file>
|
|
|
|
|
|
|
|
With this the nfs cluster will use the specified config and it will have
|
|
|
|
precedence over default config blocks.
|
|
|
|
|
|
|
|
Reset Ganesha Configuration
|
|
|
|
===========================
|
|
|
|
|
|
|
|
.. code:: bash
|
|
|
|
|
|
|
|
$ ceph nfs cluster config reset <clusterid>
|
|
|
|
|
|
|
|
This removes the user defined configuration.
|
|
|
|
|
2020-02-25 14:21:06 +00:00
|
|
|
Create CephFS Export
|
|
|
|
====================
|
|
|
|
|
|
|
|
.. code:: bash
|
|
|
|
|
2020-05-15 17:56:13 +00:00
|
|
|
$ ceph nfs export create cephfs <fsname> <clusterid> <binding> [--readonly] [--path=/path/in/cephfs]
|
2020-02-25 14:21:06 +00:00
|
|
|
|
|
|
|
It creates export rados objects containing the export block. Here binding is
|
2020-05-15 17:56:13 +00:00
|
|
|
the pseudo root name and type is export type.
|
2020-02-25 14:21:06 +00:00
|
|
|
|
2020-04-28 16:27:20 +00:00
|
|
|
Delete CephFS Export
|
|
|
|
====================
|
|
|
|
|
|
|
|
.. code:: bash
|
|
|
|
|
2020-05-14 16:00:46 +00:00
|
|
|
$ ceph nfs export delete <clusterid> <binding>
|
2020-04-28 16:27:20 +00:00
|
|
|
|
|
|
|
It deletes an export in cluster based on pseudo root name (binding).
|
|
|
|
|
2020-06-16 10:29:19 +00:00
|
|
|
List CephFS Export
|
|
|
|
==================
|
|
|
|
|
|
|
|
.. code:: bash
|
|
|
|
|
|
|
|
$ ceph nfs export ls <clusterid> [--detailed]
|
|
|
|
|
|
|
|
It lists export for a cluster. With detailed option enabled it shows entire
|
|
|
|
export block.
|
|
|
|
|
|
|
|
Get CephFS Export
|
|
|
|
=================
|
|
|
|
|
|
|
|
.. code:: bash
|
|
|
|
|
|
|
|
$ ceph nfs export get <clusterid> <binding>
|
|
|
|
|
|
|
|
It displays export block for a cluster based on pseudo root name (binding).
|
|
|
|
|
2020-02-25 14:21:06 +00:00
|
|
|
Configuring NFS-Ganesha to export CephFS with vstart
|
|
|
|
====================================================
|
|
|
|
|
2020-07-16 11:36:11 +00:00
|
|
|
1) Using cephadm
|
|
|
|
|
|
|
|
.. code:: bash
|
|
|
|
|
|
|
|
$ MDS=1 MON=1 OSD=3 NFS=1 ../src/vstart.sh -n -d --cephadm
|
|
|
|
|
|
|
|
It can deploy only single ganesha daemon with vstart on default ganesha port.
|
|
|
|
|
|
|
|
2) Using test orchestrator
|
|
|
|
|
|
|
|
.. code:: bash
|
|
|
|
|
|
|
|
$ MDS=1 MON=1 OSD=3 NFS=1 ../src/vstart.sh -n -d
|
2020-02-25 14:21:06 +00:00
|
|
|
|
2020-07-16 11:36:11 +00:00
|
|
|
It can deploy multiple ganesha daemons on random port. But this requires
|
|
|
|
ganesha packages to be installed.
|
2020-02-25 14:21:06 +00:00
|
|
|
|
2020-07-16 11:36:11 +00:00
|
|
|
NFS: It is the number of NFS-Ganesha clusters to be created.
|
2020-02-25 14:21:06 +00:00
|
|
|
|
|
|
|
Mount
|
|
|
|
=====
|
|
|
|
|
|
|
|
After the exports are successfully created and Ganesha daemons are no longer in
|
|
|
|
grace period. The exports can be mounted by
|
|
|
|
|
|
|
|
.. code:: bash
|
|
|
|
|
|
|
|
$ mount -t nfs -o port=<ganesha-port> <ganesha-host-name>:<ganesha-pseudo-path> <mount-point>
|
|
|
|
|
|
|
|
.. note:: Only NFS v4.0+ is supported.
|