24 Distributed Lock Manager (DLM) #
The Distributed Lock Manager (DLM) in the kernel is the base component used by OCFS2, GFS2, Cluster MD, and Cluster LVM (lvmlockd) to provide active-active storage at each respective layer.
24.1 Protocols for DLM communication #
To avoid single points of failure, redundant communication paths are important for High Availability clusters. This is also true for DLM communication. If network bonding (Link Aggregation Control Protocol, LACP) cannot be used for any reason, we highly recommend defining a redundant communication channel (a second ring) in Corosync. For details, see Procedure 7.3, “Defining a redundant communication channel”.
   DLM communicates through port 21064 using either the TCP or SCTP protocol,
   depending on the configuration in /etc/corosync/corosync.conf:
  
- If is set to - none(which means redundant ring configuration is disabled), DLM automatically uses TCP. However, without a redundant communication channel, DLM communication fails if the TCP link is down.
- If is set to - passive(which is the typical setting), and a second communication ring in- /etc/corosync/corosync.confis configured correctly, DLM automatically uses SCTP. In this case, DLM messaging has the redundancy capability provided by SCTP.
24.2 Configuring DLM cluster resources #
DLM uses the cluster membership services from Pacemaker which run in user space. Therefore, DLM needs to be configured as a clone resource that is present on each node in the cluster.
As OCFS2, GFS2, Cluster MD, and Cluster LVM (lvmlockd) all use DLM, it is enough to configure one resource for DLM. As the DLM resource runs on all nodes in the cluster it is configured as a clone resource.
If you have a setup that includes both OCFS2 and Cluster LVM, configuring one DLM resource for both OCFS2 and Cluster LVM is enough. In this case, configure DLM using Procedure 24.1, “Configuring a base group for DLM”.
However, if you need to keep the resources that use DLM independent from one another (such as multiple OCFS2 mount points), use separate colocation and order constraints instead of a group. In this case, configure DLM using Procedure 24.2, “Configuring an independent DLM resource”.
This configuration consists of a base group that includes several primitives and a base clone. Both base group and base clone can be used in different scenarios afterward (for both OCFS2 and Cluster LVM, for example). You only need to extend the base group with the respective primitives as needed. As the base group has internal colocation and ordering, this simplifies the overall setup as you do not need to specify several individual groups, clones and their dependencies.
- Log in to a node as - rootor equivalent.
- Run - crm configure.
- Create the primitive resource for DLM: - crm(live)configure#- primitive dlm ocf:pacemaker:controld \ op monitor interval="60" timeout="60"
- Create a base group for the - dlmresource and further storage-related resources:- crm(live)configure#- group g-storage dlm
- Clone the - g-storagegroup so that it runs on all nodes:- crm(live)configure#- clone cl-storage g-storage \ meta interleave=true target-role=Started
- Review your changes with - show.
- If everything is correct, submit your changes with - commitand leave the crm live configuration with- quit.
    Clusters without STONITH are not supported. If you set the global cluster
    option stonith-enabled to false for
    testing or troubleshooting purposes, the DLM resource and all services
    depending on it (such as Cluster LVM, GFS2, and OCFS2) will fail to start.
   
This configuration consists of a primitive and a clone, but no group. By adding colocation and order constraints, you can avoid introducing dependencies between multiple resources that use DLM (such as multiple GFS2 mount points).
- Log in to a node as - rootor equivalent.
- Run - crm configure.
- Create the primitive resource for DLM: - crm(live)configure#- primitive dlm ocf:pacemaker:controld \ op start timeout=90 interval=0 \ op stop timeout=100 interval=0 \ op monitor interval=60 timeout=60
- Clone the - dlmresource so that it runs on all nodes:- crm(live)configure#- clone cl-dlm dlm meta interleave=true
- Review your changes with - show.
- If everything is correct, submit your changes with - commitand leave the crm live configuration with- quit.