141 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			141 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| .. SPDX-License-Identifier: GPL-2.0
 | |
| .. include:: <isonum.txt>
 | |
| 
 | |
| =====
 | |
| DLMFS
 | |
| =====
 | |
| 
 | |
| A minimal DLM userspace interface implemented via a virtual file
 | |
| system.
 | |
| 
 | |
| dlmfs is built with OCFS2 as it requires most of its infrastructure.
 | |
| 
 | |
| :Project web page:    http://ocfs2.wiki.kernel.org
 | |
| :Tools web page:      https://github.com/markfasheh/ocfs2-tools
 | |
| :OCFS2 mailing lists: https://oss.oracle.com/projects/ocfs2/mailman/
 | |
| 
 | |
| All code copyright 2005 Oracle except when otherwise noted.
 | |
| 
 | |
| Credits
 | |
| =======
 | |
| 
 | |
| Some code taken from ramfs which is Copyright |copy| 2000 Linus Torvalds
 | |
| and Transmeta Corp.
 | |
| 
 | |
| Mark Fasheh <mark.fasheh@oracle.com>
 | |
| 
 | |
| Caveats
 | |
| =======
 | |
| - Right now it only works with the OCFS2 DLM, though support for other
 | |
|   DLM implementations should not be a major issue.
 | |
| 
 | |
| Mount options
 | |
| =============
 | |
| None
 | |
| 
 | |
| Usage
 | |
| =====
 | |
| 
 | |
| If you're just interested in OCFS2, then please see ocfs2.txt. The
 | |
| rest of this document will be geared towards those who want to use
 | |
| dlmfs for easy to setup and easy to use clustered locking in
 | |
| userspace.
 | |
| 
 | |
| Setup
 | |
| =====
 | |
| 
 | |
| dlmfs requires that the OCFS2 cluster infrastructure be in
 | |
| place. Please download ocfs2-tools from the above url and configure a
 | |
| cluster.
 | |
| 
 | |
| You'll want to start heartbeating on a volume which all the nodes in
 | |
| your lockspace can access. The easiest way to do this is via
 | |
| ocfs2_hb_ctl (distributed with ocfs2-tools). Right now it requires
 | |
| that an OCFS2 file system be in place so that it can automatically
 | |
| find its heartbeat area, though it will eventually support heartbeat
 | |
| against raw disks.
 | |
| 
 | |
| Please see the ocfs2_hb_ctl and mkfs.ocfs2 manual pages distributed
 | |
| with ocfs2-tools.
 | |
| 
 | |
| Once you're heartbeating, DLM lock 'domains' can be easily created /
 | |
| destroyed and locks within them accessed.
 | |
| 
 | |
| Locking
 | |
| =======
 | |
| 
 | |
| Users may access dlmfs via standard file system calls, or they can use
 | |
| 'libo2dlm' (distributed with ocfs2-tools) which abstracts the file
 | |
| system calls and presents a more traditional locking api.
 | |
| 
 | |
| dlmfs handles lock caching automatically for the user, so a lock
 | |
| request for an already acquired lock will not generate another DLM
 | |
| call. Userspace programs are assumed to handle their own local
 | |
| locking.
 | |
| 
 | |
| Two levels of locks are supported - Shared Read, and Exclusive.
 | |
| Also supported is a Trylock operation.
 | |
| 
 | |
| For information on the libo2dlm interface, please see o2dlm.h,
 | |
| distributed with ocfs2-tools.
 | |
| 
 | |
| Lock value blocks can be read and written to a resource via read(2)
 | |
| and write(2) against the fd obtained via your open(2) call. The
 | |
| maximum currently supported LVB length is 64 bytes (though that is an
 | |
| OCFS2 DLM limitation). Through this mechanism, users of dlmfs can share
 | |
| small amounts of data amongst their nodes.
 | |
| 
 | |
| mkdir(2) signals dlmfs to join a domain (which will have the same name
 | |
| as the resulting directory)
 | |
| 
 | |
| rmdir(2) signals dlmfs to leave the domain
 | |
| 
 | |
| Locks for a given domain are represented by regular inodes inside the
 | |
| domain directory.  Locking against them is done via the open(2) system
 | |
| call.
 | |
| 
 | |
| The open(2) call will not return until your lock has been granted or
 | |
| an error has occurred, unless it has been instructed to do a trylock
 | |
| operation. If the lock succeeds, you'll get an fd.
 | |
| 
 | |
| open(2) with O_CREAT to ensure the resource inode is created - dlmfs does
 | |
| not automatically create inodes for existing lock resources.
 | |
| 
 | |
| ============  ===========================
 | |
| Open Flag     Lock Request Type
 | |
| ============  ===========================
 | |
| O_RDONLY      Shared Read
 | |
| O_RDWR        Exclusive
 | |
| ============  ===========================
 | |
| 
 | |
| 
 | |
| ============  ===========================
 | |
| Open Flag     Resulting Locking Behavior
 | |
| ============  ===========================
 | |
| O_NONBLOCK    Trylock operation
 | |
| ============  ===========================
 | |
| 
 | |
| You must provide exactly one of O_RDONLY or O_RDWR.
 | |
| 
 | |
| If O_NONBLOCK is also provided and the trylock operation was valid but
 | |
| could not lock the resource then open(2) will return ETXTBUSY.
 | |
| 
 | |
| close(2) drops the lock associated with your fd.
 | |
| 
 | |
| Modes passed to mkdir(2) or open(2) are adhered to locally. Chown is
 | |
| supported locally as well. This means you can use them to restrict
 | |
| access to the resources via dlmfs on your local node only.
 | |
| 
 | |
| The resource LVB may be read from the fd in either Shared Read or
 | |
| Exclusive modes via the read(2) system call. It can be written via
 | |
| write(2) only when open in Exclusive mode.
 | |
| 
 | |
| Once written, an LVB will be visible to other nodes who obtain Read
 | |
| Only or higher level locks on the resource.
 | |
| 
 | |
| See Also
 | |
| ========
 | |
| http://opendlm.sourceforge.net/cvsmirror/opendlm/docs/dlmbook_final.pdf
 | |
| 
 | |
| For more information on the VMS distributed locking API.
 |