Blame view

kernel/linux-imx6_3.14.28/Documentation/filesystems/dlmfs.txt 4.22 KB
6b13f685e   김민수   BSP 최초 추가
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
  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://oss.oracle.com/projects/ocfs2
  Tools web page:      http://oss.oracle.com/projects/ocfs2-tools
  OCFS2 mailing lists: http://oss.oracle.com/projects/ocfs2/mailman/
  
  All code copyright 2005 Oracle except when otherwise noted.
  
  CREDITS
  =======
  
  Some code taken from ramfs which is Copyright (C) 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.