823ec82238
Traditionally, Ganesha consumes /etc/idmapd.conf, which controls mapping of user/owner identities under NFSv4+. With containerized service deployment, this file has beenan immutable part of the container image and could not be modified. Recently ceph-ansible was modified to allow the user to set the path for idmapd.conf and to override ini settings in this file by supplying json configuration for the overrides in the same way that it can be supplied for ceph.conf overrides [1]. Also, the default path setting for the idmapd.conf file is /etc/ganesha/idmap.conf, which already is reflected into containerized ganesha under /etc/ganesha, solving the immutability issue. If no overrides are supplied, the file put in this location will match that originally frozen into the container, so there is no issue here with backwards compatibility. This change exposes parameters for idmap.conf file path and override contents in TripleO and passes them into ceph-ansible. It also sets up these parameters for cephadm. Cephadm support for OpenStack Ganesha is WIP so there will likely need to be a followup patch to make these effective when cephadm replaces ceph ansible. [1] https://github.com/ceph/ceph-ansible/pull/6422 Change-Id: I422e49f0027efbbb25256d8b4718eb0aa78d90a4 (cherry picked from commit9a42686dc7
) (cherry picked from commitb2a8641a5c
)
34 lines
1.8 KiB
YAML
34 lines
1.8 KiB
YAML
# A Heat environment file which can be used to enable a
|
|
# Manila CephFS-NFS driver backend.
|
|
resource_registry:
|
|
OS::TripleO::Services::ManilaApi: ../deployment/manila/manila-api-container-puppet.yaml
|
|
OS::TripleO::Services::ManilaScheduler: ../deployment/manila/manila-scheduler-container-puppet.yaml
|
|
# Only manila-share is pacemaker managed:
|
|
OS::TripleO::Services::ManilaShare: ../deployment/manila/manila-share-pacemaker-puppet.yaml
|
|
OS::TripleO::Services::ManilaBackendCephFs: ../deployment/manila/manila-backend-cephfs.yaml
|
|
# ceph-nfs (ganesha) service is installed and configured by ceph-ansible
|
|
# but it's still managed by pacemaker
|
|
OS::TripleO::Services::CephNfs: ../deployment/ceph-ansible/ceph-nfs.yaml
|
|
|
|
|
|
parameter_defaults:
|
|
ManilaCephFSBackendName: cephfs
|
|
ManilaCephFSDriverHandlesShareServers: false
|
|
ManilaCephFSCephFSEnableSnapshots: false
|
|
ManilaCephFSCephVolumeMode: '0755'
|
|
# manila cephfs driver supports either native cephfs backend - 'CEPHFS'
|
|
# (users mount shares directly from ceph cluster), or nfs-ganesha backend -
|
|
# 'NFS' (users mount shares through nfs-ganesha server)
|
|
ManilaCephFSCephFSProtocolHelperType: 'NFS'
|
|
# Use ManilaCephFSNFSIdmapConf to change the path of the idmap.conf file consumed by ganesha
|
|
ManilaCephFSNFSIdmapConf: '/etc/ganesha/idmap.conf'
|
|
# Use ManilaCephFSNFSIdmapOverrides to overide ini configuration in the idmap.conf file
|
|
ManilaCephFSNFSIdmapOverrides: {}
|
|
# Uncomment the following and set them appropriately if the Ceph cluster is
|
|
# external and you need to use a specific keyring/key and pool to access the
|
|
# CephFS share
|
|
#ManilaCephFSDataPoolName: manila_data
|
|
#ManilaCephFSMetadataPoolName: manila_metadata
|
|
#ManilaCephFSCephFSAuthId: 'manila'
|
|
#CephManilaClientKey: 'AQDLOh1VgEp6FRAAFzT7Zw+Y9V6JJExQAsRnRQ=='
|