xref: /titanic_54/usr/src/man/man1m/zfs.1m (revision 9c3fd1216fa7fb02cfbc78a2518a686d54b48ab8)
189f5d17bSYuri Pankov.\"
289f5d17bSYuri Pankov.\" CDDL HEADER START
389f5d17bSYuri Pankov.\"
489f5d17bSYuri Pankov.\" The contents of this file are subject to the terms of the
589f5d17bSYuri Pankov.\" Common Development and Distribution License (the "License").
689f5d17bSYuri Pankov.\" You may not use this file except in compliance with the License.
789f5d17bSYuri Pankov.\"
889f5d17bSYuri Pankov.\" You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
989f5d17bSYuri Pankov.\" or http://www.opensolaris.org/os/licensing.
1089f5d17bSYuri Pankov.\" See the License for the specific language governing permissions
1189f5d17bSYuri Pankov.\" and limitations under the License.
1289f5d17bSYuri Pankov.\"
1389f5d17bSYuri Pankov.\" When distributing Covered Code, include this CDDL HEADER in each
1489f5d17bSYuri Pankov.\" file and include the License file at usr/src/OPENSOLARIS.LICENSE.
1589f5d17bSYuri Pankov.\" If applicable, add the following below this CDDL HEADER, with the
1689f5d17bSYuri Pankov.\" fields enclosed by brackets "[]" replaced with your own identifying
1789f5d17bSYuri Pankov.\" information: Portions Copyright [yyyy] [name of copyright owner]
1889f5d17bSYuri Pankov.\"
1989f5d17bSYuri Pankov.\" CDDL HEADER END
2089f5d17bSYuri Pankov.\"
2189f5d17bSYuri Pankov.\"
22c10c16deSRichard Lowe.\" Copyright (c) 2009 Sun Microsystems, Inc. All Rights Reserved.
236658b4ffSJoshua M. Clulow.\" Copyright 2011 Joshua M. Clulow <josh@sysmgr.org>
2430925561SChris Williamson.\" Copyright (c) 2011, 2014 by Delphix. All rights reserved.
25a6f561b4SSašo Kiselkov.\" Copyright (c) 2013 by Saso Kiselkov. All rights reserved.
26a2afb611SJerry Jelinek.\" Copyright (c) 2014, Joyent, Inc. All rights reserved.
27409f1c06SAdam Stevko.\" Copyright (c) 2014 by Adam Stevko. All rights reserved.
28b3cff10cSYuri Pankov.\" Copyright 2015 Nexenta Systems, Inc.  All Rights Reserved.
2989f5d17bSYuri Pankov.\"
30b3cff10cSYuri Pankov.Dd June 8, 2015
31b3cff10cSYuri Pankov.Dt ZFS 1M
32b3cff10cSYuri Pankov.Os
33b3cff10cSYuri Pankov.Sh NAME
34b3cff10cSYuri Pankov.Nm zfs
35b3cff10cSYuri Pankov.Nd configures ZFS file systems
36b3cff10cSYuri Pankov.Sh SYNOPSIS
37b3cff10cSYuri Pankov.Nm
38b3cff10cSYuri Pankov.Op Fl \?
39b3cff10cSYuri Pankov.Nm
40b3cff10cSYuri Pankov.Cm create
41b3cff10cSYuri Pankov.Op Fl p
42b3cff10cSYuri Pankov.Oo Fl o Ar property Ns = Ns Ar value Oc Ns ...
43b3cff10cSYuri Pankov.Ar filesystem
44b3cff10cSYuri Pankov.Nm
45b3cff10cSYuri Pankov.Cm create
46b3cff10cSYuri Pankov.Op Fl ps
47b3cff10cSYuri Pankov.Op Fl b Ar blocksize
48b3cff10cSYuri Pankov.Oo Fl o Ar property Ns = Ns Ar value Oc Ns ...
49b3cff10cSYuri Pankov.Fl V Ar size Ar volume
50b3cff10cSYuri Pankov.Nm
51b3cff10cSYuri Pankov.Cm destroy
52b3cff10cSYuri Pankov.Op Fl Rfnprv
53b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
54b3cff10cSYuri Pankov.Nm
55b3cff10cSYuri Pankov.Cm destroy
56b3cff10cSYuri Pankov.Op Fl Rdnprv
57b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume Ns @ Ns Ar snap Ns
58b3cff10cSYuri Pankov.Oo % Ns Ar snap Ns Oo , Ns Ar snap Ns Oo % Ns Ar snap Oc Oc Oc Ns ...
59b3cff10cSYuri Pankov.Nm
60b3cff10cSYuri Pankov.Cm destroy
61b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume Ns # Ns Ar bookmark
62b3cff10cSYuri Pankov.Nm
63b3cff10cSYuri Pankov.Cm snapshot
64b3cff10cSYuri Pankov.Op Fl r
65b3cff10cSYuri Pankov.Oo Fl o Ar property Ns = Ns value Oc Ns ...
66b3cff10cSYuri Pankov.Ar filesystem Ns @ Ns Ar snapname Ns | Ns Ar volume Ns @ Ns Ar snapname Ns ...
67b3cff10cSYuri Pankov.Nm
68b3cff10cSYuri Pankov.Cm rollback
69b3cff10cSYuri Pankov.Op Fl Rfr
70b3cff10cSYuri Pankov.Ar snapshot
71b3cff10cSYuri Pankov.Nm
72b3cff10cSYuri Pankov.Cm clone
73b3cff10cSYuri Pankov.Op Fl p
74b3cff10cSYuri Pankov.Oo Fl o Ar property Ns = Ns Ar value Oc Ns ...
75b3cff10cSYuri Pankov.Ar snapshot Ar filesystem Ns | Ns Ar volume
76b3cff10cSYuri Pankov.Nm
77b3cff10cSYuri Pankov.Cm promote
78b3cff10cSYuri Pankov.Ar clone-filesystem
79b3cff10cSYuri Pankov.Nm
80b3cff10cSYuri Pankov.Cm rename
81b3cff10cSYuri Pankov.Op Fl f
82b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume Ns | Ns Ar snapshot
83b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume Ns | Ns Ar snapshot
84b3cff10cSYuri Pankov.Nm
85b3cff10cSYuri Pankov.Cm rename
86b3cff10cSYuri Pankov.Op Fl fp
87b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
88b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
89b3cff10cSYuri Pankov.Nm
90b3cff10cSYuri Pankov.Cm rename
91b3cff10cSYuri Pankov.Fl r
92b3cff10cSYuri Pankov.Ar snapshot Ar snapshot
93b3cff10cSYuri Pankov.Nm
94b3cff10cSYuri Pankov.Cm list
95b3cff10cSYuri Pankov.Op Fl r Ns | Ns Fl d Ar depth
96b3cff10cSYuri Pankov.Op Fl Hp
97b3cff10cSYuri Pankov.Oo Fl o Ar property Ns Oo , Ns Ar property Oc Ns ... Oc
98b3cff10cSYuri Pankov.Oo Fl s Ar property Oc Ns ...
99b3cff10cSYuri Pankov.Oo Fl S Ar property Oc Ns ...
100b3cff10cSYuri Pankov.Oo Fl t Ar type Ns Oo , Ns Ar type Oc Ns ... Oc
101b3cff10cSYuri Pankov.Oo Ar filesystem Ns | Ns Ar volume Ns | Ns Ar snapshot Oc Ns ...
102b3cff10cSYuri Pankov.Nm
103b3cff10cSYuri Pankov.Cm set
104b3cff10cSYuri Pankov.Ar property Ns = Ns Ar value Oo Ar property Ns = Ns Ar value Oc Ns ...
105b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume Ns | Ns Ar snapshot Ns ...
106b3cff10cSYuri Pankov.Nm
107b3cff10cSYuri Pankov.Cm get
108b3cff10cSYuri Pankov.Op Fl r Ns | Ns Fl d Ar depth
109b3cff10cSYuri Pankov.Op Fl Hp
110b3cff10cSYuri Pankov.Oo Fl o Ar field Ns Oo , Ns Ar field Oc Ns ... Oc
111b3cff10cSYuri Pankov.Oo Fl s Ar source Ns Oo , Ns Ar source Oc Ns ... Oc
112b3cff10cSYuri Pankov.Oo Fl t Ar type Ns Oo , Ns Ar type Oc Ns ... Oc
113b3cff10cSYuri Pankov.Cm all | Ar property Ns Oo , Ns Ar property Oc Ns ...
114b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume Ns | Ns Ar snapshot Ns ...
115b3cff10cSYuri Pankov.Nm
116b3cff10cSYuri Pankov.Cm inherit
117b3cff10cSYuri Pankov.Op Fl rS
118b3cff10cSYuri Pankov.Ar property Ar filesystem Ns | Ns Ar volume Ns | Ns Ar snapshot Ns ...
119b3cff10cSYuri Pankov.Nm
120b3cff10cSYuri Pankov.Cm upgrade
121b3cff10cSYuri Pankov.Nm
122b3cff10cSYuri Pankov.Cm upgrade
123b3cff10cSYuri Pankov.Fl v
124b3cff10cSYuri Pankov.Nm
125b3cff10cSYuri Pankov.Cm upgrade
126b3cff10cSYuri Pankov.Op Fl r
127b3cff10cSYuri Pankov.Op Fl V Ar version
128b3cff10cSYuri Pankov.Fl a | Ar filesystem
129b3cff10cSYuri Pankov.Nm
130b3cff10cSYuri Pankov.Cm userspace
131b3cff10cSYuri Pankov.Op Fl Hinp
132b3cff10cSYuri Pankov.Oo Fl o Ar field Ns Oo , Ns Ar field Oc Ns ... Oc
133b3cff10cSYuri Pankov.Oo Fl s Ar field Oc Ns ...
134b3cff10cSYuri Pankov.Oo Fl S Ar field Oc Ns ...
135b3cff10cSYuri Pankov.Oo Fl t Ar type Ns Oo , Ns Ar type Oc Ns ... Oc
136b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar snapshot
137b3cff10cSYuri Pankov.Nm
138b3cff10cSYuri Pankov.Cm groupspace
139b3cff10cSYuri Pankov.Op Fl Hinp
140b3cff10cSYuri Pankov.Oo Fl o Ar field Ns Oo , Ns Ar field Oc Ns ... Oc
141b3cff10cSYuri Pankov.Oo Fl s Ar field Oc Ns ...
142b3cff10cSYuri Pankov.Oo Fl S Ar field Oc Ns ...
143b3cff10cSYuri Pankov.Oo Fl t Ar type Ns Oo , Ns Ar type Oc Ns ... Oc
144b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar snapshot
145b3cff10cSYuri Pankov.Nm
146b3cff10cSYuri Pankov.Cm mount
147b3cff10cSYuri Pankov.Nm
148b3cff10cSYuri Pankov.Cm mount
149b3cff10cSYuri Pankov.Op Fl Ov
150b3cff10cSYuri Pankov.Op Fl o Ar options
151b3cff10cSYuri Pankov.Fl a | Ar filesystem
152b3cff10cSYuri Pankov.Nm
153b3cff10cSYuri Pankov.Cm unmount
154b3cff10cSYuri Pankov.Op Fl f
155b3cff10cSYuri Pankov.Fl a | Ar filesystem Ns | Ns Ar mountpoint
156b3cff10cSYuri Pankov.Nm
157b3cff10cSYuri Pankov.Cm share
158b3cff10cSYuri Pankov.Fl a | Ar filesystem
159b3cff10cSYuri Pankov.Nm
160b3cff10cSYuri Pankov.Cm unshare
161b3cff10cSYuri Pankov.Fl a | Ar filesystem Ns | Ns Ar mountpoint
162b3cff10cSYuri Pankov.Nm
163b3cff10cSYuri Pankov.Cm bookmark
164b3cff10cSYuri Pankov.Ar snapshot bookmark
165b3cff10cSYuri Pankov.Nm
166b3cff10cSYuri Pankov.Cm send
167b3cff10cSYuri Pankov.Op Fl DLPRenpv
168b3cff10cSYuri Pankov.Op Oo Fl I Ns | Ns Fl i Oc Ar snapshot
169b3cff10cSYuri Pankov.Ar snapshot
170b3cff10cSYuri Pankov.Nm
171b3cff10cSYuri Pankov.Cm send
172b3cff10cSYuri Pankov.Op Fl Le
173b3cff10cSYuri Pankov.Op Fl i Ar snapshot Ns | Ns Ar bookmark
174b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume Ns | Ns Ar snapshot
175b3cff10cSYuri Pankov.Nm
176*9c3fd121SMatthew Ahrens.Cm send
177*9c3fd121SMatthew Ahrens.Op Fl Penv
178*9c3fd121SMatthew Ahrens.Fl t Ar receive_resume_token
179*9c3fd121SMatthew Ahrens.Nm
180b3cff10cSYuri Pankov.Cm receive
181*9c3fd121SMatthew Ahrens.Op Fl Fnsuv
182a2cdcdd2SPaul Dagnelie.Op Fl o Sy origin Ns = Ns Ar snapshot
183b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume Ns | Ns Ar snapshot
184b3cff10cSYuri Pankov.Nm
185b3cff10cSYuri Pankov.Cm receive
186*9c3fd121SMatthew Ahrens.Op Fl Fnsuv
187b3cff10cSYuri Pankov.Op Fl d Ns | Ns Fl e
188a2cdcdd2SPaul Dagnelie.Op Fl o Sy origin Ns = Ns Ar snapshot
189b3cff10cSYuri Pankov.Ar filesystem
190b3cff10cSYuri Pankov.Nm
191*9c3fd121SMatthew Ahrens.Cm receive
192*9c3fd121SMatthew Ahrens.Fl A
193*9c3fd121SMatthew Ahrens.Ar filesystem Ns | Ns Ar volume
194*9c3fd121SMatthew Ahrens.Nm
195b3cff10cSYuri Pankov.Cm allow
196b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
197b3cff10cSYuri Pankov.Nm
198b3cff10cSYuri Pankov.Cm allow
199b3cff10cSYuri Pankov.Op Fl dglu
200b3cff10cSYuri Pankov.Ar user Ns | Ns Ar group Ns Oo , Ns Ar user Ns | Ns Ar group Oc Ns ...
201b3cff10cSYuri Pankov.Ar perm Ns | Ns @ Ns Ar setname Ns Oo , Ns Ar perm Ns | Ns @ Ns
202b3cff10cSYuri Pankov.Ar setname Oc Ns ...
203b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
204b3cff10cSYuri Pankov.Nm
205b3cff10cSYuri Pankov.Cm allow
206b3cff10cSYuri Pankov.Op Fl dl
207b3cff10cSYuri Pankov.Fl e Ns | Ns Sy everyone
208b3cff10cSYuri Pankov.Ar perm Ns | Ns @ Ns Ar setname Ns Oo , Ns Ar perm Ns | Ns @ Ns
209b3cff10cSYuri Pankov.Ar setname Oc Ns ...
210b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
211b3cff10cSYuri Pankov.Nm
212b3cff10cSYuri Pankov.Cm allow
213b3cff10cSYuri Pankov.Fl c
214b3cff10cSYuri Pankov.Ar perm Ns | Ns @ Ns Ar setname Ns Oo , Ns Ar perm Ns | Ns @ Ns
215b3cff10cSYuri Pankov.Ar setname Oc Ns ...
216b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
217b3cff10cSYuri Pankov.Nm
218b3cff10cSYuri Pankov.Cm allow
219b3cff10cSYuri Pankov.Fl s No @ Ns Ar setname
220b3cff10cSYuri Pankov.Ar perm Ns | Ns @ Ns Ar setname Ns Oo , Ns Ar perm Ns | Ns @ Ns
221b3cff10cSYuri Pankov.Ar setname Oc Ns ...
222b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
223b3cff10cSYuri Pankov.Nm
224b3cff10cSYuri Pankov.Cm unallow
225b3cff10cSYuri Pankov.Op Fl dglru
226b3cff10cSYuri Pankov.Ar user Ns | Ns Ar group Ns Oo , Ns Ar user Ns | Ns Ar group Oc Ns ...
227b3cff10cSYuri Pankov.Oo Ar perm Ns | Ns @ Ns Ar setname Ns Oo , Ns Ar perm Ns | Ns @ Ns
228b3cff10cSYuri Pankov.Ar setname Oc Ns ... Oc
229b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
230b3cff10cSYuri Pankov.Nm
231b3cff10cSYuri Pankov.Cm unallow
232b3cff10cSYuri Pankov.Op Fl dlr
233b3cff10cSYuri Pankov.Fl e Ns | Ns Sy everyone
234b3cff10cSYuri Pankov.Oo Ar perm Ns | Ns @ Ns Ar setname Ns Oo , Ns Ar perm Ns | Ns @ Ns
235b3cff10cSYuri Pankov.Ar setname Oc Ns ... Oc
236b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
237b3cff10cSYuri Pankov.Nm
238b3cff10cSYuri Pankov.Cm unallow
239b3cff10cSYuri Pankov.Op Fl r
240b3cff10cSYuri Pankov.Fl c
241b3cff10cSYuri Pankov.Oo Ar perm Ns | Ns @ Ns Ar setname Ns Oo , Ns Ar perm Ns | Ns @ Ns
242b3cff10cSYuri Pankov.Ar setname Oc Ns ... Oc
243b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
244b3cff10cSYuri Pankov.Nm
245b3cff10cSYuri Pankov.Cm unallow
246b3cff10cSYuri Pankov.Op Fl r
247b3cff10cSYuri Pankov.Fl s @ Ns Ar setname
248b3cff10cSYuri Pankov.Oo Ar perm Ns | Ns @ Ns Ar setname Ns Oo , Ns Ar perm Ns | Ns @ Ns
249b3cff10cSYuri Pankov.Ar setname Oc Ns ... Oc
250b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
251b3cff10cSYuri Pankov.Nm
252b3cff10cSYuri Pankov.Cm hold
253b3cff10cSYuri Pankov.Op Fl r
254b3cff10cSYuri Pankov.Ar tag Ar snapshot Ns ...
255b3cff10cSYuri Pankov.Nm
256b3cff10cSYuri Pankov.Cm holds
257b3cff10cSYuri Pankov.Op Fl r
258b3cff10cSYuri Pankov.Ar snapshot Ns ...
259b3cff10cSYuri Pankov.Nm
260b3cff10cSYuri Pankov.Cm release
261b3cff10cSYuri Pankov.Op Fl r
262b3cff10cSYuri Pankov.Ar tag Ar snapshot Ns ...
263b3cff10cSYuri Pankov.Nm
264b3cff10cSYuri Pankov.Cm diff
265b3cff10cSYuri Pankov.Op Fl FHt
266b3cff10cSYuri Pankov.Ar snapshot Ar snapshot Ns | Ns Ar filesystem
267b3cff10cSYuri Pankov.Sh DESCRIPTION
268b3cff10cSYuri PankovThe
269b3cff10cSYuri Pankov.Nm
270b3cff10cSYuri Pankovcommand configures ZFS datasets within a ZFS storage pool, as described in
271b3cff10cSYuri Pankov.Xr zpool 1M .
272b3cff10cSYuri PankovA dataset is identified by a unique path within the ZFS namespace. For example:
273b3cff10cSYuri Pankov.Bd -literal
274c10c16deSRichard Lowepool/{filesystem,volume,snapshot}
275b3cff10cSYuri Pankov.Ed
276b3cff10cSYuri Pankov.Pp
277b3cff10cSYuri Pankovwhere the maximum length of a dataset name is
278b3cff10cSYuri Pankov.Dv MAXNAMELEN
279b3cff10cSYuri Pankov.Pq 256 bytes .
280b3cff10cSYuri Pankov.Pp
281c10c16deSRichard LoweA dataset can be one of the following:
282b3cff10cSYuri Pankov.Bl -tag -width "file system"
283b3cff10cSYuri Pankov.It Sy file system
284b3cff10cSYuri PankovA ZFS dataset of type
285b3cff10cSYuri Pankov.Sy filesystem
286b3cff10cSYuri Pankovcan be mounted within the standard system namespace and behaves like other file
287b3cff10cSYuri Pankovsystems. While ZFS file systems are designed to be POSIX compliant, known issues
288b3cff10cSYuri Pankovexist that prevent compliance in some cases. Applications that depend on
289b3cff10cSYuri Pankovstandards conformance might fail due to non-standard behavior when checking file
290b3cff10cSYuri Pankovsystem free space.
291b3cff10cSYuri Pankov.It Sy volume
292c10c16deSRichard LoweA logical volume exported as a raw or block device. This type of dataset should
293c10c16deSRichard Loweonly be used under special circumstances. File systems are typically used in
294c10c16deSRichard Lowemost environments.
295b3cff10cSYuri Pankov.It Sy snapshot
296c10c16deSRichard LoweA read-only version of a file system or volume at a given point in time. It is
297b3cff10cSYuri Pankovspecified as
298b3cff10cSYuri Pankov.Ar filesystem Ns @ Ns Ar name
299b3cff10cSYuri Pankovor
300b3cff10cSYuri Pankov.Ar volume Ns @ Ns Ar name .
301b3cff10cSYuri Pankov.El
302b3cff10cSYuri Pankov.Ss ZFS File System Hierarchy
303b3cff10cSYuri PankovA ZFS storage pool is a logical collection of devices that provide space for
304b3cff10cSYuri Pankovdatasets. A storage pool is also the root of the ZFS file system hierarchy.
305b3cff10cSYuri Pankov.Pp
306c10c16deSRichard LoweThe root of the pool can be accessed as a file system, such as mounting and
307c10c16deSRichard Loweunmounting, taking snapshots, and setting properties. The physical storage
308b3cff10cSYuri Pankovcharacteristics, however, are managed by the
309b3cff10cSYuri Pankov.Xr zpool 1M
310b3cff10cSYuri Pankovcommand.
311b3cff10cSYuri Pankov.Pp
312b3cff10cSYuri PankovSee
313b3cff10cSYuri Pankov.Xr zpool 1M
314b3cff10cSYuri Pankovfor more information on creating and administering pools.
315b3cff10cSYuri Pankov.Ss Snapshots
316c10c16deSRichard LoweA snapshot is a read-only copy of a file system or volume. Snapshots can be
317c10c16deSRichard Lowecreated extremely quickly, and initially consume no additional space within the
318c10c16deSRichard Lowepool. As data within the active dataset changes, the snapshot consumes more
319c10c16deSRichard Lowedata than would otherwise be shared with the active dataset.
320b3cff10cSYuri Pankov.Pp
321c10c16deSRichard LoweSnapshots can have arbitrary names. Snapshots of volumes can be cloned or
322c10c16deSRichard Lowerolled back, but cannot be accessed independently.
323b3cff10cSYuri Pankov.Pp
324b3cff10cSYuri PankovFile system snapshots can be accessed under the
325b3cff10cSYuri Pankov.Pa .zfs/snapshot
326b3cff10cSYuri Pankovdirectory in the root of the file system. Snapshots are automatically mounted on
327b3cff10cSYuri Pankovdemand and may be unmounted at regular intervals. The visibility of the
328b3cff10cSYuri Pankov.Pa .zfs
329b3cff10cSYuri Pankovdirectory can be controlled by the
330b3cff10cSYuri Pankovsnapdir
331b3cff10cSYuri Pankovproperty.
332b3cff10cSYuri Pankov.Ss Clones
333c10c16deSRichard LoweA clone is a writable volume or file system whose initial contents are the same
334b3cff10cSYuri Pankovas another dataset. As with snapshots, creating a clone is nearly instantaneous,
335b3cff10cSYuri Pankovand initially consumes no additional space.
336b3cff10cSYuri Pankov.Pp
337c10c16deSRichard LoweClones can only be created from a snapshot. When a snapshot is cloned, it
338c10c16deSRichard Lowecreates an implicit dependency between the parent and child. Even though the
339c10c16deSRichard Loweclone is created somewhere else in the dataset hierarchy, the original snapshot
340b3cff10cSYuri Pankovcannot be destroyed as long as a clone exists. The
341b3cff10cSYuri Pankov.Sy origin
342b3cff10cSYuri Pankovproperty exposes this dependency, and the
343b3cff10cSYuri Pankov.Cm destroy
344b3cff10cSYuri Pankovcommand lists any such dependencies, if they exist.
345b3cff10cSYuri Pankov.Pp
346c10c16deSRichard LoweThe clone parent-child dependency relationship can be reversed by using the
347b3cff10cSYuri Pankov.Cm promote
348b3cff10cSYuri Pankovsubcommand. This causes the
349b3cff10cSYuri Pankov.Qq origin
350b3cff10cSYuri Pankovfile system to become a clone of the specified file system, which makes it
351b3cff10cSYuri Pankovpossible to destroy the file system that the clone was created from.
352b3cff10cSYuri Pankov.Ss "Mount Points"
353b3cff10cSYuri PankovCreating a ZFS file system is a simple operation, so the number of file systems
354b3cff10cSYuri Pankovper system is likely to be numerous. To cope with this, ZFS automatically
355b3cff10cSYuri Pankovmanages mounting and unmounting file systems without the need to edit the
356b3cff10cSYuri Pankov.Pa /etc/vfstab
357b3cff10cSYuri Pankovfile. All automatically managed file systems are mounted by ZFS at boot time.
358b3cff10cSYuri Pankov.Pp
359b3cff10cSYuri PankovBy default, file systems are mounted under
360b3cff10cSYuri Pankov.Pa /path ,
361b3cff10cSYuri Pankovwhere
362b3cff10cSYuri Pankov.Ar path
363b3cff10cSYuri Pankovis the name of the file system in the ZFS namespace. Directories are created and
364b3cff10cSYuri Pankovdestroyed as needed.
365b3cff10cSYuri Pankov.Pp
366b3cff10cSYuri PankovA file system can also have a mount point set in the
367b3cff10cSYuri Pankov.Sy mountpoint
368b3cff10cSYuri Pankovproperty. This directory is created as needed, and ZFS automatically mounts the
369b3cff10cSYuri Pankovfile system when the
370b3cff10cSYuri Pankov.Nm zfs Cm mount Fl a
371b3cff10cSYuri Pankovcommand is invoked
372b3cff10cSYuri Pankov.Po without editing
373b3cff10cSYuri Pankov.Pa /etc/vfstab
374b3cff10cSYuri Pankov.Pc .
375b3cff10cSYuri PankovThe
376b3cff10cSYuri Pankov.Sy mountpoint
377b3cff10cSYuri Pankovproperty can be inherited, so if
378b3cff10cSYuri Pankov.Em pool/home
379b3cff10cSYuri Pankovhas a mount point of
380b3cff10cSYuri Pankov.Pa /export/stuff ,
381b3cff10cSYuri Pankovthen
382b3cff10cSYuri Pankov.Em pool/home/user
383b3cff10cSYuri Pankovautomatically inherits a mount point of
384b3cff10cSYuri Pankov.Pa /export/stuff/user .
385b3cff10cSYuri Pankov.Pp
386b3cff10cSYuri PankovA file system
387b3cff10cSYuri Pankov.Sy mountpoint
388b3cff10cSYuri Pankovproperty of
389b3cff10cSYuri Pankov.Sy none
390b3cff10cSYuri Pankovprevents the file system from being mounted.
391b3cff10cSYuri Pankov.Pp
392b3cff10cSYuri PankovIf needed, ZFS file systems can also be managed with traditional tools
393b3cff10cSYuri Pankov.Po
394b3cff10cSYuri Pankov.Nm mount ,
395b3cff10cSYuri Pankov.Nm umount ,
396b3cff10cSYuri Pankov.Pa /etc/vfstab
397b3cff10cSYuri Pankov.Pc .
398b3cff10cSYuri PankovIf a file system's mount point is set to
399b3cff10cSYuri Pankov.Sy legacy ,
400b3cff10cSYuri PankovZFS makes no attempt to manage the file system, and the administrator is
401b3cff10cSYuri Pankovresponsible for mounting and unmounting the file system.
402b3cff10cSYuri Pankov.Ss "Zones"
403b3cff10cSYuri PankovA ZFS file system can be added to a non-global zone by using the
404b3cff10cSYuri Pankov.Nm zonecfg Cm add Sy fs
405b3cff10cSYuri Pankovsubcommand. A ZFS file system that is added to a non-global zone must have its
406b3cff10cSYuri Pankov.Sy mountpoint
407b3cff10cSYuri Pankovproperty set to
408b3cff10cSYuri Pankov.Sy legacy .
409b3cff10cSYuri Pankov.Pp
410c10c16deSRichard LoweThe physical properties of an added file system are controlled by the global
411c10c16deSRichard Loweadministrator. However, the zone administrator can create, modify, or destroy
412b3cff10cSYuri Pankovfiles within the added file system, depending on how the file system is mounted.
413b3cff10cSYuri Pankov.Pp
414b3cff10cSYuri PankovA dataset can also be delegated to a non-global zone by using the
415b3cff10cSYuri Pankov.Nm zonecfg Cm add Sy dataset
416b3cff10cSYuri Pankovsubcommand. You cannot delegate a dataset to one zone and the children of the
417b3cff10cSYuri Pankovsame dataset to another zone. The zone administrator can change properties of
418b3cff10cSYuri Pankovthe dataset or any of its children. However, the
419b3cff10cSYuri Pankov.Sy quota ,
420b3cff10cSYuri Pankov.Sy filesystem_limit
421b3cff10cSYuri Pankovand
422b3cff10cSYuri Pankov.Sy snapshot_limit
423b3cff10cSYuri Pankovproperties of the delegated dataset can be modified only by the global
424b3cff10cSYuri Pankovadministrator.
425b3cff10cSYuri Pankov.Pp
426b3cff10cSYuri PankovA ZFS volume can be added as a device to a non-global zone by using the
427b3cff10cSYuri Pankov.Nm zonecfg Cm add Sy device
428b3cff10cSYuri Pankovsubcommand. However, its physical properties can be modified only by the global
429b3cff10cSYuri Pankovadministrator.
430b3cff10cSYuri Pankov.Pp
431b3cff10cSYuri PankovFor more information about
432b3cff10cSYuri Pankov.Nm zonecfg
433b3cff10cSYuri Pankovsyntax, see
434b3cff10cSYuri Pankov.Xr zonecfg 1M .
435b3cff10cSYuri Pankov.Pp
436b3cff10cSYuri PankovAfter a dataset is delegated to a non-global zone, the
437b3cff10cSYuri Pankov.Sy zoned
438b3cff10cSYuri Pankovproperty is automatically set. A zoned file system cannot be mounted in the
439b3cff10cSYuri Pankovglobal zone, since the zone administrator might have to set the mount point to
440b3cff10cSYuri Pankovan unacceptable value.
441b3cff10cSYuri Pankov.Pp
442b3cff10cSYuri PankovThe global administrator can forcibly clear the
443b3cff10cSYuri Pankov.Sy zoned
444b3cff10cSYuri Pankovproperty, though this should be done with extreme care. The global administrator
445b3cff10cSYuri Pankovshould verify that all the mount points are acceptable before clearing the
446b3cff10cSYuri Pankovproperty.
447b3cff10cSYuri Pankov.Ss Native Properties
448b3cff10cSYuri PankovProperties are divided into two types, native properties and user-defined
449b3cff10cSYuri Pankov.Po or
450b3cff10cSYuri Pankov.Qq user
451b3cff10cSYuri Pankov.Pc
452b3cff10cSYuri Pankovproperties. Native properties either export internal statistics or control ZFS
453b3cff10cSYuri Pankovbehavior. In addition, native properties are either editable or read-only. User
454b3cff10cSYuri Pankovproperties have no effect on ZFS behavior, but you can use them to annotate
455b3cff10cSYuri Pankovdatasets in a way that is meaningful in your environment. For more information
456b3cff10cSYuri Pankovabout user properties, see the
457b3cff10cSYuri Pankov.Sx User Properties
458b3cff10cSYuri Pankovsection, below.
459b3cff10cSYuri Pankov.Pp
460c10c16deSRichard LoweEvery dataset has a set of properties that export statistics about the dataset
461c10c16deSRichard Loweas well as control various behaviors. Properties are inherited from the parent
462c10c16deSRichard Loweunless overridden by the child. Some properties apply only to certain types of
463b3cff10cSYuri Pankovdatasets
464b3cff10cSYuri Pankov.Pq file systems, volumes, or snapshots .
465b3cff10cSYuri Pankov.Pp
466c10c16deSRichard LoweThe values of numeric properties can be specified using human-readable suffixes
467b3cff10cSYuri Pankov.Po for example,
468b3cff10cSYuri Pankov.Sy k ,
469b3cff10cSYuri Pankov.Sy KB ,
470b3cff10cSYuri Pankov.Sy M ,
471b3cff10cSYuri Pankov.Sy Gb ,
472b3cff10cSYuri Pankovand so forth, up to
473b3cff10cSYuri Pankov.Sy Z
474b3cff10cSYuri Pankovfor zettabyte
475b3cff10cSYuri Pankov.Pc .
476b3cff10cSYuri PankovThe following are all valid
477b3cff10cSYuri Pankov.Pq and equal
478b3cff10cSYuri Pankovspecifications:
479b3cff10cSYuri Pankov.Li 1536M, 1.5g, 1.50GB .
480b3cff10cSYuri Pankov.Pp
481c10c16deSRichard LoweThe values of non-numeric properties are case sensitive and must be lowercase,
482b3cff10cSYuri Pankovexcept for
483b3cff10cSYuri Pankov.Sy mountpoint ,
484b3cff10cSYuri Pankov.Sy sharenfs ,
485b3cff10cSYuri Pankovand
486b3cff10cSYuri Pankov.Sy sharesmb .
487b3cff10cSYuri Pankov.Pp
488c10c16deSRichard LoweThe following native properties consist of read-only statistics about the
489c10c16deSRichard Lowedataset. These properties can be neither set, nor inherited. Native properties
490c10c16deSRichard Loweapply to all dataset types unless otherwise noted.
491b3cff10cSYuri Pankov.Bl -tag -width "usedbyrefreservation"
492b3cff10cSYuri Pankov.It Sy available
493b3cff10cSYuri PankovThe amount of space available to the dataset and all its children, assuming that
494b3cff10cSYuri Pankovthere is no other activity in the pool. Because space is shared within a pool,
495b3cff10cSYuri Pankovavailability can be limited by any number of factors, including physical pool
496b3cff10cSYuri Pankovsize, quotas, reservations, or other datasets within the pool.
497b3cff10cSYuri Pankov.Pp
498c10c16deSRichard LoweThis property can also be referred to by its shortened column name,
499b3cff10cSYuri Pankov.Sy avail .
500b3cff10cSYuri Pankov.It Sy compressratio
501b3cff10cSYuri PankovFor non-snapshots, the compression ratio achieved for the
502b3cff10cSYuri Pankov.Sy used
503b3cff10cSYuri Pankovspace of this dataset, expressed as a multiplier. The
504b3cff10cSYuri Pankov.Sy used
505b3cff10cSYuri Pankovproperty includes descendant datasets, and, for clones, does not include the
506b3cff10cSYuri Pankovspace shared with the origin snapshot. For snapshots, the
507b3cff10cSYuri Pankov.Sy compressratio
508b3cff10cSYuri Pankovis the same as the
509b3cff10cSYuri Pankov.Sy refcompressratio
510b3cff10cSYuri Pankovproperty. Compression can be turned on by running:
511b3cff10cSYuri Pankov.Nm zfs Cm set Sy compression Ns = Ns Sy on Ar dataset .
512b3cff10cSYuri PankovThe default value is
513b3cff10cSYuri Pankov.Sy off .
514b3cff10cSYuri Pankov.It Sy creation
515c10c16deSRichard LoweThe time this dataset was created.
516b3cff10cSYuri Pankov.It Sy clones
517b3cff10cSYuri PankovFor snapshots, this property is a comma-separated list of filesystems or volumes
518b3cff10cSYuri Pankovwhich are clones of this snapshot. The clones'
519b3cff10cSYuri Pankov.Sy origin
520b3cff10cSYuri Pankovproperty is this snapshot. If the
521b3cff10cSYuri Pankov.Sy clones
522b3cff10cSYuri Pankovproperty is not empty, then this snapshot can not be destroyed
523b3cff10cSYuri Pankov.Po even with the
524b3cff10cSYuri Pankov.Fl r
525b3cff10cSYuri Pankovor
526b3cff10cSYuri Pankov.Fl f
527b3cff10cSYuri Pankovoptions
528b3cff10cSYuri Pankov.Pc .
529b3cff10cSYuri Pankov.It Sy defer_destroy
530b3cff10cSYuri PankovThis property is
531b3cff10cSYuri Pankov.Sy on
532b3cff10cSYuri Pankovif the snapshot has been marked for deferred destroy by using the
533b3cff10cSYuri Pankov.Nm zfs Cm destroy Fl d
534b3cff10cSYuri Pankovcommand. Otherwise, the property is
535b3cff10cSYuri Pankov.Sy off .
536b3cff10cSYuri Pankov.It Sy filesystem_count
537b3cff10cSYuri PankovThe total number of filesystems and volumes that exist under this location in
538b3cff10cSYuri Pankovthe dataset tree. This value is only available when a
539b3cff10cSYuri Pankov.Sy filesystem_limit
540b3cff10cSYuri Pankovhas been set somewhere in the tree under which the dataset resides.
541b3cff10cSYuri Pankov.It Sy logicalreferenced
542b3cff10cSYuri PankovThe amount of space that is
543b3cff10cSYuri Pankov.Qq logically
544b3cff10cSYuri Pankovaccessible by this dataset. See the
545b3cff10cSYuri Pankov.Sy referenced
546b3cff10cSYuri Pankovproperty. The logical space ignores the effect of the
547b3cff10cSYuri Pankov.Sy compression
548b3cff10cSYuri Pankovand
549b3cff10cSYuri Pankov.Sy copies
550b3cff10cSYuri Pankovproperties, giving a quantity closer to the amount of data that applications
551b3cff10cSYuri Pankovsee. However, it does include space consumed by metadata.
552b3cff10cSYuri Pankov.Pp
55377372cb0SMatthew AhrensThis property can also be referred to by its shortened column name,
554b3cff10cSYuri Pankov.Sy lrefer .
555b3cff10cSYuri Pankov.It Sy logicalused
556b3cff10cSYuri PankovThe amount of space that is
557b3cff10cSYuri Pankov.Qq logically
558b3cff10cSYuri Pankovconsumed by this dataset and all its descendents. See the
559b3cff10cSYuri Pankov.Sy used
560b3cff10cSYuri Pankovproperty. The logical space ignores the effect of the
561b3cff10cSYuri Pankov.Sy compression
562b3cff10cSYuri Pankovand
563b3cff10cSYuri Pankov.Sy copies
564b3cff10cSYuri Pankovproperties, giving a quantity closer to the amount of data that applications
565b3cff10cSYuri Pankovsee. However, it does include space consumed by metadata.
566b3cff10cSYuri Pankov.Pp
56777372cb0SMatthew AhrensThis property can also be referred to by its shortened column name,
568b3cff10cSYuri Pankov.Sy lused .
569b3cff10cSYuri Pankov.It Sy mounted
570c10c16deSRichard LoweFor file systems, indicates whether the file system is currently mounted. This
571b3cff10cSYuri Pankovproperty can be either
572b3cff10cSYuri Pankov.Sy yes
573b3cff10cSYuri Pankovor
574b3cff10cSYuri Pankov.Sy no .
575b3cff10cSYuri Pankov.It Sy origin
576c10c16deSRichard LoweFor cloned file systems or volumes, the snapshot from which the clone was
577b3cff10cSYuri Pankovcreated. See also the
578b3cff10cSYuri Pankov.Sy clones
579b3cff10cSYuri Pankovproperty.
580*9c3fd121SMatthew Ahrens.It Sy receive_resume_token
581*9c3fd121SMatthew AhrensFor filesystems or volumes which have saved partially-completed state from
582*9c3fd121SMatthew Ahrens.Sy zfs receive -s ,
583*9c3fd121SMatthew Ahrensthis opaque token can be provided to
584*9c3fd121SMatthew Ahrens.Sy zfs send -t
585*9c3fd121SMatthew Ahrensto resume and complete the
586*9c3fd121SMatthew Ahrens.Sy zfs receive .
587b3cff10cSYuri Pankov.It Sy referenced
588c10c16deSRichard LoweThe amount of data that is accessible by this dataset, which may or may not be
589c10c16deSRichard Loweshared with other datasets in the pool. When a snapshot or clone is created, it
590c10c16deSRichard Loweinitially references the same amount of space as the file system or snapshot it
591c10c16deSRichard Lowewas created from, since its contents are identical.
592b3cff10cSYuri Pankov.Pp
593c10c16deSRichard LoweThis property can also be referred to by its shortened column name,
594b3cff10cSYuri Pankov.Sy refer .
595b3cff10cSYuri Pankov.It Sy refcompressratio
596b3cff10cSYuri PankovThe compression ratio achieved for the
597b3cff10cSYuri Pankov.Sy referenced
598b3cff10cSYuri Pankovspace of this dataset, expressed as a multiplier. See also the
599b3cff10cSYuri Pankov.Sy compressratio
600187d6ac0SMatt Ahrensproperty.
601b3cff10cSYuri Pankov.It Sy snapshot_count
602b3cff10cSYuri PankovThe total number of snapshots that exist under this location in the dataset
603b3cff10cSYuri Pankovtree. This value is only available when a
604b3cff10cSYuri Pankov.Sy snapshot_limit
605b3cff10cSYuri Pankovhas been set somewhere in the tree under which the dataset resides.
606b3cff10cSYuri Pankov.It Sy type
607b3cff10cSYuri PankovThe type of dataset:
608b3cff10cSYuri Pankov.Sy filesystem ,
609b3cff10cSYuri Pankov.Sy volume ,
610b3cff10cSYuri Pankovor
611b3cff10cSYuri Pankov.Sy snapshot .
612b3cff10cSYuri Pankov.It Sy used
613c10c16deSRichard LoweThe amount of space consumed by this dataset and all its descendents. This is
614c10c16deSRichard Lowethe value that is checked against this dataset's quota and reservation. The
615c10c16deSRichard Lowespace used does not include this dataset's reservation, but does take into
616c10c16deSRichard Loweaccount the reservations of any descendent datasets. The amount of space that a
617c10c16deSRichard Lowedataset consumes from its parent, as well as the amount of space that are freed
618c10c16deSRichard Loweif this dataset is recursively destroyed, is the greater of its space used and
619c10c16deSRichard Loweits reservation.
620b3cff10cSYuri Pankov.Pp
621b3cff10cSYuri PankovWhen snapshots
622b3cff10cSYuri Pankov.Po see the
623b3cff10cSYuri Pankov.Sx Snapshots
624b3cff10cSYuri Pankovsection
625b3cff10cSYuri Pankov.Pc
626b3cff10cSYuri Pankovare created, their space is initially shared between the snapshot and
627b3cff10cSYuri Pankovthe file system, and possibly with previous snapshots. As the file system
628b3cff10cSYuri Pankovchanges, space that was previously shared becomes unique to the snapshot, and
629b3cff10cSYuri Pankovcounted in the snapshot's space used. Additionally, deleting snapshots can
630b3cff10cSYuri Pankovincrease the amount of space unique to
631b3cff10cSYuri Pankov.Pq and used by
632b3cff10cSYuri Pankovother snapshots.
633b3cff10cSYuri Pankov.Pp
634c10c16deSRichard LoweThe amount of space used, available, or referenced does not take into account
635c10c16deSRichard Lowepending changes. Pending changes are generally accounted for within a few
636b3cff10cSYuri Pankovseconds. Committing a change to a disk using
637b3cff10cSYuri Pankov.Xr fsync 3C
638b3cff10cSYuri Pankovor
639b3cff10cSYuri Pankov.Dv O_SYNC
640c10c16deSRichard Lowedoes not necessarily guarantee that the space usage information is updated
641c10c16deSRichard Loweimmediately.
642b3cff10cSYuri Pankov.It Sy usedby*
643b3cff10cSYuri PankovThe
644b3cff10cSYuri Pankov.Sy usedby*
645b3cff10cSYuri Pankovproperties decompose the
646b3cff10cSYuri Pankov.Sy used
647b3cff10cSYuri Pankovproperties into the various reasons that space is used. Specifically,
648b3cff10cSYuri Pankov.Sy used No =
649b3cff10cSYuri Pankov.Sy usedbychildren No +
650b3cff10cSYuri Pankov.Sy usedbydataset No +
651b3cff10cSYuri Pankov.Sy usedbyrefreservation No +
652b3cff10cSYuri Pankov.Sy usedbysnapshots .
653b3cff10cSYuri PankovThese properties are only available for datasets created on
654b3cff10cSYuri Pankov.Nm zpool
655b3cff10cSYuri Pankov.Qo version 13 Qc
656b3cff10cSYuri Pankovpools.
657b3cff10cSYuri Pankov.It Sy usedbychildren
658c10c16deSRichard LoweThe amount of space used by children of this dataset, which would be freed if
659c10c16deSRichard Loweall the dataset's children were destroyed.
660b3cff10cSYuri Pankov.It Sy usedbydataset
661c10c16deSRichard LoweThe amount of space used by this dataset itself, which would be freed if the
662b3cff10cSYuri Pankovdataset were destroyed
663b3cff10cSYuri Pankov.Po after first removing any
664b3cff10cSYuri Pankov.Sy refreservation
665b3cff10cSYuri Pankovand destroying any necessary snapshots or descendents
666b3cff10cSYuri Pankov.Pc .
667b3cff10cSYuri Pankov.It Sy usedbyrefreservation
668b3cff10cSYuri PankovThe amount of space used by a
669b3cff10cSYuri Pankov.Sy refreservation
670b3cff10cSYuri Pankovset on this dataset, which would be freed if the
671b3cff10cSYuri Pankov.Sy refreservation
672b3cff10cSYuri Pankovwas removed.
673b3cff10cSYuri Pankov.It Sy usedbysnapshots
674c10c16deSRichard LoweThe amount of space consumed by snapshots of this dataset. In particular, it is
675c10c16deSRichard Lowethe amount of space that would be freed if all of this dataset's snapshots were
676b3cff10cSYuri Pankovdestroyed. Note that this is not simply the sum of the snapshots'
677b3cff10cSYuri Pankov.Sy used
678c10c16deSRichard Loweproperties because space can be shared by multiple snapshots.
679b3cff10cSYuri Pankov.It Sy userused Ns @ Ns Em user
680c10c16deSRichard LoweThe amount of space consumed by the specified user in this dataset. Space is
681b3cff10cSYuri Pankovcharged to the owner of each file, as displayed by
682b3cff10cSYuri Pankov.Nm ls Fl l .
683b3cff10cSYuri PankovThe amount of space charged is displayed by
684b3cff10cSYuri Pankov.Nm du
685b3cff10cSYuri Pankovand
686b3cff10cSYuri Pankov.Nm ls Fl s .
687b3cff10cSYuri PankovSee the
688b3cff10cSYuri Pankov.Nm zfs Cm userspace
689b3cff10cSYuri Pankovsubcommand for more information.
690b3cff10cSYuri Pankov.Pp
691c10c16deSRichard LoweUnprivileged users can access only their own space usage. The root user, or a
692b3cff10cSYuri Pankovuser who has been granted the
693b3cff10cSYuri Pankov.Sy userused
694b3cff10cSYuri Pankovprivilege with
695b3cff10cSYuri Pankov.Nm zfs Cm allow ,
696c10c16deSRichard Lowecan access everyone's usage.
697b3cff10cSYuri Pankov.Pp
698b3cff10cSYuri PankovThe
699b3cff10cSYuri Pankov.Sy userused Ns @ Ns Em ...
700b3cff10cSYuri Pankovproperties are not displayed by
701b3cff10cSYuri Pankov.Nm zfs Cm get Sy all .
702b3cff10cSYuri PankovThe user's name must be appended after the @ symbol, using one of the following
703b3cff10cSYuri Pankovforms:
704b3cff10cSYuri Pankov.Bl -bullet -width ""
705b3cff10cSYuri Pankov.It
706b3cff10cSYuri Pankov.Em POSIX name
707b3cff10cSYuri Pankov.Po for example,
708b3cff10cSYuri Pankov.Sy joe
709b3cff10cSYuri Pankov.Pc
710b3cff10cSYuri Pankov.It
711b3cff10cSYuri Pankov.Em POSIX numeric ID
712b3cff10cSYuri Pankov.Po for example,
713b3cff10cSYuri Pankov.Sy 789
714b3cff10cSYuri Pankov.Pc
715b3cff10cSYuri Pankov.It
716b3cff10cSYuri Pankov.Em SID name
717b3cff10cSYuri Pankov.Po for example,
718b3cff10cSYuri Pankov.Sy joe.smith@mydomain
719b3cff10cSYuri Pankov.Pc
720b3cff10cSYuri Pankov.It
721b3cff10cSYuri Pankov.Em SID numeric ID
722b3cff10cSYuri Pankov.Po for example,
723b3cff10cSYuri Pankov.Sy S-1-123-456-789
724b3cff10cSYuri Pankov.Pc
725b3cff10cSYuri Pankov.El
726b3cff10cSYuri Pankov.It Sy userrefs
727c10c16deSRichard LoweThis property is set to the number of user holds on this snapshot. User holds
728b3cff10cSYuri Pankovare set by using the
729b3cff10cSYuri Pankov.Nm zfs Cm hold
730b3cff10cSYuri Pankovcommand.
731b3cff10cSYuri Pankov.It Sy groupused Ns @ Ns Em group
732c10c16deSRichard LoweThe amount of space consumed by the specified group in this dataset. Space is
733b3cff10cSYuri Pankovcharged to the group of each file, as displayed by
734b3cff10cSYuri Pankov.Nm ls Fl l .
735b3cff10cSYuri PankovSee the
736b3cff10cSYuri Pankov.Sy userused Ns @ Ns Em user
737b3cff10cSYuri Pankovproperty for more information.
738b3cff10cSYuri Pankov.Pp
739b3cff10cSYuri PankovUnprivileged users can only access their own groups' space usage. The root user,
740b3cff10cSYuri Pankovor a user who has been granted the
741b3cff10cSYuri Pankov.Sy groupused
742b3cff10cSYuri Pankovprivilege with
743b3cff10cSYuri Pankov.Nm zfs Cm allow ,
744b3cff10cSYuri Pankovcan access all groups' usage.
745b3cff10cSYuri Pankov.It Sy volblocksize Ns = Ns Em blocksize
746b3cff10cSYuri PankovFor volumes, specifies the block size of the volume. The
747b3cff10cSYuri Pankov.Sy blocksize
748b3cff10cSYuri Pankovcannot be changed once the volume has been written, so it should be set at
749b3cff10cSYuri Pankovvolume creation time. The default
750b3cff10cSYuri Pankov.Sy blocksize
751b3cff10cSYuri Pankovfor volumes is 8 Kbytes. Any power of 2 from 512 bytes to 128 Kbytes is valid.
752b3cff10cSYuri Pankov.Pp
753c10c16deSRichard LoweThis property can also be referred to by its shortened column name,
754b3cff10cSYuri Pankov.Sy volblock .
755b3cff10cSYuri Pankov.It Sy written
756b3cff10cSYuri PankovThe amount of
757b3cff10cSYuri Pankov.Sy referenced
758b3cff10cSYuri Pankovspace written to this dataset since the previous snapshot.
759b3cff10cSYuri Pankov.It Sy written Ns @ Ns Em snapshot
760b3cff10cSYuri PankovThe amount of
761b3cff10cSYuri Pankov.Sy referenced
762b3cff10cSYuri Pankovspace written to this dataset since the specified snapshot. This is the space
763b3cff10cSYuri Pankovthat is referenced by this dataset but was not referenced by the specified
764b3cff10cSYuri Pankovsnapshot.
765b3cff10cSYuri Pankov.Pp
766b3cff10cSYuri PankovThe
767b3cff10cSYuri Pankov.Em snapshot
768b3cff10cSYuri Pankovmay be specified as a short snapshot name
769b3cff10cSYuri Pankov.Po just the part after the
770b3cff10cSYuri Pankov.Sy @
771b3cff10cSYuri Pankov.Pc ,
772b3cff10cSYuri Pankovin which case it will be interpreted as a snapshot in the same filesystem as
773b3cff10cSYuri Pankovthis dataset. The
774b3cff10cSYuri Pankov.Em snapshot
775b3cff10cSYuri Pankovmay be a full snapshot name
776b3cff10cSYuri Pankov.No Po Em filesystem Ns @ Ns Em snapshot Pc ,
777b3cff10cSYuri Pankovwhich for clones may be a snapshot in the origin's filesystem
778b3cff10cSYuri Pankov.Pq or the origin of the origin's filesystem, etc.
779b3cff10cSYuri Pankov.El
780b3cff10cSYuri Pankov.Pp
781b3cff10cSYuri PankovThe following native properties can be used to change the behavior of a ZFS
782b3cff10cSYuri Pankovdataset.
783b3cff10cSYuri Pankov.Bl -tag -width ""
784b3cff10cSYuri Pankov.It Xo
785b3cff10cSYuri Pankov.Sy aclinherit Ns = Ns Sy discard Ns | Ns Sy noallow Ns | Ns
786b3cff10cSYuri Pankov.Sy restricted Ns | Ns Sy passthrough Ns | Ns Sy passthrough-x
787b3cff10cSYuri Pankov.Xc
788b3cff10cSYuri PankovControls how
789b3cff10cSYuri Pankov.Sy ACE Ns s
790b3cff10cSYuri Pankovare inherited when files and directories are created.
791b3cff10cSYuri Pankov.Bl -tag -width "passthrough-x"
792b3cff10cSYuri Pankov.It Sy discard
793b3cff10cSYuri Pankovdoes not inherit any
794b3cff10cSYuri Pankov.Sy ACE Ns s .
795b3cff10cSYuri Pankov.It Sy noallow
796b3cff10cSYuri Pankovonly inherits inheritable
797b3cff10cSYuri Pankov.Sy ACE Ns s
798b3cff10cSYuri Pankovthat specify
799b3cff10cSYuri Pankov.Qq deny
800b3cff10cSYuri Pankovpermissions.
801b3cff10cSYuri Pankov.It Sy restricted
802b3cff10cSYuri Pankovdefault, removes the
803b3cff10cSYuri Pankov.Sy write_acl
804b3cff10cSYuri Pankovand
805b3cff10cSYuri Pankov.Sy write_owner
806b3cff10cSYuri Pankovpermissions when the
807b3cff10cSYuri Pankov.Sy ACE
808b3cff10cSYuri Pankovis inherited.
809b3cff10cSYuri Pankov.It Sy passthrough
810b3cff10cSYuri Pankovinherits all inheritable
811b3cff10cSYuri Pankov.Sy ACE Ns s
812b3cff10cSYuri Pankovwithout any modifications.
813b3cff10cSYuri Pankov.It Sy passthrough-x
814b3cff10cSYuri Pankovsame meaning as
815b3cff10cSYuri Pankov.Sy passthrough ,
816b3cff10cSYuri Pankovexcept that the
817b3cff10cSYuri Pankov.Sy owner@ ,
818b3cff10cSYuri Pankov.Sy group@ ,
819b3cff10cSYuri Pankovand
820b3cff10cSYuri Pankov.Sy everyone@
821b3cff10cSYuri Pankov.Sy ACE Ns s
822b3cff10cSYuri Pankovinherit the execute permission only if the file creation mode also requests the
823b3cff10cSYuri Pankovexecute bit.
824b3cff10cSYuri Pankov.El
825b3cff10cSYuri Pankov.Pp
826b3cff10cSYuri PankovWhen the property value is set to
827b3cff10cSYuri Pankov.Sy passthrough ,
828b3cff10cSYuri Pankovfiles are created with a mode determined by the inheritable
829b3cff10cSYuri Pankov.Sy ACE Ns s .
830b3cff10cSYuri PankovIf no inheritable
831b3cff10cSYuri Pankov.Sy ACE Ns s
832c10c16deSRichard Loweexist that affect the mode, then the mode is set in accordance to the requested
833c10c16deSRichard Lowemode from the application.
834b3cff10cSYuri Pankov.It Xo
835b3cff10cSYuri Pankov.Sy aclmode Ns = Ns Sy discard Ns | Ns Sy groupmask Ns | Ns
836b3cff10cSYuri Pankov.Sy passthrough Ns | Ns Sy restricted
837b3cff10cSYuri Pankov.Xc
838b3cff10cSYuri PankovControls how an
839b3cff10cSYuri Pankov.Sy ACL
840b3cff10cSYuri Pankovis modified during
841b3cff10cSYuri Pankov.Xr chmod 2 .
842b3cff10cSYuri Pankov.Bl -tag -width "passthrough"
843b3cff10cSYuri Pankov.It Sy discard
844b3cff10cSYuri Pankovdefault, deletes all
845b3cff10cSYuri Pankov.Sy ACE Ns s
846b3cff10cSYuri Pankovthat do not represent the mode of the file.
847b3cff10cSYuri Pankov.It Sy groupmask
848b3cff10cSYuri Pankovreduces permissions granted in all
849b3cff10cSYuri Pankov.Sy ALLOW
850b3cff10cSYuri Pankoventries found in the
851b3cff10cSYuri Pankov.Sy ACL
852b3cff10cSYuri Pankovsuch that they are no greater than the group permissions specified by
853b3cff10cSYuri Pankov.Xr chmod 2 .
854b3cff10cSYuri Pankov.It Sy passthrough
855b3cff10cSYuri Pankovindicates that no changes are made to the
856b3cff10cSYuri Pankov.Sy ACL
857b3cff10cSYuri Pankovother than creating or updating the necessary
858b3cff10cSYuri Pankov.Sy ACE Ns s
859b3cff10cSYuri Pankovto represent the new mode of the file or directory.
860b3cff10cSYuri Pankov.It Sy restricted
861b3cff10cSYuri Pankovcauses the
862b3cff10cSYuri Pankov.Xr chmod 2
863b3cff10cSYuri Pankovoperation to return an error when used on any file or directory which has a
864b3cff10cSYuri Pankovnon-trivial
865b3cff10cSYuri Pankov.Sy ACE Ns s
866b3cff10cSYuri Pankovwhose entries can not be represented by a mode.
867b3cff10cSYuri Pankov.El
868b3cff10cSYuri Pankov.Pp
869b3cff10cSYuri Pankov.Xr chmod 2
870b3cff10cSYuri Pankovis required to change the set user ID, set group ID, or sticky bits on a file or
871b3cff10cSYuri Pankovdirectory, as they do not have equivalent
872b3cff10cSYuri Pankov.Sy ACE Ns s.
873b3cff10cSYuri PankovIn order to use
874b3cff10cSYuri Pankov.Xr chmod 2
875b3cff10cSYuri Pankovon a file or directory with a non-trivial
876b3cff10cSYuri Pankov.Sy ACL
877b3cff10cSYuri Pankovwhen
878b3cff10cSYuri Pankov.Sy aclmode
879b3cff10cSYuri Pankovis set to
880b3cff10cSYuri Pankov.Sy restricted ,
881b3cff10cSYuri Pankovyou must first remove all
882b3cff10cSYuri Pankov.Sy ACE Ns s
883b3cff10cSYuri Pankovwhich do not represent the current mode.
884b3cff10cSYuri Pankov.It Sy atime Ns = Ns Sy on Ns | Ns Sy off
885c10c16deSRichard LoweControls whether the access time for files is updated when they are read.
886c10c16deSRichard LoweTurning this property off avoids producing write traffic when reading files and
887c10c16deSRichard Lowecan result in significant performance gains, though it might confuse mailers
888b3cff10cSYuri Pankovand other similar utilities. The default value is
889b3cff10cSYuri Pankov.Sy on .
890b3cff10cSYuri Pankov.It Sy canmount Ns = Ns Sy on Ns | Ns Sy off Ns | Ns Sy noauto
891b3cff10cSYuri PankovIf this property is set to
892b3cff10cSYuri Pankov.Sy off ,
893b3cff10cSYuri Pankovthe file system cannot be mounted, and is ignored by
894b3cff10cSYuri Pankov.Nm zfs Cm mount Fl a .
895b3cff10cSYuri PankovSetting this property to
896b3cff10cSYuri Pankov.Sy off
897b3cff10cSYuri Pankovis similar to setting the
898b3cff10cSYuri Pankov.Sy mountpoint
899b3cff10cSYuri Pankovproperty to
900b3cff10cSYuri Pankov.Sy none ,
901b3cff10cSYuri Pankovexcept that the dataset still has a normal
902b3cff10cSYuri Pankov.Sy mountpoint
903b3cff10cSYuri Pankovproperty, which can be inherited. Setting this property to
904b3cff10cSYuri Pankov.Sy off
905b3cff10cSYuri Pankovallows datasets to be used solely as a mechanism to inherit properties. One
906b3cff10cSYuri Pankovexample of setting
907b3cff10cSYuri Pankov.Sy canmount Ns = Ns Sy off
908b3cff10cSYuri Pankovis to have two datasets with the same
909b3cff10cSYuri Pankov.Sy mountpoint ,
910b3cff10cSYuri Pankovso that the children of both datasets appear in the same directory, but might
911b3cff10cSYuri Pankovhave different inherited characteristics.
912b3cff10cSYuri Pankov.Pp
913b3cff10cSYuri PankovWhen set to
914b3cff10cSYuri Pankov.Sy noauto ,
915b3cff10cSYuri Pankova dataset can only be mounted and unmounted explicitly. The dataset is not
916b3cff10cSYuri Pankovmounted automatically when the dataset is created or imported, nor is it mounted
917b3cff10cSYuri Pankovby the
918b3cff10cSYuri Pankov.Nm zfs Cm mount Fl a
919b3cff10cSYuri Pankovcommand or unmounted by the
920b3cff10cSYuri Pankov.Nm zfs Cm unmount Fl a
921b3cff10cSYuri Pankovcommand.
922b3cff10cSYuri Pankov.Pp
923c10c16deSRichard LoweThis property is not inherited.
924b3cff10cSYuri Pankov.It Xo
925b3cff10cSYuri Pankov.Sy checksum Ns = Ns Sy on Ns | Ns Sy off Ns | Ns Sy fletcher2 Ns | Ns
92645818ee1SMatthew Ahrens.Sy fletcher4 Ns | Ns Sy sha256 Ns | Ns Sy noparity Ns | Ns
92745818ee1SMatthew Ahrens.Sy sha512 Ns | Ns Sy skein Ns | Ns Sy edonr
928b3cff10cSYuri Pankov.Xc
929c10c16deSRichard LoweControls the checksum used to verify data integrity. The default value is
930b3cff10cSYuri Pankov.Sy on ,
931b3cff10cSYuri Pankovwhich automatically selects an appropriate algorithm
932b3cff10cSYuri Pankov.Po currently,
933b3cff10cSYuri Pankov.Sy fletcher4 ,
934b3cff10cSYuri Pankovbut this may change in future releases
935b3cff10cSYuri Pankov.Pc .
936b3cff10cSYuri PankovThe value
937b3cff10cSYuri Pankov.Sy off
938b3cff10cSYuri Pankovdisables integrity checking on user data. The value
939b3cff10cSYuri Pankov.Sy noparity
940b3cff10cSYuri Pankovnot only disables integrity but also disables maintaining parity for user data.
941b3cff10cSYuri PankovThis setting is used internally by a dump device residing on a RAID-Z pool and
942b3cff10cSYuri Pankovshould not be used by any other dataset. Disabling checksums is
943b3cff10cSYuri Pankov.Sy NOT
944b3cff10cSYuri Pankova recommended practice.
945b3cff10cSYuri Pankov.Pp
94645818ee1SMatthew AhrensThe
94745818ee1SMatthew Ahrens.Sy sha512 ,
94845818ee1SMatthew Ahrens.Sy skein ,
94945818ee1SMatthew Ahrensand
95045818ee1SMatthew Ahrens.Sy edonr
95145818ee1SMatthew Ahrenschecksum algorithms require enabling the appropriate features on the
95245818ee1SMatthew Ahrenspool. Please see
95345818ee1SMatthew Ahrens.Xr zpool-features 5
95445818ee1SMatthew Ahrensfor more information on these algorithms.
95545818ee1SMatthew Ahrens.Pp
956c10c16deSRichard LoweChanging this property affects only newly-written data.
957b3cff10cSYuri Pankov.It Xo
958b3cff10cSYuri Pankov.Sy compression Ns = Ns Sy on Ns | Ns Sy off Ns | Ns Sy gzip Ns | Ns
959b3cff10cSYuri Pankov.Sy gzip- Ns Em N Ns | Ns Sy lz4 Ns | Ns Sy lzjb Ns | Ns Sy zle
960b3cff10cSYuri Pankov.Xc
961db1741f5SJustin T. GibbsControls the compression algorithm used for this dataset.
962b3cff10cSYuri Pankov.Pp
963b3cff10cSYuri PankovSetting compression to
964b3cff10cSYuri Pankov.Sy on
965b3cff10cSYuri Pankovindicates that the current default compression algorithm should be used. The
966b3cff10cSYuri Pankovdefault balances compression and decompression speed, with compression ratio and
967b3cff10cSYuri Pankovis expected to work well on a wide variety of workloads.  Unlike all other
968b3cff10cSYuri Pankovsettings for this property,
969b3cff10cSYuri Pankov.Sy on
970b3cff10cSYuri Pankovdoes not select a fixed compression type. As new compression algorithms are
971b3cff10cSYuri Pankovadded to ZFS and enabled on a pool, the default compression algorithm may
972b3cff10cSYuri Pankovchange. The current default compression algorthm is either
973b3cff10cSYuri Pankov.Sy lzjb
974b3cff10cSYuri Pankovor, if the
975b3cff10cSYuri Pankov.Sy lz4_compress
976b3cff10cSYuri Pankovfeature is enabled,
977b3cff10cSYuri Pankov.Sy lz4 .
978b3cff10cSYuri Pankov.Pp
979b3cff10cSYuri PankovThe
980b3cff10cSYuri Pankov.Sy lz4
981b3cff10cSYuri Pankovcompression algorithm is a high-performance replacement for the
982b3cff10cSYuri Pankov.Sy lzjb
983b3cff10cSYuri Pankovalgorithm. It features significantly faster compression and decompression, as
984b3cff10cSYuri Pankovwell as a moderately higher compression ratio than
985b3cff10cSYuri Pankov.Sy lzjb ,
986b3cff10cSYuri Pankovbut can only be used on pools with the
987b3cff10cSYuri Pankov.Sy lz4_compress
988b3cff10cSYuri Pankovfeature set to
989b3cff10cSYuri Pankov.Sy enabled .
990b3cff10cSYuri PankovSee
991b3cff10cSYuri Pankov.Xr zpool-features 5
992b3cff10cSYuri Pankovfor details on ZFS feature flags and the
993b3cff10cSYuri Pankov.Sy lz4_compress
994b3cff10cSYuri Pankovfeature.
995b3cff10cSYuri Pankov.Pp
996b3cff10cSYuri PankovThe
997b3cff10cSYuri Pankov.Sy lzjb
998b3cff10cSYuri Pankovcompression algorithm is optimized for performance while providing decent data
999b3cff10cSYuri Pankovcompression.
1000b3cff10cSYuri Pankov.Pp
1001b3cff10cSYuri PankovThe
1002b3cff10cSYuri Pankov.Sy gzip
1003b3cff10cSYuri Pankovcompression algorithm uses the same compression as the
1004b3cff10cSYuri Pankov.Xr gzip 1
1005b3cff10cSYuri Pankovcommand. You can specify the
1006b3cff10cSYuri Pankov.Sy gzip
1007b3cff10cSYuri Pankovlevel by using the value
1008b3cff10cSYuri Pankov.Sy gzip- Ns Em N ,
1009b3cff10cSYuri Pankovwhere
1010b3cff10cSYuri Pankov.Em N
1011b3cff10cSYuri Pankovis an integer from 1
1012b3cff10cSYuri Pankov.Pq fastest
1013b3cff10cSYuri Pankovto 9
1014b3cff10cSYuri Pankov.Pq best compression ratio .
1015b3cff10cSYuri PankovCurrently,
1016b3cff10cSYuri Pankov.Sy gzip
1017b3cff10cSYuri Pankovis equivalent to
1018b3cff10cSYuri Pankov.Sy gzip-6
1019b3cff10cSYuri Pankov.Po which is also the default for
1020b3cff10cSYuri Pankov.Xr gzip 1
1021b3cff10cSYuri Pankov.Pc .
1022b3cff10cSYuri Pankov.Pp
1023b3cff10cSYuri PankovThe
1024b3cff10cSYuri Pankov.Sy zle
1025b3cff10cSYuri Pankovcompression algorithm compresses runs of zeros.
1026b3cff10cSYuri Pankov.Pp
1027c10c16deSRichard LoweThis property can also be referred to by its shortened column name
1028c10c16deSRichard Lowe\fBcompress\fR. Changing this property affects only newly-written data.
1029b3cff10cSYuri Pankov.It Sy copies Ns = Ns Sy 1 Ns | Ns Sy 2 Ns | Ns Sy 3
1030c10c16deSRichard LoweControls the number of copies of data stored for this dataset. These copies are
1031c10c16deSRichard Lowein addition to any redundancy provided by the pool, for example, mirroring or
1032c10c16deSRichard LoweRAID-Z. The copies are stored on different disks, if possible. The space used
1033c10c16deSRichard Loweby multiple copies is charged to the associated file and dataset, changing the
1034b3cff10cSYuri Pankov.Sy used
1035b3cff10cSYuri Pankovproperty and counting against quotas and reservations.
1036b3cff10cSYuri Pankov.Pp
1037c10c16deSRichard LoweChanging this property only affects newly-written data. Therefore, set this
1038b3cff10cSYuri Pankovproperty at file system creation time by using the
1039b3cff10cSYuri Pankov.Fl o Sy copies Ns = Ns Ar N
1040b3cff10cSYuri Pankovoption.
1041b3cff10cSYuri Pankov.It Sy devices Ns = Ns Sy on Ns | Ns Sy off
1042c10c16deSRichard LoweControls whether device nodes can be opened on this file system. The default
1043b3cff10cSYuri Pankovvalue is
1044b3cff10cSYuri Pankov.Sy on .
1045b3cff10cSYuri Pankov.It Sy exec Ns = Ns Sy on Ns | Ns Sy off
1046c10c16deSRichard LoweControls whether processes can be executed from within this file system. The
1047b3cff10cSYuri Pankovdefault value is
1048b3cff10cSYuri Pankov.Sy on .
1049b3cff10cSYuri Pankov.It Sy filesystem_limit Ns = Ns Em count Ns | Ns Sy none
1050a2afb611SJerry JelinekLimits the number of filesystems and volumes that can exist under this point in
1051a2afb611SJerry Jelinekthe dataset tree. The limit is not enforced if the user is allowed to change
1052b3cff10cSYuri Pankovthe limit. Setting a
1053b3cff10cSYuri Pankov.Sy filesystem_limit
1054b3cff10cSYuri Pankovto
1055b3cff10cSYuri Pankov.Sy on
1056b3cff10cSYuri Pankova descendent of a filesystem that already has a
1057b3cff10cSYuri Pankov.Sy filesystem_limit
1058b3cff10cSYuri Pankovdoes not override the ancestor's
1059b3cff10cSYuri Pankov.Sy filesystem_limit ,
1060a2afb611SJerry Jelinekbut rather imposes an additional limit. This feature must be enabled to be used
1061b3cff10cSYuri Pankov.Po see
1062b3cff10cSYuri Pankov.Xr zpool-features 5
1063b3cff10cSYuri Pankov.Pc .
1064b3cff10cSYuri Pankov.It Sy mountpoint Ns = Ns Pa path Ns | Ns Sy none Ns | Ns Sy legacy
1065b3cff10cSYuri PankovControls the mount point used for this file system. See the
1066b3cff10cSYuri Pankov.Sx Mount Points
1067c10c16deSRichard Lowesection for more information on how this property is used.
1068b3cff10cSYuri Pankov.Pp
1069b3cff10cSYuri PankovWhen the
1070b3cff10cSYuri Pankov.Sy mountpoint
1071b3cff10cSYuri Pankovproperty is changed for a file system, the file system and any children that
1072b3cff10cSYuri Pankovinherit the mount point are unmounted. If the new value is
1073b3cff10cSYuri Pankov.Sy legacy ,
1074b3cff10cSYuri Pankovthen they remain unmounted. Otherwise, they are automatically remounted in the
1075b3cff10cSYuri Pankovnew location if the property was previously
1076b3cff10cSYuri Pankov.Sy legacy
1077b3cff10cSYuri Pankovor
1078b3cff10cSYuri Pankov.Sy none ,
1079b3cff10cSYuri Pankovor if they were mounted before the property was changed. In addition, any shared
1080b3cff10cSYuri Pankovfile systems are unshared and shared in the new location.
1081b3cff10cSYuri Pankov.It Sy nbmand Ns = Ns Sy on Ns | Ns Sy off
1082b3cff10cSYuri PankovControls whether the file system should be mounted with
1083b3cff10cSYuri Pankov.Sy nbmand
1084b3cff10cSYuri Pankov.Pq Non Blocking mandatory locks .
1085b3cff10cSYuri PankovThis is used for SMB clients. Changes to this property only take effect when the
1086b3cff10cSYuri Pankovfile system is umounted and remounted. See
1087b3cff10cSYuri Pankov.Xr mount 1M
1088b3cff10cSYuri Pankovfor more information on
1089b3cff10cSYuri Pankov.Sy nbmand
1090b3cff10cSYuri Pankovmounts.
1091b3cff10cSYuri Pankov.It Sy primarycache Ns = Ns Sy all Ns | Ns Sy none Ns | Ns Sy metadata
1092b3cff10cSYuri PankovControls what is cached in the primary cache
1093b3cff10cSYuri Pankov.Pq ARC .
1094b3cff10cSYuri PankovIf this property is set to
1095b3cff10cSYuri Pankov.Sy all ,
1096b3cff10cSYuri Pankovthen both user data and metadata is cached. If this property is set to
1097b3cff10cSYuri Pankov.Sy none ,
1098b3cff10cSYuri Pankovthen neither user data nor metadata is cached. If this property is set to
1099b3cff10cSYuri Pankov.Sy metadata ,
1100b3cff10cSYuri Pankovthen only metadata is cached. The default value is
1101b3cff10cSYuri Pankov.Sy all .
1102b3cff10cSYuri Pankov.It Sy quota Ns = Ns Em size Ns | Ns Sy none
1103c10c16deSRichard LoweLimits the amount of space a dataset and its descendents can consume. This
1104c10c16deSRichard Loweproperty enforces a hard limit on the amount of space used. This includes all
1105c10c16deSRichard Lowespace consumed by descendents, including file systems and snapshots. Setting a
1106c10c16deSRichard Lowequota on a descendent of a dataset that already has a quota does not override
1107c10c16deSRichard Lowethe ancestor's quota, but rather imposes an additional limit.
1108b3cff10cSYuri Pankov.Pp
1109b3cff10cSYuri PankovQuotas cannot be set on volumes, as the
1110b3cff10cSYuri Pankov.Sy volsize
1111b3cff10cSYuri Pankovproperty acts as an implicit quota.
1112b3cff10cSYuri Pankov.It Sy snapshot_limit Ns = Ns Em count Ns | Ns Sy none
1113a2afb611SJerry JelinekLimits the number of snapshots that can be created on a dataset and its
1114b3cff10cSYuri Pankovdescendents. Setting a
1115b3cff10cSYuri Pankov.Sy snapshot_limit
1116b3cff10cSYuri Pankovon a descendent of a dataset that already has a
1117b3cff10cSYuri Pankov.Sy snapshot_limit
1118b3cff10cSYuri Pankovdoes not override the ancestor's
1119b3cff10cSYuri Pankov.Sy snapshot_limit ,
1120b3cff10cSYuri Pankovbut rather imposes an additional limit. The limit is not enforced if the user is
1121a2afb611SJerry Jelinekallowed to change the limit. For example, this means that recursive snapshots
1122a2afb611SJerry Jelinektaken from the global zone are counted against each delegated dataset within
1123b3cff10cSYuri Pankova zone. This feature must be enabled to be used
1124b3cff10cSYuri Pankov.Po see
1125b3cff10cSYuri Pankov.Xr zpool-features 5
1126b3cff10cSYuri Pankov.Pc .
1127b3cff10cSYuri Pankov.It Sy userquota@ Ns Em user Ns = Ns Em size Ns | Ns Sy none
1128c10c16deSRichard LoweLimits the amount of space consumed by the specified user. User space
1129b3cff10cSYuri Pankovconsumption is identified by the
1130b3cff10cSYuri Pankov.Sy userspace@ Ns Em user
1131b3cff10cSYuri Pankovproperty.
1132b3cff10cSYuri Pankov.Pp
1133c10c16deSRichard LoweEnforcement of user quotas may be delayed by several seconds. This delay means
1134c10c16deSRichard Lowethat a user might exceed their quota before the system notices that they are
1135b3cff10cSYuri Pankovover quota and begins to refuse additional writes with the
1136b3cff10cSYuri Pankov.Er EDQUOT
1137b3cff10cSYuri Pankoverror message. See the
1138b3cff10cSYuri Pankov.Nm zfs Cm userspace
1139b3cff10cSYuri Pankovsubcommand for more information.
1140b3cff10cSYuri Pankov.Pp
1141c10c16deSRichard LoweUnprivileged users can only access their own groups' space usage. The root
1142b3cff10cSYuri Pankovuser, or a user who has been granted the
1143b3cff10cSYuri Pankov.Sy userquota
1144b3cff10cSYuri Pankovprivilege with
1145b3cff10cSYuri Pankov.Nm zfs Cm allow ,
1146b3cff10cSYuri Pankovcan get and set everyone's quota.
1147b3cff10cSYuri Pankov.Pp
1148c10c16deSRichard LoweThis property is not available on volumes, on file systems before version 4, or
1149b3cff10cSYuri Pankovon pools before version 15. The
1150b3cff10cSYuri Pankov.Sy userquota@ Ns Em ...
1151b3cff10cSYuri Pankovproperties are not displayed by
1152b3cff10cSYuri Pankov.Nm zfs Cm get Sy all .
1153b3cff10cSYuri PankovThe user's name must be appended after the
1154b3cff10cSYuri Pankov.Sy @
1155b3cff10cSYuri Pankovsymbol, using one of the following forms:
1156b3cff10cSYuri Pankov.Bl -bullet
1157b3cff10cSYuri Pankov.It
1158b3cff10cSYuri Pankov.Em POSIX name
1159b3cff10cSYuri Pankov.Po for example,
1160b3cff10cSYuri Pankov.Sy joe
1161b3cff10cSYuri Pankov.Pc
1162b3cff10cSYuri Pankov.It
1163b3cff10cSYuri Pankov.Em POSIX numeric ID
1164b3cff10cSYuri Pankov.Po for example,
1165b3cff10cSYuri Pankov.Sy 789
1166b3cff10cSYuri Pankov.Pc
1167b3cff10cSYuri Pankov.It
1168b3cff10cSYuri Pankov.Em SID name
1169b3cff10cSYuri Pankov.Po for example,
1170b3cff10cSYuri Pankov.Sy joe.smith@mydomain
1171b3cff10cSYuri Pankov.Pc
1172b3cff10cSYuri Pankov.It
1173b3cff10cSYuri Pankov.Em SID numeric ID
1174b3cff10cSYuri Pankov.Po for example,
1175b3cff10cSYuri Pankov.Sy S-1-123-456-789
1176b3cff10cSYuri Pankov.Pc
1177b3cff10cSYuri Pankov.El
1178b3cff10cSYuri Pankov.It Sy groupquota@ Ns Em group Ns = Ns Em size Ns | Ns Sy none
1179c10c16deSRichard LoweLimits the amount of space consumed by the specified group. Group space
1180b3cff10cSYuri Pankovconsumption is identified by the
1181b3cff10cSYuri Pankov.Sy groupused@ Ns Em group
1182b3cff10cSYuri Pankovproperty.
1183b3cff10cSYuri Pankov.Pp
1184c10c16deSRichard LoweUnprivileged users can access only their own groups' space usage. The root
1185b3cff10cSYuri Pankovuser, or a user who has been granted the
1186b3cff10cSYuri Pankov.Sy groupquota
1187b3cff10cSYuri Pankovprivilege with
1188b3cff10cSYuri Pankov.Nm zfs Cm allow ,
1189b3cff10cSYuri Pankovcan get and set all groups' quotas.
1190b3cff10cSYuri Pankov.It Sy readonly Ns = Ns Sy on Ns | Ns Sy off
1191b3cff10cSYuri PankovControls whether this dataset can be modified. The default value is
1192b3cff10cSYuri Pankov.Sy off .
1193b3cff10cSYuri Pankov.Pp
1194c10c16deSRichard LoweThis property can also be referred to by its shortened column name,
1195b3cff10cSYuri Pankov.Sy rdonly .
1196b3cff10cSYuri Pankov.It Sy recordsize Ns = Ns Em size
1197c10c16deSRichard LoweSpecifies a suggested block size for files in the file system. This property is
1198c10c16deSRichard Lowedesigned solely for use with database workloads that access files in fixed-size
1199b3cff10cSYuri Pankovrecords. ZFS automatically tunes block sizes according to internal algorithms
1200b3cff10cSYuri Pankovoptimized for typical access patterns.
1201b3cff10cSYuri Pankov.Pp
1202c10c16deSRichard LoweFor databases that create very large files but access them in small random
1203b3cff10cSYuri Pankovchunks, these algorithms may be suboptimal. Specifying a
1204b3cff10cSYuri Pankov.Sy recordsize
1205c10c16deSRichard Lowegreater than or equal to the record size of the database can result in
1206c10c16deSRichard Lowesignificant performance gains. Use of this property for general purpose file
1207c10c16deSRichard Lowesystems is strongly discouraged, and may adversely affect performance.
1208b3cff10cSYuri Pankov.Pp
1209c10c16deSRichard LoweThe size specified must be a power of two greater than or equal to 512 and less
1210b3cff10cSYuri Pankovthan or equal to 128 Kbytes. If the
1211b3cff10cSYuri Pankov.Sy large_blocks
1212b3cff10cSYuri Pankovfeature is enabled on the pool, the size may be up to 1 Mbyte. See
1213b3cff10cSYuri Pankov.Xr zpool-features 5
1214b5152584SMatthew Ahrensfor details on ZFS feature flags.
1215b3cff10cSYuri Pankov.Pp
1216b3cff10cSYuri PankovChanging the file system's
1217b3cff10cSYuri Pankov.Sy recordsize
1218b3cff10cSYuri Pankovaffects only files created afterward; existing files are unaffected.
1219b3cff10cSYuri Pankov.Pp
1220c10c16deSRichard LoweThis property can also be referred to by its shortened column name,
1221b3cff10cSYuri Pankov.Sy recsize .
1222b3cff10cSYuri Pankov.It Sy redundant_metadata Ns = Ns Sy all Ns | Ns Sy most
1223b3cff10cSYuri PankovControls what types of metadata are stored redundantly. ZFS stores an extra copy
1224b3cff10cSYuri Pankovof metadata, so that if a single block is corrupted, the amount of user data
1225b3cff10cSYuri Pankovlost is limited. This extra copy is in addition to any redundancy provided at
1226b3cff10cSYuri Pankovthe pool level
1227b3cff10cSYuri Pankov.Pq e.g. by mirroring or RAID-Z ,
1228b3cff10cSYuri Pankovand is in addition to an extra copy specified by the
1229b3cff10cSYuri Pankov.Sy copies
1230b3cff10cSYuri Pankovproperty
1231b3cff10cSYuri Pankov.Pq up to a total of 3 copies .
1232b3cff10cSYuri PankovFor example if the pool is mirrored,
1233b3cff10cSYuri Pankov.Sy copies Ns = Ns 2 ,
1234b3cff10cSYuri Pankovand
1235b3cff10cSYuri Pankov.Sy redundant_metadata Ns = Ns Sy most ,
1236b3cff10cSYuri Pankovthen ZFS stores 6 copies of most metadata, and 4 copies of data and some
1237edf345e6SMatthew Ahrensmetadata.
1238b3cff10cSYuri Pankov.Pp
1239b3cff10cSYuri PankovWhen set to
1240b3cff10cSYuri Pankov.Sy all ,
1241b3cff10cSYuri PankovZFS stores an extra copy of all metadata. If a single on-disk block is corrupt,
1242b3cff10cSYuri Pankovat worst a single block of user data
1243b3cff10cSYuri Pankov.Po which is
1244b3cff10cSYuri Pankov.Sy recordsize
1245b3cff10cSYuri Pankovbytes long
1246b3cff10cSYuri Pankov.Pc
1247b3cff10cSYuri Pankovcan be lost.
1248b3cff10cSYuri Pankov.Pp
1249b3cff10cSYuri PankovWhen set to
1250b3cff10cSYuri Pankov.Sy most ,
1251b3cff10cSYuri PankovZFS stores an extra copy of most types of metadata. This can improve performance
1252b3cff10cSYuri Pankovof random writes, because less metadata must be written. In practice, at worst
1253b3cff10cSYuri Pankovabout 100 blocks
1254b3cff10cSYuri Pankov.Po of
1255b3cff10cSYuri Pankov.Sy recordsize
1256b3cff10cSYuri Pankovbytes each
1257b3cff10cSYuri Pankov.Pc
1258b3cff10cSYuri Pankovof user data can be lost if a single on-disk block is corrupt. The exact
1259b3cff10cSYuri Pankovbehavior of which metadata blocks are stored redundantly may change in future
1260b3cff10cSYuri Pankovreleases.
1261b3cff10cSYuri Pankov.Pp
1262b3cff10cSYuri PankovThe default value is
1263b3cff10cSYuri Pankov.Sy all .
1264b3cff10cSYuri Pankov.It Sy refquota Ns = Ns Em size Ns | Ns Sy none
1265c10c16deSRichard LoweLimits the amount of space a dataset can consume. This property enforces a hard
1266c10c16deSRichard Lowelimit on the amount of space used. This hard limit does not include space used
1267c10c16deSRichard Loweby descendents, including file systems and snapshots.
1268b3cff10cSYuri Pankov.It Sy refreservation Ns = Ns Em size Ns | Ns Sy none
1269c10c16deSRichard LoweThe minimum amount of space guaranteed to a dataset, not including its
1270c10c16deSRichard Lowedescendents. When the amount of space used is below this value, the dataset is
1271c10c16deSRichard Lowetreated as if it were taking up the amount of space specified by
1272b3cff10cSYuri Pankov.Sy refreservation .
1273b3cff10cSYuri PankovThe
1274b3cff10cSYuri Pankov.Sy refreservation
1275b3cff10cSYuri Pankovreservation is accounted for in the parent datasets' space used, and counts
1276b3cff10cSYuri Pankovagainst the parent datasets' quotas and reservations.
1277b3cff10cSYuri Pankov.Pp
1278b3cff10cSYuri PankovIf
1279b3cff10cSYuri Pankov.Sy refreservation
1280b3cff10cSYuri Pankovis set, a snapshot is only allowed if there is enough free pool space outside of
1281b3cff10cSYuri Pankovthis reservation to accommodate the current number of
1282b3cff10cSYuri Pankov.Qq referenced
1283b3cff10cSYuri Pankovbytes in the dataset.
1284b3cff10cSYuri Pankov.Pp
1285c10c16deSRichard LoweThis property can also be referred to by its shortened column name,
1286b3cff10cSYuri Pankov.Sy refreserv .
1287b3cff10cSYuri Pankov.It Sy reservation Ns = Ns Em size Ns | Ns Sy none
1288c10c16deSRichard LoweThe minimum amount of space guaranteed to a dataset and its descendents. When
1289c10c16deSRichard Lowethe amount of space used is below this value, the dataset is treated as if it
1290c10c16deSRichard Lowewere taking up the amount of space specified by its reservation. Reservations
1291c10c16deSRichard Loweare accounted for in the parent datasets' space used, and count against the
1292c10c16deSRichard Loweparent datasets' quotas and reservations.
1293b3cff10cSYuri Pankov.Pp
1294c10c16deSRichard LoweThis property can also be referred to by its shortened column name,
1295b3cff10cSYuri Pankov.Sy reserv .
1296b3cff10cSYuri Pankov.It Sy secondarycache Ns = Ns Sy all Ns | Ns Sy none Ns | Ns Sy metadata
1297b3cff10cSYuri PankovControls what is cached in the secondary cache
1298b3cff10cSYuri Pankov.Pq L2ARC .
1299b3cff10cSYuri PankovIf this property is set to
1300b3cff10cSYuri Pankov.Sy all ,
1301b3cff10cSYuri Pankovthen both user data and metadata is cached. If this property is set to
1302b3cff10cSYuri Pankov.Sy none ,
1303b3cff10cSYuri Pankovthen neither user data nor metadata is cached. If this property is set to
1304b3cff10cSYuri Pankov.Sy metadata ,
1305b3cff10cSYuri Pankovthen only metadata is cached. The default value is
1306b3cff10cSYuri Pankov.Sy all .
1307b3cff10cSYuri Pankov.It Sy setuid Ns = Ns Sy on Ns | Ns Sy off
1308b3cff10cSYuri PankovControls whether the setuid bit is respected for the file system. The default
1309b3cff10cSYuri Pankovvalue is
1310b3cff10cSYuri Pankov.Sy on .
1311b3cff10cSYuri Pankov.It Sy sharesmb Ns = Ns Sy on Ns | Ns Sy off Ns | Ns Em opts
1312b3cff10cSYuri PankovControls whether the file system is shared via SMB, and what options are to be
1313b3cff10cSYuri Pankovused. A file system with the
1314b3cff10cSYuri Pankov.Sy sharesmb
1315b3cff10cSYuri Pankovproperty set to
1316b3cff10cSYuri Pankov.Sy off
1317b3cff10cSYuri Pankovis managed through traditional tools such as
1318b3cff10cSYuri Pankov.Xr sharemgr 1M .
1319b3cff10cSYuri PankovOtherwise, the file system is automatically shared and unshared with the
1320b3cff10cSYuri Pankov.Nm zfs Cm share
1321b3cff10cSYuri Pankovand
1322b3cff10cSYuri Pankov.Nm zfs Cm unshare
1323b3cff10cSYuri Pankovcommands. If the property is set to
1324b3cff10cSYuri Pankov.Sy on ,
1325b3cff10cSYuri Pankovthe
1326b3cff10cSYuri Pankov.Xr sharemgr 1M
1327b3cff10cSYuri Pankovcommand is invoked with no options. Otherwise, the
1328b3cff10cSYuri Pankov.Xr sharemgr 1M
1329b3cff10cSYuri Pankovcommand is invoked with options equivalent to the contents of this property.
1330b3cff10cSYuri Pankov.Pp
1331b3cff10cSYuri PankovBecause SMB shares requires a resource name, a unique resource name is
1332b3cff10cSYuri Pankovconstructed from the dataset name. The constructed name is a copy of the dataset
1333b3cff10cSYuri Pankovname except that the characters in the dataset name, which would be illegal in
1334b3cff10cSYuri Pankovthe resource name, are replaced with underscore
1335b3cff10cSYuri Pankov.Pq Sy _
1336b3cff10cSYuri Pankovcharacters. A pseudo property
1337b3cff10cSYuri Pankov.Qq name
1338b3cff10cSYuri Pankovis also supported that allows you to replace the data set name with a specified
1339b3cff10cSYuri Pankovname. The specified name is then used to replace the prefix dataset in the case
1340b3cff10cSYuri Pankovof inheritance. For example, if the dataset
1341b3cff10cSYuri Pankov.Em data/home/john
1342b3cff10cSYuri Pankovis set to
1343b3cff10cSYuri Pankov.Sy name Ns = Ns Sy john ,
1344b3cff10cSYuri Pankovthen
1345b3cff10cSYuri Pankov.Em data/home/john
1346b3cff10cSYuri Pankovhas a resource name of
1347b3cff10cSYuri Pankov.Sy john .
1348b3cff10cSYuri PankovIf a child dataset
1349b3cff10cSYuri Pankov.Em data/home/john/backups
1350b3cff10cSYuri Pankovis shared, it has a resource name of
1351b3cff10cSYuri Pankov.Sy john_backups .
1352b3cff10cSYuri Pankov.Pp
1353c10c16deSRichard LoweWhen SMB shares are created, the SMB share name appears as an entry in the
1354b3cff10cSYuri Pankov.Pa .zfs/shares
1355b3cff10cSYuri Pankovdirectory. You can use the
1356b3cff10cSYuri Pankov.Nm ls
1357b3cff10cSYuri Pankovor
1358b3cff10cSYuri Pankov.Nm chmod
1359b3cff10cSYuri Pankovcommand to display the share-level ACLs on the entries in this directory.
1360b3cff10cSYuri Pankov.Pp
1361b3cff10cSYuri PankovWhen the
1362b3cff10cSYuri Pankov.Sy sharesmb
1363b3cff10cSYuri Pankovproperty is changed for a dataset, the dataset and any children inheriting the
1364b3cff10cSYuri Pankovproperty are re-shared with the new options, only if the property was previously
1365b3cff10cSYuri Pankovset to
1366b3cff10cSYuri Pankov.Sy off ,
1367b3cff10cSYuri Pankovor if they were shared before the property was changed. If the new property is
1368b3cff10cSYuri Pankovset to
1369b3cff10cSYuri Pankov.Sy off ,
1370b3cff10cSYuri Pankovthe file systems are unshared.
1371b3cff10cSYuri Pankov.It Sy sharenfs Ns = Ns Sy on Ns | Ns Sy off Ns | Ns Em opts
1372b3cff10cSYuri PankovControls whether the file system is shared via NFS, and what options are to be
1373b3cff10cSYuri Pankovused. A file system with a
1374b3cff10cSYuri Pankov.Sy sharenfs
1375b3cff10cSYuri Pankovproperty of
1376b3cff10cSYuri Pankov.Sy off
1377b3cff10cSYuri Pankovis managed through traditional tools such as
1378b3cff10cSYuri Pankov.Xr share 1M ,
1379b3cff10cSYuri Pankov.Xr unshare 1M ,
1380b3cff10cSYuri Pankovand
1381b3cff10cSYuri Pankov.Xr dfstab 4 .
1382b3cff10cSYuri PankovOtherwise, the file system is automatically shared and unshared with the
1383b3cff10cSYuri Pankov.Nm zfs Cm share
1384b3cff10cSYuri Pankovand
1385b3cff10cSYuri Pankov.Nm zfs Cm unshare
1386b3cff10cSYuri Pankovcommands. If the property is set to
1387b3cff10cSYuri Pankov.Sy on ,
1388b3cff10cSYuri Pankov.Xr share 1M
1389b3cff10cSYuri Pankovcommand is invoked with no options. Otherwise, the
1390b3cff10cSYuri Pankov.Xr share 1M
1391b3cff10cSYuri Pankovcommand is invoked with options equivalent to the contents of this property.
1392b3cff10cSYuri Pankov.Pp
1393b3cff10cSYuri PankovWhen the
1394b3cff10cSYuri Pankov.Sy sharenfs
1395b3cff10cSYuri Pankovproperty is changed for a dataset, the dataset and any children inheriting the
1396b3cff10cSYuri Pankovproperty are re-shared with the new options, only if the property was previously
1397b3cff10cSYuri Pankov.Sy off ,
1398b3cff10cSYuri Pankovor if they were shared before the property was changed. If the new property is
1399b3cff10cSYuri Pankov.Sy off ,
1400b3cff10cSYuri Pankovthe file systems are unshared.
1401b3cff10cSYuri Pankov.It Sy logbias Ns = Ns Sy latency Ns | Ns Sy throughput
1402b3cff10cSYuri PankovProvide a hint to ZFS about handling of synchronous requests in this dataset. If
1403b3cff10cSYuri Pankov.Sy logbias
1404b3cff10cSYuri Pankovis set to
1405b3cff10cSYuri Pankov.Sy latency
1406b3cff10cSYuri Pankov.Pq the default ,
1407b3cff10cSYuri PankovZFS will use pool log devices
1408b3cff10cSYuri Pankov.Pq if configured
1409b3cff10cSYuri Pankovto handle the requests at low latency. If
1410b3cff10cSYuri Pankov.Sy logbias
1411b3cff10cSYuri Pankovis set to
1412b3cff10cSYuri Pankov.Sy throughput ,
1413b3cff10cSYuri PankovZFS will not use configured pool log devices. ZFS will instead optimize
1414b3cff10cSYuri Pankovsynchronous operations for global pool throughput and efficient use of
1415b3cff10cSYuri Pankovresources.
1416b3cff10cSYuri Pankov.It Sy snapdir Ns = Ns Sy hidden Ns | Ns Sy visible
1417b3cff10cSYuri PankovControls whether the
1418b3cff10cSYuri Pankov.Pa .zfs
1419b3cff10cSYuri Pankovdirectory is hidden or visible in the root of the file system as discussed in
1420b3cff10cSYuri Pankovthe
1421b3cff10cSYuri Pankov.Sx Snapshots
1422b3cff10cSYuri Pankovsection. The default value is
1423b3cff10cSYuri Pankov.Sy hidden .
1424b3cff10cSYuri Pankov.It Sy sync Ns = Ns Sy standard Ns | Ns Sy always Ns | Ns Sy disabled
1425b3cff10cSYuri PankovControls the behavior of synchronous requests
1426b3cff10cSYuri Pankov.Pq e.g. fsync, O_DSYNC .
1427b3cff10cSYuri Pankov.Sy standard
1428b3cff10cSYuri Pankovis the
1429b3cff10cSYuri Pankov.Tn POSIX
1430b3cff10cSYuri Pankovspecified behavior of ensuring all synchronous requests are written to stable
1431b3cff10cSYuri Pankovstorage and all devices are flushed to ensure data is not cached by device
1432b3cff10cSYuri Pankovcontrollers
1433b3cff10cSYuri Pankov.Pq this is the default .
1434b3cff10cSYuri Pankov.Sy always
143519b94df9SMatthew Ahrenscauses every file system transaction to be written and flushed before its
1436b3cff10cSYuri Pankovsystem call returns. This has a large performance penalty.
1437b3cff10cSYuri Pankov.Sy disabled
143819b94df9SMatthew Ahrensdisables synchronous requests. File system transactions are only committed to
143919b94df9SMatthew Ahrensstable storage periodically. This option will give the highest performance.
144019b94df9SMatthew AhrensHowever, it is very dangerous as ZFS would be ignoring the synchronous
144119b94df9SMatthew Ahrenstransaction demands of applications such as databases or NFS. Administrators
144219b94df9SMatthew Ahrensshould only use this option when the risks are understood.
1443b3cff10cSYuri Pankov.It Sy version Ns = Ns Em N Ns | Ns Sy current
1444c10c16deSRichard LoweThe on-disk version of this file system, which is independent of the pool
1445c10c16deSRichard Loweversion. This property can only be set to later supported versions. See the
1446b3cff10cSYuri Pankov.Nm zfs Cm upgrade
1447b3cff10cSYuri Pankovcommand.
1448b3cff10cSYuri Pankov.It Sy volsize Ns = Ns Em size
1449c10c16deSRichard LoweFor volumes, specifies the logical size of the volume. By default, creating a
1450b3cff10cSYuri Pankovvolume establishes a reservation of equal size. For storage pools with a version
1451b3cff10cSYuri Pankovnumber of 9 or higher, a
1452b3cff10cSYuri Pankov.Sy refreservation
1453b3cff10cSYuri Pankovis set instead. Any changes to
1454b3cff10cSYuri Pankov.Sy volsize
1455b3cff10cSYuri Pankovare reflected in an equivalent change to the reservation
1456b3cff10cSYuri Pankov.Po or
1457b3cff10cSYuri Pankov.Sy refreservation
1458b3cff10cSYuri Pankov.Pc .
1459b3cff10cSYuri PankovThe
1460b3cff10cSYuri Pankov.Sy volsize
1461b3cff10cSYuri Pankovcan only be set to a multiple of
1462b3cff10cSYuri Pankov.Sy volblocksize ,
1463b3cff10cSYuri Pankovand cannot be zero.
1464b3cff10cSYuri Pankov.Pp
1465b3cff10cSYuri PankovThe reservation is kept equal to the volume's logical size to prevent unexpected
1466b3cff10cSYuri Pankovbehavior for consumers. Without the reservation, the volume could run out of
1467b3cff10cSYuri Pankovspace, resulting in undefined behavior or data corruption, depending on how the
1468b3cff10cSYuri Pankovvolume is used. These effects can also occur when the volume size is changed
1469b3cff10cSYuri Pankovwhile it is in use
1470b3cff10cSYuri Pankov.Pq particularly when shrinking the size .
1471b3cff10cSYuri PankovExtreme care should be used when adjusting the volume size.
1472b3cff10cSYuri Pankov.Pp
1473b3cff10cSYuri PankovThough not recommended, a
1474b3cff10cSYuri Pankov.Qq sparse volume
1475b3cff10cSYuri Pankov.Po also known as
1476b3cff10cSYuri Pankov.Qq thin provisioning
1477b3cff10cSYuri Pankov.Pc
1478b3cff10cSYuri Pankovcan be created by specifying the
1479b3cff10cSYuri Pankov.Fl s
1480b3cff10cSYuri Pankovoption to the
1481b3cff10cSYuri Pankov.Nm zfs Cm create Fl V
1482c10c16deSRichard Lowecommand, or by changing the reservation after the volume has been created. A
1483b3cff10cSYuri Pankov.Qq sparse volume
1484b3cff10cSYuri Pankovis a volume where the reservation is less then the volume size. Consequently,
1485b3cff10cSYuri Pankovwrites to a sparse volume can fail with
1486b3cff10cSYuri Pankov.Er ENOSPC
1487b3cff10cSYuri Pankovwhen the pool is low on space. For a sparse volume, changes to
1488b3cff10cSYuri Pankov.Sy volsize
1489b3cff10cSYuri Pankovare not reflected in the reservation.
1490b3cff10cSYuri Pankov.It Sy vscan Ns = Ns Sy on Ns | Ns Sy off
1491c10c16deSRichard LoweControls whether regular files should be scanned for viruses when a file is
1492c10c16deSRichard Loweopened and closed. In addition to enabling this property, the virus scan
1493c10c16deSRichard Loweservice must also be enabled for virus scanning to occur. The default value is
1494b3cff10cSYuri Pankov.Sy off .
1495b3cff10cSYuri Pankov.It Sy xattr Ns = Ns Sy on Ns | Ns Sy off
1496c10c16deSRichard LoweControls whether extended attributes are enabled for this file system. The
1497b3cff10cSYuri Pankovdefault value is
1498b3cff10cSYuri Pankov.Sy on .
1499b3cff10cSYuri Pankov.It Sy zoned Ns = Ns Sy on Ns | Ns Sy off
1500b3cff10cSYuri PankovControls whether the dataset is managed from a non-global zone. See the
1501b3cff10cSYuri Pankov.Sx Zones
1502b3cff10cSYuri Pankovsection for more information. The default value is
1503b3cff10cSYuri Pankov.Sy off .
1504b3cff10cSYuri Pankov.El
1505b3cff10cSYuri Pankov.Pp
1506c10c16deSRichard LoweThe following three properties cannot be changed after the file system is
1507c10c16deSRichard Lowecreated, and therefore, should be set when the file system is created. If the
1508b3cff10cSYuri Pankovproperties are not set with the
1509b3cff10cSYuri Pankov.Nm zfs Cm create
1510b3cff10cSYuri Pankovor
1511b3cff10cSYuri Pankov.Nm zpool Cm create
1512c10c16deSRichard Lowecommands, these properties are inherited from the parent dataset. If the parent
1513c10c16deSRichard Lowedataset lacks these properties due to having been created prior to these
1514c10c16deSRichard Lowefeatures being supported, the new file system will have the default values for
1515c10c16deSRichard Lowethese properties.
1516b3cff10cSYuri Pankov.Bl -tag -width ""
1517b3cff10cSYuri Pankov.It Xo
1518b3cff10cSYuri Pankov.Sy casesensitivity Ns = Ns Sy sensitive Ns | Ns
1519b3cff10cSYuri Pankov.Sy insensitive Ns | Ns Sy mixed
1520b3cff10cSYuri Pankov.Xc
1521c10c16deSRichard LoweIndicates whether the file name matching algorithm used by the file system
1522c10c16deSRichard Loweshould be case-sensitive, case-insensitive, or allow a combination of both
1523b3cff10cSYuri Pankovstyles of matching. The default value for the
1524b3cff10cSYuri Pankov.Sy casesensitivity
1525b3cff10cSYuri Pankovproperty is
1526b3cff10cSYuri Pankov.Sy sensitive .
1527b3cff10cSYuri PankovTraditionally,
1528b3cff10cSYuri Pankov.Ux
1529b3cff10cSYuri Pankovand
1530b3cff10cSYuri Pankov.Tn POSIX
1531b3cff10cSYuri Pankovfile systems have case-sensitive file names.
1532b3cff10cSYuri Pankov.Pp
1533b3cff10cSYuri PankovThe
1534b3cff10cSYuri Pankov.Sy mixed
1535b3cff10cSYuri Pankovvalue for the
1536b3cff10cSYuri Pankov.Sy casesensitivity
1537b3cff10cSYuri Pankovproperty indicates that the file system can support requests for both
1538b3cff10cSYuri Pankovcase-sensitive and case-insensitive matching behavior. Currently,
1539b3cff10cSYuri Pankovcase-insensitive matching behavior on a file system that supports mixed behavior
1540b3cff10cSYuri Pankovis limited to the SMB server product. For more information about the
1541b3cff10cSYuri Pankov.Sy mixed
1542b3cff10cSYuri Pankovvalue behavior, see the "ZFS Administration Guide".
1543b3cff10cSYuri Pankov.It Xo
1544b3cff10cSYuri Pankov.Sy normalization Ns = Ns Sy none Ns | Ns Sy formC Ns | Ns
1545b3cff10cSYuri Pankov.Sy formD Ns | Ns Sy formKC Ns | Ns Sy formKD
1546b3cff10cSYuri Pankov.Xc
1547b3cff10cSYuri PankovIndicates whether the file system should perform a
1548b3cff10cSYuri Pankov.Sy unicode
1549b3cff10cSYuri Pankovnormalization of file names whenever two file names are compared, and which
1550b3cff10cSYuri Pankovnormalization algorithm should be used. File names are always stored unmodified,
1551b3cff10cSYuri Pankovnames are normalized as part of any comparison process. If this property is set
1552b3cff10cSYuri Pankovto a legal value other than
1553b3cff10cSYuri Pankov.Sy none ,
1554b3cff10cSYuri Pankovand the
1555b3cff10cSYuri Pankov.Sy utf8only
1556b3cff10cSYuri Pankovproperty was left unspecified, the
1557b3cff10cSYuri Pankov.Sy utf8only
1558b3cff10cSYuri Pankovproperty is automatically set to
1559b3cff10cSYuri Pankov.Sy on .
1560b3cff10cSYuri PankovThe default value of the
1561b3cff10cSYuri Pankov.Sy normalization
1562b3cff10cSYuri Pankovproperty is
1563b3cff10cSYuri Pankov.Sy none .
1564b3cff10cSYuri PankovThis property cannot be changed after the file system is created.
1565b3cff10cSYuri Pankov.It Sy utf8only Ns = Ns Sy on Ns | Ns Sy off
1566c10c16deSRichard LoweIndicates whether the file system should reject file names that include
1567b3cff10cSYuri Pankovcharacters that are not present in the
1568b3cff10cSYuri Pankov.Sy UTF-8
1569b3cff10cSYuri Pankovcharacter code set. If this property is explicitly set to
1570b3cff10cSYuri Pankov.Sy off ,
1571b3cff10cSYuri Pankovthe normalization property must either not be explicitly set or be set to
1572b3cff10cSYuri Pankov.Sy none .
1573b3cff10cSYuri PankovThe default value for the
1574b3cff10cSYuri Pankov.Sy utf8only
1575b3cff10cSYuri Pankovproperty is
1576b3cff10cSYuri Pankov.Sy off .
1577b3cff10cSYuri PankovThis property cannot be changed after the file system is created.
1578b3cff10cSYuri Pankov.El
1579b3cff10cSYuri Pankov.Pp
1580b3cff10cSYuri PankovThe
1581b3cff10cSYuri Pankov.Sy casesensitivity ,
1582b3cff10cSYuri Pankov.Sy normalization ,
1583b3cff10cSYuri Pankovand
1584b3cff10cSYuri Pankov.Sy utf8only
1585b3cff10cSYuri Pankovproperties are also new permissions that can be assigned to non-privileged users
1586b3cff10cSYuri Pankovby using the ZFS delegated administration feature.
1587b3cff10cSYuri Pankov.Ss "Temporary Mount Point Properties"
1588b3cff10cSYuri PankovWhen a file system is mounted, either through
1589b3cff10cSYuri Pankov.Xr mount 1M
1590b3cff10cSYuri Pankovfor legacy mounts or the
1591b3cff10cSYuri Pankov.Nm zfs Cm mount
1592b3cff10cSYuri Pankovcommand for normal file systems, its mount options are set according to its
1593b3cff10cSYuri Pankovproperties. The correlation between properties and mount options is as follows:
1594b3cff10cSYuri Pankov.Bd -literal
1595c10c16deSRichard Lowe    PROPERTY                MOUNT OPTION
1596c10c16deSRichard Lowe    devices                 devices/nodevices
1597c10c16deSRichard Lowe    exec                    exec/noexec
1598c10c16deSRichard Lowe    readonly                ro/rw
1599c10c16deSRichard Lowe    setuid                  setuid/nosetuid
1600c10c16deSRichard Lowe    xattr                   xattr/noxattr
1601b3cff10cSYuri Pankov.Ed
1602b3cff10cSYuri Pankov.Pp
1603b3cff10cSYuri PankovIn addition, these options can be set on a per-mount basis using the
1604b3cff10cSYuri Pankov.Fl o
1605c10c16deSRichard Loweoption, without affecting the property that is stored on disk. The values
1606c10c16deSRichard Lowespecified on the command line override the values stored in the dataset. The
1607b3cff10cSYuri Pankov.Sy nosuid
1608b3cff10cSYuri Pankovoption is an alias for
1609b3cff10cSYuri Pankov.Sy nodevices Ns , Ns Sy nosetuid .
1610b3cff10cSYuri PankovThese properties are reported as
1611b3cff10cSYuri Pankov.Qq temporary
1612b3cff10cSYuri Pankovby the
1613b3cff10cSYuri Pankov.Nm zfs Cm get
1614b3cff10cSYuri Pankovcommand. If the properties are changed while the dataset is mounted, the new
1615b3cff10cSYuri Pankovsetting overrides any temporary settings.
1616b3cff10cSYuri Pankov.Ss "User Properties"
1617b3cff10cSYuri PankovIn addition to the standard native properties, ZFS supports arbitrary user
1618b3cff10cSYuri Pankovproperties. User properties have no effect on ZFS behavior, but applications or
1619b3cff10cSYuri Pankovadministrators can use them to annotate datasets
1620b3cff10cSYuri Pankov.Pq file systems, volumes, and snapshots .
1621b3cff10cSYuri Pankov.Pp
1622b3cff10cSYuri PankovUser property names must contain a colon
1623b3cff10cSYuri Pankov.No Po Ns Sy \&:  Ns Pc
1624b3cff10cSYuri Pankovcharacter to distinguish them from native properties. They may contain lowercase
1625b3cff10cSYuri Pankovletters, numbers, and the following punctuation characters: colon
1626b3cff10cSYuri Pankov.Pq Qq Sy \&: ,
1627b3cff10cSYuri Pankovdash
1628b3cff10cSYuri Pankov.Pq Qq Sy - ,
1629b3cff10cSYuri Pankovperiod
1630b3cff10cSYuri Pankov.Pq Qq Sy \&. ,
1631b3cff10cSYuri Pankovand underscore
1632b3cff10cSYuri Pankov.Pq Qq Sy _ .
1633b3cff10cSYuri PankovThe expected convention is that the property name is divided into two portions
1634b3cff10cSYuri Pankovsuch as
1635b3cff10cSYuri Pankov.Em module Ns : Ns Em property ,
1636b3cff10cSYuri Pankovbut this namespace is not enforced by ZFS.
1637b3cff10cSYuri PankovUser property names can be at most 256 characters, and cannot begin with a dash
1638b3cff10cSYuri Pankov.Pq Qq Sy - .
1639b3cff10cSYuri Pankov.Pp
1640b3cff10cSYuri PankovWhen making programmatic use of user properties, it is strongly suggested to use
1641b3cff10cSYuri Pankova reversed
1642b3cff10cSYuri Pankov.Sy DNS
1643b3cff10cSYuri Pankovdomain name for the
1644b3cff10cSYuri Pankov.Em module
1645b3cff10cSYuri Pankovcomponent of property names to reduce the chance that two
1646b3cff10cSYuri Pankovindependently-developed packages use the same property name for different
1647b3cff10cSYuri Pankovpurposes.
1648b3cff10cSYuri Pankov.Pp
1649c10c16deSRichard LoweThe values of user properties are arbitrary strings, are always inherited, and
1650b3cff10cSYuri Pankovare never validated. All of the commands that operate on properties
1651b3cff10cSYuri Pankov.Po Nm zfs Cm list ,
1652b3cff10cSYuri Pankov.Nm zfs Cm get ,
1653b3cff10cSYuri Pankov.Nm zfs Cm set ,
1654b3cff10cSYuri Pankovand so forth
1655b3cff10cSYuri Pankov.Pc
1656b3cff10cSYuri Pankovcan be used to manipulate both native properties and user properties. Use the
1657b3cff10cSYuri Pankov.Nm zfs Cm inherit
1658b3cff10cSYuri Pankovcommand to clear a user property . If the property is not defined in any parent
1659c10c16deSRichard Lowedataset, it is removed entirely. Property values are limited to 1024
1660c10c16deSRichard Lowecharacters.
1661b3cff10cSYuri Pankov.Ss ZFS Volumes as Swap or Dump Devices
1662b3cff10cSYuri PankovDuring an initial installation a swap device and dump device are created on ZFS
1663b3cff10cSYuri Pankovvolumes in the ZFS root pool. By default, the swap area size is based on 1/2 the
1664b3cff10cSYuri Pankovsize of physical memory up to 2 Gbytes. The size of the dump device depends on
1665b3cff10cSYuri Pankovthe kernel's requirements at installation time. Separate ZFS volumes must be
1666b3cff10cSYuri Pankovused for the swap area and dump devices. Do not swap to a file on a ZFS file
1667b3cff10cSYuri Pankovsystem. A ZFS swap file configuration is not supported.
1668b3cff10cSYuri Pankov.Pp
1669c10c16deSRichard LoweIf you need to change your swap area or dump device after the system is
1670b3cff10cSYuri Pankovinstalled or upgraded, use the
1671b3cff10cSYuri Pankov.Xr swap 1M
1672b3cff10cSYuri Pankovand
1673b3cff10cSYuri Pankov.Xr dumpadm 1M
1674b3cff10cSYuri Pankovcommands.
1675b3cff10cSYuri Pankov.Sh SUBCOMMANDS
1676c10c16deSRichard LoweAll subcommands that modify state are logged persistently to the pool in their
1677c10c16deSRichard Loweoriginal form.
1678b3cff10cSYuri Pankov.Bl -tag -width ""
1679b3cff10cSYuri Pankov.It Nm Fl \?
1680c10c16deSRichard LoweDisplays a help message.
1681b3cff10cSYuri Pankov.It Xo
1682b3cff10cSYuri Pankov.Nm
1683b3cff10cSYuri Pankov.Cm create
1684b3cff10cSYuri Pankov.Op Fl p
1685b3cff10cSYuri Pankov.Oo Fl o Ar property Ns = Ns Ar value Oc Ns ...
1686b3cff10cSYuri Pankov.Ar filesystem
1687b3cff10cSYuri Pankov.Xc
1688b3cff10cSYuri PankovCreates a new ZFS file system. The file system is automatically mounted
1689b3cff10cSYuri Pankovaccording to the
1690b3cff10cSYuri Pankov.Sy mountpoint
1691b3cff10cSYuri Pankovproperty inherited from the parent.
1692b3cff10cSYuri Pankov.Bl -tag -width "-o"
1693b3cff10cSYuri Pankov.It Fl o Ar property Ns = Ns Ar value
1694b3cff10cSYuri PankovSets the specified property as if the command
1695b3cff10cSYuri Pankov.Nm zfs Cm set Ar property Ns = Ns Ar value
1696b3cff10cSYuri Pankovwas invoked at the same time the dataset was created. Any editable ZFS property
1697b3cff10cSYuri Pankovcan also be set at creation time. Multiple
1698b3cff10cSYuri Pankov.Fl o
1699b3cff10cSYuri Pankovoptions can be specified. An error results if the same property is specified in
1700b3cff10cSYuri Pankovmultiple
1701b3cff10cSYuri Pankov.Fl o
1702b3cff10cSYuri Pankovoptions.
1703b3cff10cSYuri Pankov.It Fl p
1704c10c16deSRichard LoweCreates all the non-existing parent datasets. Datasets created in this manner
1705b3cff10cSYuri Pankovare automatically mounted according to the
1706b3cff10cSYuri Pankov.Sy mountpoint
1707b3cff10cSYuri Pankovproperty inherited from their parent. Any property specified on the command line
1708b3cff10cSYuri Pankovusing the
1709b3cff10cSYuri Pankov.Fl o
1710b3cff10cSYuri Pankovoption is ignored. If the target filesystem already exists, the operation
1711b3cff10cSYuri Pankovcompletes successfully.
1712b3cff10cSYuri Pankov.El
1713b3cff10cSYuri Pankov.It Xo
1714b3cff10cSYuri Pankov.Nm
1715b3cff10cSYuri Pankov.Cm create
1716b3cff10cSYuri Pankov.Op Fl ps
1717b3cff10cSYuri Pankov.Op Fl b Ar blocksize
1718b3cff10cSYuri Pankov.Oo Fl o Ar property Ns = Ns Ar value Oc Ns ...
1719b3cff10cSYuri Pankov.Fl V Ar size Ar volume
1720b3cff10cSYuri Pankov.Xc
1721c10c16deSRichard LoweCreates a volume of the given size. The volume is exported as a block device in
1722b3cff10cSYuri Pankov.Pa /dev/zvol/{dsk,rdsk}/path ,
1723b3cff10cSYuri Pankovwhere
1724b3cff10cSYuri Pankov.Em path
1725b3cff10cSYuri Pankovis the name of the volume in the ZFS namespace. The size represents the logical
1726b3cff10cSYuri Pankovsize as exported by the device. By default, a reservation of equal size is
1727b3cff10cSYuri Pankovcreated.
1728b3cff10cSYuri Pankov.Pp
1729b3cff10cSYuri Pankov.Ar size
1730b3cff10cSYuri Pankovis automatically rounded up to the nearest 128 Kbytes to ensure that the volume
1731b3cff10cSYuri Pankovhas an integral number of blocks regardless of
1732b3cff10cSYuri Pankov.Sy blocksize .
1733b3cff10cSYuri Pankov.Bl -tag -width "-b"
1734b3cff10cSYuri Pankov.It Fl b Ar blocksize
1735b3cff10cSYuri PankovEquivalent to
1736b3cff10cSYuri Pankov.Fl o Sy volblocksize Ns = Ns Ar blocksize .
1737b3cff10cSYuri PankovIf this option is specified in conjunction with
1738b3cff10cSYuri Pankov.Fl o Sy volblocksize ,
1739b3cff10cSYuri Pankovthe resulting behavior is undefined.
1740b3cff10cSYuri Pankov.It Fl o Ar property Ns = Ns Ar value
1741b3cff10cSYuri PankovSets the specified property as if the
1742b3cff10cSYuri Pankov.Nm zfs Cm set Ar property Ns = Ns Ar value
1743b3cff10cSYuri Pankovcommand was invoked at the same time the dataset was created. Any editable ZFS
1744b3cff10cSYuri Pankovproperty can also be set at creation time. Multiple
1745b3cff10cSYuri Pankov.Fl o
1746b3cff10cSYuri Pankovoptions can be specified. An error results if the same property is specified in
1747b3cff10cSYuri Pankovmultiple
1748b3cff10cSYuri Pankov.Fl o
1749b3cff10cSYuri Pankovoptions.
1750b3cff10cSYuri Pankov.It Fl p
1751c10c16deSRichard LoweCreates all the non-existing parent datasets. Datasets created in this manner
1752b3cff10cSYuri Pankovare automatically mounted according to the
1753b3cff10cSYuri Pankov.Sy mountpoint
1754b3cff10cSYuri Pankovproperty inherited from their parent. Any property specified on the command line
1755b3cff10cSYuri Pankovusing the
1756b3cff10cSYuri Pankov.Fl o
1757b3cff10cSYuri Pankovoption is ignored. If the target filesystem already exists, the operation
1758b3cff10cSYuri Pankovcompletes successfully.
1759b3cff10cSYuri Pankov.It Fl s
1760b3cff10cSYuri PankovCreates a sparse volume with no reservation. See
1761b3cff10cSYuri Pankov.Sy volsize
1762b3cff10cSYuri Pankovin the
1763b3cff10cSYuri Pankov.Sx Native Properties
1764b3cff10cSYuri Pankovsection for more information about sparse volumes.
1765b3cff10cSYuri Pankov.El
1766b3cff10cSYuri Pankov.It Xo
1767b3cff10cSYuri Pankov.Nm
1768b3cff10cSYuri Pankov.Cm destroy
1769b3cff10cSYuri Pankov.Op Fl Rfnprv
1770b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
1771b3cff10cSYuri Pankov.Xc
1772c10c16deSRichard LoweDestroys the given dataset. By default, the command unshares any file systems
1773c10c16deSRichard Lowethat are currently shared, unmounts any file systems that are currently
1774b3cff10cSYuri Pankovmounted, and refuses to destroy a dataset that has active dependents
1775b3cff10cSYuri Pankov.Pq children or clones .
1776b3cff10cSYuri Pankov.Bl -tag -width "-R"
1777b3cff10cSYuri Pankov.It Fl R
1778c10c16deSRichard LoweRecursively destroy all dependents, including cloned file systems outside the
1779c10c16deSRichard Lowetarget hierarchy.
1780b3cff10cSYuri Pankov.It Fl f
1781b3cff10cSYuri PankovForce an unmount of any file systems using the
1782b3cff10cSYuri Pankov.Nm unmount Fl f
1783b3cff10cSYuri Pankovcommand. This option has no effect on non-file systems or unmounted file
1784b3cff10cSYuri Pankovsystems.
1785b3cff10cSYuri Pankov.It Fl n
1786b3cff10cSYuri PankovDo a dry-run
1787b3cff10cSYuri Pankov.Pq Qq No-op
1788b3cff10cSYuri Pankovdeletion. No data will be deleted. This is useful in conjunction with the
1789b3cff10cSYuri Pankov.Fl v
1790b3cff10cSYuri Pankovor
1791b3cff10cSYuri Pankov.Fl p
1792b3cff10cSYuri Pankovflags to determine what data would be deleted.
1793b3cff10cSYuri Pankov.It Fl p
179419b94df9SMatthew AhrensPrint machine-parsable verbose information about the deleted data.
1795b3cff10cSYuri Pankov.It Fl r
1796b3cff10cSYuri PankovRecursively destroy all children.
1797b3cff10cSYuri Pankov.It Fl v
179819b94df9SMatthew AhrensPrint verbose information about the deleted data.
1799b3cff10cSYuri Pankov.El
1800b3cff10cSYuri Pankov.Pp
1801b3cff10cSYuri PankovExtreme care should be taken when applying either the
1802b3cff10cSYuri Pankov.Fl r
1803b3cff10cSYuri Pankovor the
1804b3cff10cSYuri Pankov.Fl R
1805c10c16deSRichard Loweoptions, as they can destroy large portions of a pool and cause unexpected
1806c10c16deSRichard Lowebehavior for mounted file systems in use.
1807b3cff10cSYuri Pankov.It Xo
1808b3cff10cSYuri Pankov.Nm
1809b3cff10cSYuri Pankov.Cm destroy
1810b3cff10cSYuri Pankov.Op Fl Rdnprv
1811b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume Ns @ Ns Ar snap Ns
1812b3cff10cSYuri Pankov.Oo % Ns Ar snap Ns Oo , Ns Ar snap Ns Oo % Ns Ar snap Oc Oc Oc Ns ...
1813b3cff10cSYuri Pankov.Xc
1814b3cff10cSYuri PankovThe given snapshots are destroyed immediately if and only if the
1815b3cff10cSYuri Pankov.Nm zfs Cm destroy
1816b3cff10cSYuri Pankovcommand without the
1817b3cff10cSYuri Pankov.Fl d
1818b3cff10cSYuri Pankovoption would have destroyed it. Such immediate destruction would occur, for
1819b3cff10cSYuri Pankovexample, if the snapshot had no clones and the user-initiated reference count
1820b3cff10cSYuri Pankovwere zero.
1821b3cff10cSYuri Pankov.Pp
182219b94df9SMatthew AhrensIf a snapshot does not qualify for immediate destruction, it is marked for
1823c10c16deSRichard Lowedeferred deletion. In this state, it exists as a usable, visible snapshot until
1824c10c16deSRichard Loweboth of the preconditions listed above are met, at which point it is destroyed.
1825b3cff10cSYuri Pankov.Pp
1826b3cff10cSYuri PankovAn inclusive range of snapshots may be specified by separating the first and
1827b3cff10cSYuri Pankovlast snapshots with a percent sign. The first and/or last snapshots may be left
1828b3cff10cSYuri Pankovblank, in which case the filesystem's oldest or newest snapshot will be implied.
1829b3cff10cSYuri Pankov.Pp
183019b94df9SMatthew AhrensMultiple snapshots
1831b3cff10cSYuri Pankov.Pq or ranges of snapshots
1832b3cff10cSYuri Pankovof the same filesystem or volume may be specified in a comma-separated list of
1833b3cff10cSYuri Pankovsnapshots. Only the snapshot's short name
1834b3cff10cSYuri Pankov.Po the part after the
1835b3cff10cSYuri Pankov.Sy @
1836b3cff10cSYuri Pankov.Pc
1837b3cff10cSYuri Pankovshould be specified when using a range or comma-separated list to identify
1838b3cff10cSYuri Pankovmultiple snapshots.
1839b3cff10cSYuri Pankov.Bl -tag -width "-R"
1840b3cff10cSYuri Pankov.It Fl R
18413b2aab18SMatthew AhrensRecursively destroy all clones of these snapshots, including the clones,
1842b3cff10cSYuri Pankovsnapshots, and children. If this flag is specified, the
1843b3cff10cSYuri Pankov.Fl d
1844b3cff10cSYuri Pankovflag will have no effect.
1845b3cff10cSYuri Pankov.It Fl d
1846b3cff10cSYuri PankovDefer snapshot deletion.
1847b3cff10cSYuri Pankov.It Fl n
1848b3cff10cSYuri PankovDo a dry-run
1849b3cff10cSYuri Pankov.Pq Qq No-op
1850b3cff10cSYuri Pankovdeletion. No data will be deleted. This is
1851b3cff10cSYuri Pankovuseful in conjunction with the
1852b3cff10cSYuri Pankov.Fl p
1853b3cff10cSYuri Pankovor
1854b3cff10cSYuri Pankov.Fl v
1855b3cff10cSYuri Pankovflags to determine what data would be deleted.
1856b3cff10cSYuri Pankov.It Fl p
185719b94df9SMatthew AhrensPrint machine-parsable verbose information about the deleted data.
1858b3cff10cSYuri Pankov.It Fl r
1859b3cff10cSYuri PankovDestroy
1860b3cff10cSYuri Pankov.Pq or mark for deferred deletion
1861b3cff10cSYuri Pankovall snapshots with this name in descendent file systems.
1862b3cff10cSYuri Pankov.It Fl v
186319b94df9SMatthew AhrensPrint verbose information about the deleted data.
1864b3cff10cSYuri Pankov.Pp
1865b3cff10cSYuri PankovExtreme care should be taken when applying either the
1866b3cff10cSYuri Pankov.Fl r
1867b3cff10cSYuri Pankovor the
1868b3cff10cSYuri Pankov.Fl R
186919b94df9SMatthew Ahrensoptions, as they can destroy large portions of a pool and cause unexpected
187019b94df9SMatthew Ahrensbehavior for mounted file systems in use.
1871b3cff10cSYuri Pankov.El
1872b3cff10cSYuri Pankov.It Xo
1873b3cff10cSYuri Pankov.Nm
1874b3cff10cSYuri Pankov.Cm destroy
1875b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume Ns # Ns Ar bookmark
1876b3cff10cSYuri Pankov.Xc
187778f17100SMatthew AhrensThe given bookmark is destroyed.
1878b3cff10cSYuri Pankov.It Xo
1879b3cff10cSYuri Pankov.Nm
1880b3cff10cSYuri Pankov.Cm snapshot
1881b3cff10cSYuri Pankov.Op Fl r
1882b3cff10cSYuri Pankov.Oo Fl o Ar property Ns = Ns value Oc Ns ...
1883b3cff10cSYuri Pankov.Ar filesystem Ns @ Ns Ar snapname Ns | Ns Ar volume Ns @ Ns Ar snapname Ns ...
1884b3cff10cSYuri Pankov.Xc
1885b3cff10cSYuri PankovCreates snapshots with the given names. All previous modifications by successful
1886b3cff10cSYuri Pankovsystem calls to the file system are part of the snapshots. Snapshots are taken
1887b3cff10cSYuri Pankovatomically, so that all snapshots correspond to the same moment in time. See the
1888b3cff10cSYuri Pankov.Sx Snapshots
1889b3cff10cSYuri Pankovsection for details.
1890b3cff10cSYuri Pankov.Bl -tag -width "-o"
1891b3cff10cSYuri Pankov.It Fl o Ar property Ns = Ns Ar value
1892b3cff10cSYuri PankovSets the specified property; see
1893b3cff10cSYuri Pankov.Nm zfs Cm create
1894b3cff10cSYuri Pankovfor details.
1895b3cff10cSYuri Pankov.It Fl r
18964445fffbSMatthew AhrensRecursively create snapshots of all descendent datasets
1897b3cff10cSYuri Pankov.El
1898b3cff10cSYuri Pankov.It Xo
1899b3cff10cSYuri Pankov.Nm
1900b3cff10cSYuri Pankov.Cm rollback
1901b3cff10cSYuri Pankov.Op Fl Rfr
1902b3cff10cSYuri Pankov.Ar snapshot
1903b3cff10cSYuri Pankov.Xc
1904c10c16deSRichard LoweRoll back the given dataset to a previous snapshot. When a dataset is rolled
1905b3cff10cSYuri Pankovback, all data that has changed since the snapshot is discarded, and the dataset
1906b3cff10cSYuri Pankovreverts to the state at the time of the snapshot. By default, the command
1907b3cff10cSYuri Pankovrefuses to roll back to a snapshot other than the most recent one. In order to
1908b3cff10cSYuri Pankovdo so, all intermediate snapshots and bookmarks must be destroyed by specifying
1909b3cff10cSYuri Pankovthe
1910b3cff10cSYuri Pankov.Fl r
1911b3cff10cSYuri Pankovoption.
1912b3cff10cSYuri Pankov.Pp
1913b3cff10cSYuri PankovThe
1914b3cff10cSYuri Pankov.Fl rR
1915b3cff10cSYuri Pankovoptions do not recursively destroy the child snapshots of a recursive snapshot.
1916b3cff10cSYuri PankovOnly direct snapshots of the specified filesystem are destroyed by either of
1917b3cff10cSYuri Pankovthese options. To completely roll back a recursive snapshot, you must rollback
1918b3cff10cSYuri Pankovthe individual child snapshots.
1919b3cff10cSYuri Pankov.Bl -tag -width "-R"
1920b3cff10cSYuri Pankov.It Fl R
192178f17100SMatthew AhrensDestroy any more recent snapshots and bookmarks, as well as any clones of those
1922c10c16deSRichard Lowesnapshots.
1923b3cff10cSYuri Pankov.It Fl f
1924b3cff10cSYuri PankovUsed with the
1925b3cff10cSYuri Pankov.Fl R
1926b3cff10cSYuri Pankovoption to force an unmount of any clone file systems that are to be destroyed.
1927b3cff10cSYuri Pankov.It Fl r
1928b3cff10cSYuri PankovDestroy any snapshots and bookmarks more recent than the one specified.
1929b3cff10cSYuri Pankov.El
1930b3cff10cSYuri Pankov.It Xo
1931b3cff10cSYuri Pankov.Nm
1932b3cff10cSYuri Pankov.Cm clone
1933b3cff10cSYuri Pankov.Op Fl p
1934b3cff10cSYuri Pankov.Oo Fl o Ar property Ns = Ns Ar value Oc Ns ...
1935b3cff10cSYuri Pankov.Ar snapshot Ar filesystem Ns | Ns Ar volume
1936b3cff10cSYuri Pankov.Xc
1937b3cff10cSYuri PankovCreates a clone of the given snapshot. See the
1938b3cff10cSYuri Pankov.Sx Clones
1939b3cff10cSYuri Pankovsection for details. The target dataset can be located anywhere in the ZFS
1940b3cff10cSYuri Pankovhierarchy, and is created as the same type as the original.
1941b3cff10cSYuri Pankov.Bl -tag -width "-o"
1942b3cff10cSYuri Pankov.It Fl o Ar property Ns = Ns Ar value
1943b3cff10cSYuri PankovSets the specified property; see
1944b3cff10cSYuri Pankov.Nm zfs Cm create
1945b3cff10cSYuri Pankovfor details.
1946b3cff10cSYuri Pankov.It Fl p
1947c10c16deSRichard LoweCreates all the non-existing parent datasets. Datasets created in this manner
1948b3cff10cSYuri Pankovare automatically mounted according to the
1949b3cff10cSYuri Pankov.Sy mountpoint
1950b3cff10cSYuri Pankovproperty inherited from their parent. If the target filesystem or volume already
1951b3cff10cSYuri Pankovexists, the operation completes successfully.
1952b3cff10cSYuri Pankov.El
1953b3cff10cSYuri Pankov.It Xo
1954b3cff10cSYuri Pankov.Nm
1955b3cff10cSYuri Pankov.Cm promote
1956b3cff10cSYuri Pankov.Ar clone-filesystem
1957b3cff10cSYuri Pankov.Xc
1958b3cff10cSYuri PankovPromotes a clone file system to no longer be dependent on its
1959b3cff10cSYuri Pankov.Qq origin
1960c10c16deSRichard Lowesnapshot. This makes it possible to destroy the file system that the clone was
1961c10c16deSRichard Lowecreated from. The clone parent-child dependency relationship is reversed, so
1962c10c16deSRichard Lowethat the origin file system becomes a clone of the specified file system.
1963b3cff10cSYuri Pankov.Pp
1964c10c16deSRichard LoweThe snapshot that was cloned, and any snapshots previous to this snapshot, are
1965c10c16deSRichard Lowenow owned by the promoted clone. The space they use moves from the origin file
1966c10c16deSRichard Lowesystem to the promoted clone, so enough space must be available to accommodate
1967c10c16deSRichard Lowethese snapshots. No new space is consumed by this operation, but the space
1968c10c16deSRichard Loweaccounting is adjusted. The promoted clone must not have any conflicting
1969b3cff10cSYuri Pankovsnapshot names of its own. The
1970b3cff10cSYuri Pankov.Cm rename
1971b3cff10cSYuri Pankovsubcommand can be used to rename any conflicting snapshots.
1972b3cff10cSYuri Pankov.It Xo
1973b3cff10cSYuri Pankov.Nm
1974b3cff10cSYuri Pankov.Cm rename
1975b3cff10cSYuri Pankov.Op Fl f
1976b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume Ns | Ns Ar snapshot
1977b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume Ns | Ns Ar snapshot
1978c10c16deSRichard Lowe.br
1979b3cff10cSYuri Pankov.Nm
1980b3cff10cSYuri Pankov.Cm rename
1981b3cff10cSYuri Pankov.Op Fl fp
1982b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
1983b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
1984b3cff10cSYuri Pankov.Xc
1985b3cff10cSYuri PankovRenames the given dataset. The new target can be located anywhere in the ZFS
1986b3cff10cSYuri Pankovhierarchy, with the exception of snapshots. Snapshots can only be renamed within
1987b3cff10cSYuri Pankovthe parent file system or volume. When renaming a snapshot, the parent file
1988b3cff10cSYuri Pankovsystem of the snapshot does not need to be specified as part of the second
1989b3cff10cSYuri Pankovargument. Renamed file systems can inherit new mount points, in which case they
1990b3cff10cSYuri Pankovare unmounted and remounted at the new mount point.
1991b3cff10cSYuri Pankov.Bl -tag -width "-a"
1992b3cff10cSYuri Pankov.It Fl f
19936a9cb0eaSEric SchrockForce unmount any filesystems that need to be unmounted in the process.
1994b3cff10cSYuri Pankov.It Fl p
1995b3cff10cSYuri PankovCreates all the nonexistent parent datasets. Datasets created in this manner are
1996b3cff10cSYuri Pankovautomatically mounted according to the
1997b3cff10cSYuri Pankov.Sy mountpoint
1998b3cff10cSYuri Pankovproperty inherited from their parent.
1999b3cff10cSYuri Pankov.El
2000b3cff10cSYuri Pankov.It Xo
2001b3cff10cSYuri Pankov.Nm
2002b3cff10cSYuri Pankov.Cm rename
2003b3cff10cSYuri Pankov.Fl r
2004b3cff10cSYuri Pankov.Ar snapshot Ar snapshot
2005b3cff10cSYuri Pankov.Xc
2006c10c16deSRichard LoweRecursively rename the snapshots of all descendent datasets. Snapshots are the
2007c10c16deSRichard Loweonly dataset that can be renamed recursively.
2008b3cff10cSYuri Pankov.It Xo
2009b3cff10cSYuri Pankov.Nm
2010b3cff10cSYuri Pankov.Cm list
2011b3cff10cSYuri Pankov.Op Fl r Ns | Ns Fl d Ar depth
2012b3cff10cSYuri Pankov.Op Fl Hp
2013b3cff10cSYuri Pankov.Oo Fl o Ar property Ns Oo , Ns Ar property Oc Ns ... Oc
2014b3cff10cSYuri Pankov.Oo Fl s Ar property Oc Ns ...
2015b3cff10cSYuri Pankov.Oo Fl S Ar property Oc Ns ...
2016b3cff10cSYuri Pankov.Oo Fl t Ar type Ns Oo , Ns Ar type Oc Ns ... Oc
2017b3cff10cSYuri Pankov.Oo Ar filesystem Ns | Ns Ar volume Ns | Ns Ar snapshot Oc Ns ...
2018b3cff10cSYuri Pankov.Xc
2019c10c16deSRichard LoweLists the property information for the given datasets in tabular form. If
2020c10c16deSRichard Lowespecified, you can list property information by the absolute pathname or the
2021c10c16deSRichard Lowerelative pathname. By default, all file systems and volumes are displayed.
2022b3cff10cSYuri PankovSnapshots are displayed if the
2023b3cff10cSYuri Pankov.Sy listsnaps
2024b3cff10cSYuri Pankovproperty is
2025b3cff10cSYuri Pankov.Sy on
2026b3cff10cSYuri Pankov.Po the default is
2027b3cff10cSYuri Pankov.Sy off
2028b3cff10cSYuri Pankov.Pc .
2029b3cff10cSYuri PankovThe following fields are displayed,
2030b3cff10cSYuri Pankov.Sy name Ns , Ns Sy used Ns , Ns Sy available Ns , Ns Sy referenced Ns , Ns
2031b3cff10cSYuri Pankov.Sy mountpoint .
2032b3cff10cSYuri Pankov.Bl -tag -width "-H"
2033b3cff10cSYuri Pankov.It Fl H
2034c10c16deSRichard LoweUsed for scripting mode. Do not print headers and separate fields by a single
2035c10c16deSRichard Lowetab instead of arbitrary white space.
2036b3cff10cSYuri Pankov.It Fl S Ar property
2037b3cff10cSYuri PankovSame as the
2038b3cff10cSYuri Pankov.Fl s
2039b3cff10cSYuri Pankovoption, but sorts by property in descending order.
2040b3cff10cSYuri Pankov.It Fl d Ar depth
2041c10c16deSRichard LoweRecursively display any children of the dataset, limiting the recursion to
2042b3cff10cSYuri Pankov.It Fl o Ar property
2043c10c16deSRichard LoweA comma-separated list of properties to display. The property must be:
2044b3cff10cSYuri Pankov.Bl -bullet
2045b3cff10cSYuri Pankov.It
2046b3cff10cSYuri PankovOne of the properties described in the
2047b3cff10cSYuri Pankov.Sx Native Properties
2048b3cff10cSYuri Pankovsection
2049b3cff10cSYuri Pankov.It
2050c10c16deSRichard LoweA user property
2051b3cff10cSYuri Pankov.It
2052b3cff10cSYuri PankovThe value
2053b3cff10cSYuri Pankov.Sy name
2054b3cff10cSYuri Pankovto display the dataset name
2055b3cff10cSYuri Pankov.It
2056b3cff10cSYuri PankovThe value
2057b3cff10cSYuri Pankov.Sy space
2058b3cff10cSYuri Pankovto display space usage properties on file systems and volumes. This is a
2059b3cff10cSYuri Pankovshortcut for specifying
2060b3cff10cSYuri Pankov.Fl o Sy name Ns , Ns Sy avail Ns , Ns Sy used Ns , Ns Sy usedsnap Ns , Ns
2061b3cff10cSYuri Pankov.Sy usedds Ns , Ns Sy usedrefreserv Ns , Ns Sy usedchild Fl t
2062b3cff10cSYuri Pankov.Sy filesystem Ns , Ns Sy volume
2063b3cff10cSYuri Pankovsyntax.
2064b3cff10cSYuri Pankov.El
2065b3cff10cSYuri Pankov.It Fl p
2066b3cff10cSYuri PankovDisplay numbers in parsable
2067b3cff10cSYuri Pankov.Pq exact
2068b3cff10cSYuri Pankovvalues.
2069b3cff10cSYuri Pankov.It Fl r
2070b3cff10cSYuri PankovRecursively display any children of the dataset on the command line.
2071b3cff10cSYuri Pankov.Ar depth .
2072b3cff10cSYuri PankovA depth of
2073b3cff10cSYuri Pankov.Sy 1
2074b3cff10cSYuri Pankovwill display only the dataset and its direct children.
2075b3cff10cSYuri Pankov.It Fl s Ar property
2076c10c16deSRichard LoweA property for sorting the output by column in ascending order based on the
2077c10c16deSRichard Lowevalue of the property. The property must be one of the properties described in
2078b3cff10cSYuri Pankovthe
2079b3cff10cSYuri Pankov.Sx Properties
2080b3cff10cSYuri Pankovsection, or the special value
2081b3cff10cSYuri Pankov.Sy name
2082b3cff10cSYuri Pankovto sort by the dataset name. Multiple properties can be specified at one time
2083b3cff10cSYuri Pankovusing multiple
2084b3cff10cSYuri Pankov.Fl s
2085b3cff10cSYuri Pankovproperty options. Multiple
2086b3cff10cSYuri Pankov.Fl s
2087b3cff10cSYuri Pankovoptions are evaluated from left to right in decreasing order of importance. The
2088b3cff10cSYuri Pankovfollowing is a list of sorting criteria:
2089b3cff10cSYuri Pankov.Bl -bullet
2090b3cff10cSYuri Pankov.It
2091c10c16deSRichard LoweNumeric types sort in numeric order.
2092b3cff10cSYuri Pankov.It
2093c10c16deSRichard LoweString types sort in alphabetical order.
2094b3cff10cSYuri Pankov.It
2095b3cff10cSYuri PankovTypes inappropriate for a row sort that row to the literal bottom, regardless of
2096b3cff10cSYuri Pankovthe specified ordering.
2097b3cff10cSYuri Pankov.El
2098b3cff10cSYuri Pankov.Pp
2099b3cff10cSYuri PankovIf no sorting options are specified the existing behavior of
2100b3cff10cSYuri Pankov.Nm zfs Cm list
2101b3cff10cSYuri Pankovis preserved.
2102b3cff10cSYuri Pankov.It Fl t Ar type
2103b3cff10cSYuri PankovA comma-separated list of types to display, where
2104b3cff10cSYuri Pankov.Ar type
2105b3cff10cSYuri Pankovis one of
2106b3cff10cSYuri Pankov.Sy filesystem ,
2107b3cff10cSYuri Pankov.Sy snapshot ,
2108b3cff10cSYuri Pankov.Sy volume ,
2109b3cff10cSYuri Pankov.Sy bookmark ,
2110b3cff10cSYuri Pankovor
2111b3cff10cSYuri Pankov.Sy all .
2112b3cff10cSYuri PankovFor example, specifying
2113b3cff10cSYuri Pankov.Fl t Sy snapshot
2114b3cff10cSYuri Pankovdisplays only snapshots.
2115b3cff10cSYuri Pankov.El
2116b3cff10cSYuri Pankov.It Xo
2117b3cff10cSYuri Pankov.Nm
2118b3cff10cSYuri Pankov.Cm set
2119b3cff10cSYuri Pankov.Ar property Ns = Ns Ar value Oo Ar property Ns = Ns Ar value Oc Ns ...
2120b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume Ns | Ns Ar snapshot Ns ...
2121b3cff10cSYuri Pankov.Xc
212230925561SChris WilliamsonSets the property or list of properties to the given value(s) for each dataset.
2123b3cff10cSYuri PankovOnly some properties can be edited. See the
2124b3cff10cSYuri Pankov.Sx Properties
2125b3cff10cSYuri Pankovsection for more information on what properties can be set and acceptable
2126b3cff10cSYuri Pankovvalues. Numeric values can be specified as exact values, or in a human-readable
2127b3cff10cSYuri Pankovform with a suffix of
2128b3cff10cSYuri Pankov.Sy B , K , M , G , T , P , E , Z
2129b3cff10cSYuri Pankov.Po for bytes, kilobytes, megabytes, gigabytes, terabytes, petabytes, exabytes,
2130b3cff10cSYuri Pankovor zettabytes, respectively
2131b3cff10cSYuri Pankov.Pc .
2132b3cff10cSYuri PankovUser properties can be set on snapshots. For more information, see the
2133b3cff10cSYuri Pankov.Sx User Properties
2134b3cff10cSYuri Pankovsection.
2135b3cff10cSYuri Pankov.It Xo
2136b3cff10cSYuri Pankov.Nm
2137b3cff10cSYuri Pankov.Cm get
2138b3cff10cSYuri Pankov.Op Fl r Ns | Ns Fl d Ar depth
2139b3cff10cSYuri Pankov.Op Fl Hp
2140b3cff10cSYuri Pankov.Oo Fl o Ar field Ns Oo , Ns Ar field Oc Ns ... Oc
2141b3cff10cSYuri Pankov.Oo Fl s Ar source Ns Oo , Ns Ar source Oc Ns ... Oc
2142b3cff10cSYuri Pankov.Oo Fl t Ar type Ns Oo , Ns Ar type Oc Ns ... Oc
2143b3cff10cSYuri Pankov.Cm all | Ar property Ns Oo , Ns Ar property Oc Ns ...
2144b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume Ns | Ns Ar snapshot Ns ...
2145b3cff10cSYuri Pankov.Xc
2146c10c16deSRichard LoweDisplays properties for the given datasets. If no datasets are specified, then
2147c10c16deSRichard Lowethe command displays properties for all datasets on the system. For each
2148c10c16deSRichard Loweproperty, the following columns are displayed:
2149b3cff10cSYuri Pankov.Bd -literal
2150c10c16deSRichard Lowe    name      Dataset name
2151c10c16deSRichard Lowe    property  Property name
2152c10c16deSRichard Lowe    value     Property value
2153c10c16deSRichard Lowe    source    Property source. Can either be local, default,
2154b3cff10cSYuri Pankov              temporary, inherited, or none (-).
2155b3cff10cSYuri Pankov.Ed
2156b3cff10cSYuri Pankov.Pp
2157b3cff10cSYuri PankovAll columns are displayed by default, though this can be controlled by using the
2158b3cff10cSYuri Pankov.Fl o
2159b3cff10cSYuri Pankovoption. This command takes a comma-separated list of properties as described in
2160b3cff10cSYuri Pankovthe
2161b3cff10cSYuri Pankov.Sx Native Properties
2162b3cff10cSYuri Pankovand
2163b3cff10cSYuri Pankov.Sx User Properties
2164b3cff10cSYuri Pankovsections.
2165b3cff10cSYuri Pankov.Pp
2166b3cff10cSYuri PankovThe special value
2167b3cff10cSYuri Pankov.Sy all
2168b3cff10cSYuri Pankovcan be used to display all properties that apply to the given dataset's type
2169b3cff10cSYuri Pankov.Pq filesystem, volume, snapshot, or bookmark .
2170b3cff10cSYuri Pankov.Bl -tag -width "-H"
2171b3cff10cSYuri Pankov.It Fl H
2172b3cff10cSYuri PankovDisplay output in a form more easily parsed by scripts. Any headers are omitted,
2173b3cff10cSYuri Pankovand fields are explicitly separated by a single tab instead of an arbitrary
2174b3cff10cSYuri Pankovamount of space.
2175b3cff10cSYuri Pankov.It Fl d Ar depth
2176c10c16deSRichard LoweRecursively display any children of the dataset, limiting the recursion to
2177b3cff10cSYuri Pankov.Ar depth .
2178b3cff10cSYuri PankovA depth of
2179b3cff10cSYuri Pankov.Sy 1
2180b3cff10cSYuri Pankovwill display only the dataset and its direct children.
2181b3cff10cSYuri Pankov.It Fl o Ar field
2182b3cff10cSYuri PankovA comma-separated list of columns to display.
2183b3cff10cSYuri Pankov.Sy name Ns , Ns Sy property Ns , Ns Sy value Ns , Ns Sy source
2184c10c16deSRichard Loweis the default value.
2185b3cff10cSYuri Pankov.It Fl p
2186b3cff10cSYuri PankovDisplay numbers in parsable
2187b3cff10cSYuri Pankov.Pq exact
2188b3cff10cSYuri Pankovvalues.
2189b3cff10cSYuri Pankov.It Fl r
2190b3cff10cSYuri PankovRecursively display properties for any children.
2191b3cff10cSYuri Pankov.It Fl s Ar source
2192c10c16deSRichard LoweA comma-separated list of sources to display. Those properties coming from a
2193b3cff10cSYuri Pankovsource other than those in this list are ignored. Each source must be one of the
2194b3cff10cSYuri Pankovfollowing:
2195b3cff10cSYuri Pankov.Sy local ,
2196b3cff10cSYuri Pankov.Sy default ,
2197b3cff10cSYuri Pankov.Sy inherited ,
2198b3cff10cSYuri Pankov.Sy temporary ,
2199b3cff10cSYuri Pankovand
2200b3cff10cSYuri Pankov.Sy none .
2201b3cff10cSYuri PankovThe default value is all sources.
2202b3cff10cSYuri Pankov.It Fl t Ar type
2203b3cff10cSYuri PankovA comma-separated list of types to display, where
2204b3cff10cSYuri Pankov.Ar type
2205b3cff10cSYuri Pankovis one of
2206b3cff10cSYuri Pankov.Sy filesystem ,
2207b3cff10cSYuri Pankov.Sy snapshot ,
2208b3cff10cSYuri Pankov.Sy volume ,
2209b3cff10cSYuri Pankov.Sy bookmark ,
2210b3cff10cSYuri Pankovor
2211b3cff10cSYuri Pankov.Sy all .
2212b3cff10cSYuri Pankov.El
2213b3cff10cSYuri Pankov.It Xo
2214b3cff10cSYuri Pankov.Nm
2215b3cff10cSYuri Pankov.Cm inherit
2216b3cff10cSYuri Pankov.Op Fl rS
2217b3cff10cSYuri Pankov.Ar property Ar filesystem Ns | Ns Ar volume Ns | Ns Ar snapshot Ns ...
2218b3cff10cSYuri Pankov.Xc
22195ff8cfa9SPaul B. HensonClears the specified property, causing it to be inherited from an ancestor,
2220b3cff10cSYuri Pankovrestored to default if no ancestor has the property set, or with the
2221b3cff10cSYuri Pankov.Fl S
2222b3cff10cSYuri Pankovoption reverted to the received value if one exists. See the
2223b3cff10cSYuri Pankov.Sx Properties
22245ff8cfa9SPaul B. Hensonsection for a listing of default values, and details on which properties can be
22255ff8cfa9SPaul B. Hensoninherited.
2226b3cff10cSYuri Pankov.Bl -tag -width "-r"
2227b3cff10cSYuri Pankov.It Fl r
2228c10c16deSRichard LoweRecursively inherit the given property for all children.
2229b3cff10cSYuri Pankov.It Fl S
22305ff8cfa9SPaul B. HensonRevert the property to the received value if one exists; otherwise operate as
2231b3cff10cSYuri Pankovif the
2232b3cff10cSYuri Pankov.Fl S
2233b3cff10cSYuri Pankovoption was not specified.
2234b3cff10cSYuri Pankov.El
2235b3cff10cSYuri Pankov.It Xo
2236b3cff10cSYuri Pankov.Nm
2237b3cff10cSYuri Pankov.Cm upgrade
2238b3cff10cSYuri Pankov.Xc
2239c10c16deSRichard LoweDisplays a list of file systems that are not the most recent version.
2240b3cff10cSYuri Pankov.It Xo
2241b3cff10cSYuri Pankov.Nm
2242b3cff10cSYuri Pankov.Cm upgrade
2243b3cff10cSYuri Pankov.Fl v
2244b3cff10cSYuri Pankov.Xc
2245b3cff10cSYuri PankovDisplays a list of currently supported file system versions.
2246b3cff10cSYuri Pankov.It Xo
2247b3cff10cSYuri Pankov.Nm
2248b3cff10cSYuri Pankov.Cm upgrade
2249b3cff10cSYuri Pankov.Op Fl r
2250b3cff10cSYuri Pankov.Op Fl V Ar version
2251b3cff10cSYuri Pankov.Fl a | Ar filesystem
2252b3cff10cSYuri Pankov.Xc
2253c10c16deSRichard LoweUpgrades file systems to a new on-disk version. Once this is done, the file
2254c10c16deSRichard Lowesystems will no longer be accessible on systems running older versions of the
2255b3cff10cSYuri Pankovsoftware.
2256b3cff10cSYuri Pankov.Nm zfs Cm send
2257b3cff10cSYuri Pankovstreams generated from new snapshots of these file systems cannot be accessed on
2258b3cff10cSYuri Pankovsystems running older versions of the software.
2259b3cff10cSYuri Pankov.Pp
2260c10c16deSRichard LoweIn general, the file system version is independent of the pool version. See
2261b3cff10cSYuri Pankov.Xr zpool 1M
2262b3cff10cSYuri Pankovfor information on the
2263b3cff10cSYuri Pankov.Nm zpool Cm upgrade
2264b3cff10cSYuri Pankovcommand.
2265b3cff10cSYuri Pankov.Pp
2266b3cff10cSYuri PankovIn some cases, the file system version and the pool version are interrelated and
2267b3cff10cSYuri Pankovthe pool version must be upgraded before the file system version can be upgraded.
2268b3cff10cSYuri Pankov.Bl -tag -width "-V"
2269b3cff10cSYuri Pankov.It Fl V Ar version
2270b3cff10cSYuri PankovUpgrade to the specified
2271b3cff10cSYuri Pankov.Ar version .
2272b3cff10cSYuri PankovIf the
2273b3cff10cSYuri Pankov.Fl V
2274b3cff10cSYuri Pankovflag is not specified, this command upgrades to the most recent version. This
2275b3cff10cSYuri Pankovoption can only be used to increase the version number, and only up to the most
2276b3cff10cSYuri Pankovrecent version supported by this software.
2277b3cff10cSYuri Pankov.It Fl a
2278c10c16deSRichard LoweUpgrade all file systems on all imported pools.
2279b3cff10cSYuri Pankov.It Ar filesystem
2280c10c16deSRichard LoweUpgrade the specified file system.
2281b3cff10cSYuri Pankov.It Fl r
2282b3cff10cSYuri PankovUpgrade the specified file system and all descendent file systems.
2283b3cff10cSYuri Pankov.El
2284b3cff10cSYuri Pankov.It Xo
2285b3cff10cSYuri Pankov.Nm
2286b3cff10cSYuri Pankov.Cm userspace
2287b3cff10cSYuri Pankov.Op Fl Hinp
2288b3cff10cSYuri Pankov.Oo Fl o Ar field Ns Oo , Ns Ar field Oc Ns ... Oc
2289b3cff10cSYuri Pankov.Oo Fl s Ar field Oc Ns ...
2290b3cff10cSYuri Pankov.Oo Fl S Ar field Oc Ns ...
2291b3cff10cSYuri Pankov.Oo Fl t Ar type Ns Oo , Ns Ar type Oc Ns ... Oc
2292b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar snapshot
2293b3cff10cSYuri Pankov.Xc
2294b3cff10cSYuri PankovDisplays space consumed by, and quotas on, each user in the specified filesystem
2295b3cff10cSYuri Pankovor snapshot. This corresponds to the
2296b3cff10cSYuri Pankov.Sy userused@ Ns Em user
2297b3cff10cSYuri Pankovand
2298b3cff10cSYuri Pankov.Sy userquota@ Ns Em user
2299b3cff10cSYuri Pankovproperties.
2300b3cff10cSYuri Pankov.Bl -tag -width "-H"
2301b3cff10cSYuri Pankov.It Fl H
2302c10c16deSRichard LoweDo not print headers, use tab-delimited output.
2303b3cff10cSYuri Pankov.It Fl S Ar field
2304b3cff10cSYuri PankovSort by this field in reverse order. See
2305b3cff10cSYuri Pankov.Fl s .
2306b3cff10cSYuri Pankov.It Fl i
2307c10c16deSRichard LoweTranslate SID to POSIX ID. The POSIX ID may be ephemeral if no mapping exists.
2308b3cff10cSYuri PankovNormal POSIX interfaces
2309b3cff10cSYuri Pankov.Po for example,
2310b3cff10cSYuri Pankov.Xr stat 2 ,
2311b3cff10cSYuri Pankov.Nm ls Fl l
2312b3cff10cSYuri Pankov.Pc
2313b3cff10cSYuri Pankovperform this translation, so the
2314b3cff10cSYuri Pankov.Fl i
2315b3cff10cSYuri Pankovoption allows the output from
2316b3cff10cSYuri Pankov.Nm zfs Cm userspace
2317b3cff10cSYuri Pankovto be compared directly with those utilities. However,
2318b3cff10cSYuri Pankov.Fl i
2319c10c16deSRichard Lowemay lead to confusion if some files were created by an SMB user before a
2320b3cff10cSYuri PankovSMB-to-POSIX name mapping was established. In such a case, some files will be
2321b3cff10cSYuri Pankovowned by the SMB entity and some by the POSIX entity. However, the
2322b3cff10cSYuri Pankov.Fl i
2323b3cff10cSYuri Pankovoption will report that the POSIX entity has the total usage and quota for both.
2324b3cff10cSYuri Pankov.It Fl n
2325b3cff10cSYuri PankovPrint numeric ID instead of user/group name.
2326b3cff10cSYuri Pankov.It Fl o Ar field Ns Oo , Ns Ar field Oc Ns ...
2327b3cff10cSYuri PankovDisplay only the specified fields from the following set:
2328b3cff10cSYuri Pankov.Sy type ,
2329b3cff10cSYuri Pankov.Sy name ,
2330b3cff10cSYuri Pankov.Sy used ,
2331b3cff10cSYuri Pankov.Sy quota .
2332b3cff10cSYuri PankovThe default is to display all fields.
2333b3cff10cSYuri Pankov.It Fl p
2334b3cff10cSYuri PankovUse exact
2335b3cff10cSYuri Pankov.Pq parsable
2336b3cff10cSYuri Pankovnumeric output.
2337b3cff10cSYuri Pankov.It Fl s Ar field
2338b3cff10cSYuri PankovSort output by this field. The
2339b3cff10cSYuri Pankov.Fl s
2340b3cff10cSYuri Pankovand
2341b3cff10cSYuri Pankov.Fl S
2342b3cff10cSYuri Pankovflags may be specified multiple times to sort first by one field, then by
2343b3cff10cSYuri Pankovanother. The default is
2344b3cff10cSYuri Pankov.Fl s Sy type Fl s Sy name .
2345b3cff10cSYuri Pankov.It Fl t Ar type Ns Oo , Ns Ar type Oc Ns ...
2346b3cff10cSYuri PankovPrint only the specified types from the following set:
2347b3cff10cSYuri Pankov.Sy all ,
2348b3cff10cSYuri Pankov.Sy posixuser ,
2349b3cff10cSYuri Pankov.Sy smbuser ,
2350b3cff10cSYuri Pankov.Sy posixgroup ,
2351b3cff10cSYuri Pankov.Sy smbgroup .
2352b3cff10cSYuri PankovThe default is
2353b3cff10cSYuri Pankov.Fl t Sy posixuser Ns , Ns Sy smbuser .
2354b3cff10cSYuri PankovThe default can be changed to include group types.
2355b3cff10cSYuri Pankov.El
2356b3cff10cSYuri Pankov.It Xo
2357b3cff10cSYuri Pankov.Nm
2358b3cff10cSYuri Pankov.Cm groupspace
2359b3cff10cSYuri Pankov.Op Fl Hinp
2360b3cff10cSYuri Pankov.Oo Fl o Ar field Ns Oo , Ns Ar field Oc Ns ... Oc
2361b3cff10cSYuri Pankov.Oo Fl s Ar field Oc Ns ...
2362b3cff10cSYuri Pankov.Oo Fl S Ar field Oc Ns ...
2363b3cff10cSYuri Pankov.Oo Fl t Ar type Ns Oo , Ns Ar type Oc Ns ... Oc
2364b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar snapshot
2365b3cff10cSYuri Pankov.Xc
2366c10c16deSRichard LoweDisplays space consumed by, and quotas on, each group in the specified
2367b3cff10cSYuri Pankovfilesystem or snapshot. This subcommand is identical to
2368b3cff10cSYuri Pankov.Nm zfs Cm userspace ,
2369b3cff10cSYuri Pankovexcept that the default types to display are
2370b3cff10cSYuri Pankov.Fl t Sy posixgroup Ns , Ns Sy smbgroup .
2371b3cff10cSYuri Pankov.It Xo
2372b3cff10cSYuri Pankov.Nm
2373b3cff10cSYuri Pankov.Cm mount
2374b3cff10cSYuri Pankov.Xc
2375b3cff10cSYuri PankovDisplays all ZFS file systems currently mounted.
2376b3cff10cSYuri Pankov.It Xo
2377b3cff10cSYuri Pankov.Nm
2378b3cff10cSYuri Pankov.Cm mount
2379b3cff10cSYuri Pankov.Op Fl Ov
2380b3cff10cSYuri Pankov.Op Fl o Ar options
2381b3cff10cSYuri Pankov.Fl a | Ar filesystem
2382b3cff10cSYuri Pankov.Xc
2383b3cff10cSYuri PankovMounts ZFS file systems.
2384b3cff10cSYuri Pankov.Bl -tag -width "-O"
2385b3cff10cSYuri Pankov.It Fl O
2386b3cff10cSYuri PankovPerform an overlay mount. See
2387b3cff10cSYuri Pankov.Xr mount 1M
2388b3cff10cSYuri Pankovfor more information.
2389b3cff10cSYuri Pankov.It Fl a
2390b3cff10cSYuri PankovMount all available ZFS file systems. Invoked automatically as part of the boot
2391c10c16deSRichard Loweprocess.
2392b3cff10cSYuri Pankov.It Ar filesystem
2393c10c16deSRichard LoweMount the specified filesystem.
2394b3cff10cSYuri Pankov.It Fl o Ar options
2395b3cff10cSYuri PankovAn optional, comma-separated list of mount options to use temporarily for the
2396b3cff10cSYuri Pankovduration of the mount. See the
2397b3cff10cSYuri Pankov.Sx Temporary Mount Point Properties
2398b3cff10cSYuri Pankovsection for details.
2399b3cff10cSYuri Pankov.It Fl v
2400b3cff10cSYuri PankovReport mount progress.
2401b3cff10cSYuri Pankov.El
2402b3cff10cSYuri Pankov.It Xo
2403b3cff10cSYuri Pankov.Nm
2404b3cff10cSYuri Pankov.Cm unmount
2405b3cff10cSYuri Pankov.Op Fl f
2406b3cff10cSYuri Pankov.Fl a | Ar filesystem Ns | Ns Ar mountpoint
2407b3cff10cSYuri Pankov.Xc
2408b3cff10cSYuri PankovUnmounts currently mounted ZFS file systems.
2409b3cff10cSYuri Pankov.Bl -tag -width "-a"
2410b3cff10cSYuri Pankov.It Fl a
2411b3cff10cSYuri PankovUnmount all available ZFS file systems. Invoked automatically as part of the
2412b3cff10cSYuri Pankovshutdown process.
2413b3cff10cSYuri Pankov.It Ar filesystem Ns | Ns Ar mountpoint
2414b3cff10cSYuri PankovUnmount the specified filesystem. The command can also be given a path to a ZFS
2415b3cff10cSYuri Pankovfile system mount point on the system.
2416b3cff10cSYuri Pankov.It Fl f
2417c10c16deSRichard LoweForcefully unmount the file system, even if it is currently in use.
2418b3cff10cSYuri Pankov.El
2419b3cff10cSYuri Pankov.It Xo
2420b3cff10cSYuri Pankov.Nm
2421b3cff10cSYuri Pankov.Cm share
2422b3cff10cSYuri Pankov.Fl a | Ar filesystem
2423b3cff10cSYuri Pankov.Xc
2424b3cff10cSYuri PankovShares available ZFS file systems.
2425b3cff10cSYuri Pankov.Bl -tag -width "-a"
2426b3cff10cSYuri Pankov.It Fl a
2427b3cff10cSYuri PankovShare all available ZFS file systems. Invoked automatically as part of the boot
2428b3cff10cSYuri Pankovprocess.
2429b3cff10cSYuri Pankov.It Ar filesystem
2430b3cff10cSYuri PankovShare the specified filesystem according to the
2431b3cff10cSYuri Pankov.Sy sharenfs
2432b3cff10cSYuri Pankovand
2433b3cff10cSYuri Pankov.Sy sharesmb
2434b3cff10cSYuri Pankovproperties. File systems are shared when the
2435b3cff10cSYuri Pankov.Sy sharenfs
2436b3cff10cSYuri Pankovor
2437b3cff10cSYuri Pankov.Sy sharesmb
2438b3cff10cSYuri Pankovproperty is set.
2439b3cff10cSYuri Pankov.El
2440b3cff10cSYuri Pankov.It Xo
2441b3cff10cSYuri Pankov.Nm
2442b3cff10cSYuri Pankov.Cm unshare
2443b3cff10cSYuri Pankov.Fl a | Ar filesystem Ns | Ns Ar mountpoint
2444b3cff10cSYuri Pankov.Xc
2445b3cff10cSYuri PankovUnshares currently shared ZFS file systems.
2446b3cff10cSYuri Pankov.Bl -tag -width "-a"
2447b3cff10cSYuri Pankov.It Fl a
2448b3cff10cSYuri PankovUnshare all available ZFS file systems. Invoked automatically as part of the
2449b3cff10cSYuri Pankovshutdown process.
2450b3cff10cSYuri Pankov.It Ar filesystem Ns | Ns Ar mountpoint
2451b3cff10cSYuri PankovUnshare the specified filesystem. The command can also be given a path to a ZFS
2452b3cff10cSYuri Pankovfile system shared on the system.
2453b3cff10cSYuri Pankov.El
2454b3cff10cSYuri Pankov.It Xo
2455b3cff10cSYuri Pankov.Nm
2456b3cff10cSYuri Pankov.Cm bookmark
2457b3cff10cSYuri Pankov.Ar snapshot bookmark
2458b3cff10cSYuri Pankov.Xc
2459b3cff10cSYuri PankovCreates a bookmark of the given snapshot. Bookmarks mark the point in time when
2460b3cff10cSYuri Pankovthe snapshot was created, and can be used as the incremental source for a
2461b3cff10cSYuri Pankov.Nm zfs Cm send
2462b3cff10cSYuri Pankovcommand.
2463b3cff10cSYuri Pankov.Pp
2464b3cff10cSYuri PankovThis feature must be enabled to be used. See
2465b3cff10cSYuri Pankov.Xr zpool-features 5
2466b3cff10cSYuri Pankovfor details on ZFS feature flags and the
2467b3cff10cSYuri Pankov.Sy bookmarks
2468b3cff10cSYuri Pankovfeature.
2469b3cff10cSYuri Pankov.It Xo
2470b3cff10cSYuri Pankov.Nm
2471b3cff10cSYuri Pankov.Cm send
2472b3cff10cSYuri Pankov.Op Fl DLPRenpv
2473b3cff10cSYuri Pankov.Op Oo Fl I Ns | Ns Fl i Oc Ar snapshot
2474b3cff10cSYuri Pankov.Ar snapshot
2475b3cff10cSYuri Pankov.Xc
2476b3cff10cSYuri PankovCreates a stream representation of the second
2477b3cff10cSYuri Pankov.Ar snapshot ,
2478b3cff10cSYuri Pankovwhich is written to standard output. The output can be redirected to a file or
2479b3cff10cSYuri Pankovto a different system
2480b3cff10cSYuri Pankov.Po for example, using
2481b3cff10cSYuri Pankov.Xr ssh 1
2482b3cff10cSYuri Pankov.Pc .
2483b3cff10cSYuri PankovBy default, a full stream is generated.
2484b3cff10cSYuri Pankov.Bl -tag -width "-D"
2485b3cff10cSYuri Pankov.It Fl D
2486b3cff10cSYuri PankovGenerate a deduplicated stream. Blocks which would have been sent multiple times
2487b3cff10cSYuri Pankovin the send stream will only be sent once. The receiving system must also
2488b3cff10cSYuri Pankovsupport this feature to recieve a deduplicated stream. This flag can be used
2489b3cff10cSYuri Pankovregardless of the dataset's
2490b3cff10cSYuri Pankov.Sy dedup
2491b3cff10cSYuri Pankovproperty, but performance will be much better if the filesystem uses a
2492b3cff10cSYuri Pankovdedup-capable checksum
2493b3cff10cSYuri Pankov.Po for example,
2494b3cff10cSYuri Pankov.Sy sha256
2495b3cff10cSYuri Pankov.Pc .
2496b3cff10cSYuri Pankov.It Fl I Ar snapshot
2497c10c16deSRichard LoweGenerate a stream package that sends all intermediary snapshots from the first
2498b3cff10cSYuri Pankovsnapshot to the second snapshot. For example,
2499b3cff10cSYuri Pankov.Fl I Em @a Em fs@d
2500b3cff10cSYuri Pankovis similar to
2501b3cff10cSYuri Pankov.Fl i Em @a Em fs@b Ns ; Fl i Em @b Em fs@c Ns ; Fl i Em @c Em fs@d .
2502b3cff10cSYuri PankovThe incremental source may be specified as with the
2503b3cff10cSYuri Pankov.Fl i
2504b3cff10cSYuri Pankovoption.
2505b3cff10cSYuri Pankov.It Fl L
2506b3cff10cSYuri PankovGenerate a stream which may contain blocks larger than 128KB. This flag has no
2507b3cff10cSYuri Pankoveffect if the
2508b3cff10cSYuri Pankov.Sy large_blocks
2509b3cff10cSYuri Pankovpool feature is disabled, or if the
2510b3cff10cSYuri Pankov.Sy recordsize
2511b3cff10cSYuri Pankovproperty of this filesystem has never been set above 128KB. The receiving system
2512b3cff10cSYuri Pankovmust have the
2513b3cff10cSYuri Pankov.Sy large_blocks
2514b3cff10cSYuri Pankovpool feature enabled as well. See
2515b3cff10cSYuri Pankov.Xr zpool-features 5
2516b3cff10cSYuri Pankovfor details on ZFS feature flags and the
2517b3cff10cSYuri Pankov.Sy large_blocks
2518b3cff10cSYuri Pankovfeature.
2519b3cff10cSYuri Pankov.It Fl P
2520b3cff10cSYuri PankovPrint machine-parsable verbose information about the stream package generated.
2521b3cff10cSYuri Pankov.It Fl R
2522c10c16deSRichard LoweGenerate a replication stream package, which will replicate the specified
2523c10c16deSRichard Lowefile system, and all descendent file systems, up to the named snapshot. When
2524c10c16deSRichard Lowereceived, all properties, snapshots, descendent file systems, and clones are
2525c10c16deSRichard Lowepreserved.
2526b3cff10cSYuri Pankov.Pp
2527b3cff10cSYuri PankovIf the
2528b3cff10cSYuri Pankov.Fl i
2529b3cff10cSYuri Pankovor
2530b3cff10cSYuri Pankov.Fl I
2531b3cff10cSYuri Pankovflags are used in conjunction with the
2532b3cff10cSYuri Pankov.Fl R
2533c10c16deSRichard Loweflag, an incremental replication stream is generated. The current values of
2534c10c16deSRichard Loweproperties, and current snapshot and file system names are set when the stream
2535b3cff10cSYuri Pankovis received. If the
2536b3cff10cSYuri Pankov.Fl F
2537b3cff10cSYuri Pankovflag is specified when this stream is received, snapshots and file systems that
2538b3cff10cSYuri Pankovdo not exist on the sending side are destroyed.
2539b3cff10cSYuri Pankov.It Fl e
2540b3cff10cSYuri PankovGenerate a more compact stream by using
2541b3cff10cSYuri Pankov.Sy WRITE_EMBEDDED
2542b3cff10cSYuri Pankovrecords for blocks which are stored more compactly on disk by the
2543b3cff10cSYuri Pankov.Sy embedded_data
2544b3cff10cSYuri Pankovpool feature. This flag has no effect if the
2545b3cff10cSYuri Pankov.Sy embedded_data
2546b3cff10cSYuri Pankovfeature is disabled. The receiving system must have the
2547b3cff10cSYuri Pankov.Sy embedded_data
2548b3cff10cSYuri Pankovfeature enabled. If the
2549b3cff10cSYuri Pankov.Sy lz4_compress
2550b3cff10cSYuri Pankovfeature is active on the sending system, then the receiving system must have
2551b3cff10cSYuri Pankovthat feature enabled as well. See
2552b3cff10cSYuri Pankov.Xr zpool-features 5
2553b3cff10cSYuri Pankovfor details on ZFS feature flags and the
2554b3cff10cSYuri Pankov.Sy embedded_data
2555b3cff10cSYuri Pankovfeature.
2556b3cff10cSYuri Pankov.It Fl i Ar snapshot
2557b3cff10cSYuri PankovGenerate an incremental stream from the first
2558b3cff10cSYuri Pankov.Ar snapshot
2559b3cff10cSYuri Pankov.Pq the incremental source
2560b3cff10cSYuri Pankovto the second
2561b3cff10cSYuri Pankov.Ar snapshot
2562b3cff10cSYuri Pankov.Pq the incremental target .
2563b3cff10cSYuri PankovThe incremental source can be specified as the last component of the snapshot
2564b3cff10cSYuri Pankovname
2565b3cff10cSYuri Pankov.Po the
2566b3cff10cSYuri Pankov.Sy @
2567b3cff10cSYuri Pankovcharacter and following
2568b3cff10cSYuri Pankov.Pc
2569b3cff10cSYuri Pankovand it is assumed to be from the same file system as the incremental target.
2570b3cff10cSYuri Pankov.Pp
2571b3cff10cSYuri PankovIf the destination is a clone, the source may be the origin snapshot, which must
2572b3cff10cSYuri Pankovbe fully specified
2573b3cff10cSYuri Pankov.Po for example,
2574b3cff10cSYuri Pankov.Em pool/fs@origin ,
2575b3cff10cSYuri Pankovnot just
2576b3cff10cSYuri Pankov.Em @origin
2577b3cff10cSYuri Pankov.Pc .
2578b3cff10cSYuri Pankov.It Fl n
2579b3cff10cSYuri PankovDo a dry-run
2580b3cff10cSYuri Pankov.Pq Qq No-op
2581b3cff10cSYuri Pankovsend. Do not generate any actual send data. This is useful in conjunction with
2582b3cff10cSYuri Pankovthe
2583b3cff10cSYuri Pankov.Fl v
2584b3cff10cSYuri Pankovor
2585b3cff10cSYuri Pankov.Fl P
2586b3cff10cSYuri Pankovflags to determine what data will be sent. In this case, the verbose output will
2587b3cff10cSYuri Pankovbe written to standard output
2588b3cff10cSYuri Pankov.Po contrast with a non-dry-run, where the stream is written to standard output
2589b3cff10cSYuri Pankovand the verbose output goes to standard error
2590b3cff10cSYuri Pankov.Pc .
2591b3cff10cSYuri Pankov.It Fl p
259219b94df9SMatthew AhrensInclude the dataset's properties in the stream. This flag is implicit when
2593b3cff10cSYuri Pankov.Fl R
2594b3cff10cSYuri Pankovis specified. The receiving system must also support this feature.
2595b3cff10cSYuri Pankov.It Fl v
25964e3c9f44SBill PijewskiPrint verbose information about the stream package generated. This information
25974e3c9f44SBill Pijewskiincludes a per-second report of how much data has been sent.
2598b3cff10cSYuri Pankov.Pp
2599c10c16deSRichard LoweThe format of the stream is committed. You will be able to receive your streams
2600b3cff10cSYuri Pankovon future versions of ZFS .
2601b3cff10cSYuri Pankov.El
2602b3cff10cSYuri Pankov.It Xo
2603b3cff10cSYuri Pankov.Nm
2604b3cff10cSYuri Pankov.Cm send
2605b3cff10cSYuri Pankov.Op Fl Le
2606b3cff10cSYuri Pankov.Op Fl i Ar snapshot Ns | Ns Ar bookmark
2607b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume Ns | Ns Ar snapshot
2608b3cff10cSYuri Pankov.Xc
2609b3cff10cSYuri PankovGenerate a send stream, which may be of a filesystem, and may be incremental
2610b3cff10cSYuri Pankovfrom a bookmark. If the destination is a filesystem or volume, the pool must be
2611b3cff10cSYuri Pankovread-only, or the filesystem must not be mounted. When the stream generated from
2612b3cff10cSYuri Pankova filesystem or volume is received, the default snapshot name will be
2613b3cff10cSYuri Pankov.Qq --head-- .
2614b3cff10cSYuri Pankov.Bl -tag -width "-L"
2615b3cff10cSYuri Pankov.It Fl L
2616b3cff10cSYuri PankovGenerate a stream which may contain blocks larger than 128KB. This flag has no
2617b3cff10cSYuri Pankoveffect if the
2618b3cff10cSYuri Pankov.Sy large_blocks
2619b3cff10cSYuri Pankovpool feature is disabled, or if the
2620b3cff10cSYuri Pankov.Sy recordsize
2621b3cff10cSYuri Pankovproperty of this filesystem has never been set above 128KB. The receiving system
2622b3cff10cSYuri Pankovmust have the
2623b3cff10cSYuri Pankov.Sy large_blocks
2624b3cff10cSYuri Pankovpool feature enabled as well. See
2625b3cff10cSYuri Pankov.Xr zpool-features 5
2626b3cff10cSYuri Pankovfor details on ZFS feature flags and the
2627b3cff10cSYuri Pankov.Sy large_blocks
2628b3cff10cSYuri Pankovfeature.
2629b3cff10cSYuri Pankov.It Fl e
2630b3cff10cSYuri PankovGenerate a more compact stream by using
2631b3cff10cSYuri Pankov.Sy WRITE_EMBEDDED
2632b3cff10cSYuri Pankovrecords for blocks which are stored more compactly on disk by the
2633b3cff10cSYuri Pankov.Sy embedded_data
2634b3cff10cSYuri Pankovpool feature. This flag has no effect if the
2635b3cff10cSYuri Pankov.Sy embedded_data
2636b3cff10cSYuri Pankovfeature is disabled. The receiving system must have the
2637b3cff10cSYuri Pankov.Sy embedded_data
2638b3cff10cSYuri Pankovfeature enabled. If the
2639b3cff10cSYuri Pankov.Sy lz4_compress
2640b3cff10cSYuri Pankovfeature is active on the sending system, then the receiving system must have
2641b3cff10cSYuri Pankovthat feature enabled as well. See
2642b3cff10cSYuri Pankov.Xr zpool-features 5
2643b3cff10cSYuri Pankovfor details on ZFS feature flags and the
2644b3cff10cSYuri Pankov.Sy embedded_data
2645b3cff10cSYuri Pankovfeature.
2646b3cff10cSYuri Pankov.It Fl i Ar snapshot Ns | Ns Ar bookmark
264778f17100SMatthew AhrensGenerate an incremental send stream. The incremental source must be an earlier
2648b3cff10cSYuri Pankovsnapshot in the destination's history. It will commonly be an earlier snapshot
2649b3cff10cSYuri Pankovin the destination's file system, in which case it can be specified as the last
2650b3cff10cSYuri Pankovcomponent of the name
2651b3cff10cSYuri Pankov.Po the
2652b3cff10cSYuri Pankov.Sy #
2653b3cff10cSYuri Pankovor
2654b3cff10cSYuri Pankov.Sy @
2655b3cff10cSYuri Pankovcharacter and following
2656b3cff10cSYuri Pankov.Pc .
2657b3cff10cSYuri Pankov.Pp
2658b3cff10cSYuri PankovIf the incremental target is a clone, the incremental source can be the origin
2659b3cff10cSYuri Pankovsnapshot, or an earlier snapshot in the origin's filesystem, or the origin's
2660b3cff10cSYuri Pankovorigin, etc.
2661b3cff10cSYuri Pankov.El
2662b3cff10cSYuri Pankov.It Xo
2663b3cff10cSYuri Pankov.Nm
2664*9c3fd121SMatthew Ahrens.Cm send
2665*9c3fd121SMatthew Ahrens.Op Fl Penv
2666*9c3fd121SMatthew Ahrens.Fl t
2667*9c3fd121SMatthew Ahrens.Ar receive_resume_token
2668*9c3fd121SMatthew Ahrens.Xc
2669*9c3fd121SMatthew AhrensCreates a send stream which resumes an interrupted receive.  The
2670*9c3fd121SMatthew Ahrens.Ar receive_resume_token
2671*9c3fd121SMatthew Ahrensis the value of this property on the filesystem
2672*9c3fd121SMatthew Ahrensor volume that was being received into.  See the documentation for
2673*9c3fd121SMatthew Ahrens.Sy zfs receive -s
2674*9c3fd121SMatthew Ahrensfor more details.
2675*9c3fd121SMatthew Ahrens.It Xo
2676*9c3fd121SMatthew Ahrens.Nm
2677b3cff10cSYuri Pankov.Cm receive
2678*9c3fd121SMatthew Ahrens.Op Fl Fnsuv
2679a2cdcdd2SPaul Dagnelie.Op Fl o Sy origin Ns = Ns Ar snapshot
2680b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume Ns | Ns Ar snapshot
2681c10c16deSRichard Lowe.br
2682b3cff10cSYuri Pankov.Nm
2683b3cff10cSYuri Pankov.Cm receive
2684*9c3fd121SMatthew Ahrens.Op Fl Fnsuv
2685b3cff10cSYuri Pankov.Op Fl d Ns | Ns Fl e
2686a2cdcdd2SPaul Dagnelie.Op Fl o Sy origin Ns = Ns Ar snapshot
2687b3cff10cSYuri Pankov.Ar filesystem
2688b3cff10cSYuri Pankov.Xc
2689c10c16deSRichard LoweCreates a snapshot whose contents are as specified in the stream provided on
2690c10c16deSRichard Lowestandard input. If a full stream is received, then a new file system is created
2691b3cff10cSYuri Pankovas well. Streams are created using the
2692b3cff10cSYuri Pankov.Nm zfs Cm send
2693b3cff10cSYuri Pankovsubcommand, which by default creates a full stream.
2694b3cff10cSYuri Pankov.Nm zfs Cm recv
2695b3cff10cSYuri Pankovcan be used as an alias for
2696b3cff10cSYuri Pankov.Nm zfs Cm receive.
2697b3cff10cSYuri Pankov.Pp
2698c10c16deSRichard LoweIf an incremental stream is received, then the destination file system must
2699c10c16deSRichard Lowealready exist, and its most recent snapshot must match the incremental stream's
2700b3cff10cSYuri Pankovsource. For
2701b3cff10cSYuri Pankov.Sy zvols ,
2702b3cff10cSYuri Pankovthe destination device link is destroyed and recreated, which means the
2703b3cff10cSYuri Pankov.Sy zvol
2704b3cff10cSYuri Pankovcannot be accessed during the
2705b3cff10cSYuri Pankov.Cm receive
2706b3cff10cSYuri Pankovoperation.
2707b3cff10cSYuri Pankov.Pp
2708c10c16deSRichard LoweWhen a snapshot replication package stream that is generated by using the
2709b3cff10cSYuri Pankov.Nm zfs Cm send Fl R
2710b3cff10cSYuri Pankovcommand is received, any snapshots that do not exist on the sending location are
2711b3cff10cSYuri Pankovdestroyed by using the
2712b3cff10cSYuri Pankov.Nm zfs Cm destroy Fl d
2713c10c16deSRichard Lowecommand.
2714b3cff10cSYuri Pankov.Pp
2715b3cff10cSYuri PankovThe name of the snapshot
2716b3cff10cSYuri Pankov.Pq and file system, if a full stream is received
2717b3cff10cSYuri Pankovthat this subcommand creates depends on the argument type and the use of the
2718b3cff10cSYuri Pankov.Fl d
2719b3cff10cSYuri Pankovor
2720b3cff10cSYuri Pankov.Fl e
2721b3cff10cSYuri Pankovoptions.
2722b3cff10cSYuri Pankov.Pp
2723b3cff10cSYuri PankovIf the argument is a snapshot name, the specified
2724b3cff10cSYuri Pankov.Ar snapshot
2725b3cff10cSYuri Pankovis created. If the argument is a file system or volume name, a snapshot with the
2726b3cff10cSYuri Pankovsame name as the sent snapshot is created within the specified
2727b3cff10cSYuri Pankov.Ar filesystem
2728b3cff10cSYuri Pankovor
2729b3cff10cSYuri Pankov.Ar volume .
2730b3cff10cSYuri PankovIf neither of the
2731b3cff10cSYuri Pankov.Fl d
2732b3cff10cSYuri Pankovor
2733b3cff10cSYuri Pankov.Fl e
2734b3cff10cSYuri Pankovoptions are specified, the provided target snapshot name is used exactly as
2735b3cff10cSYuri Pankovprovided.
2736b3cff10cSYuri Pankov.Pp
2737b3cff10cSYuri PankovThe
2738b3cff10cSYuri Pankov.Fl d
2739b3cff10cSYuri Pankovand
2740b3cff10cSYuri Pankov.Fl e
2741b3cff10cSYuri Pankovoptions cause the file system name of the target snapshot to be determined by
2742b3cff10cSYuri Pankovappending a portion of the sent snapshot's name to the specified target
2743b3cff10cSYuri Pankov.Ar filesystem .
2744b3cff10cSYuri PankovIf the
2745b3cff10cSYuri Pankov.Fl d
2746b3cff10cSYuri Pankovoption is specified, all but the first element of the sent snapshot's file
2747b3cff10cSYuri Pankovsystem path
2748b3cff10cSYuri Pankov.Pq usually the pool name
2749b3cff10cSYuri Pankovis used and any required intermediate file systems within the specified one are
2750b3cff10cSYuri Pankovcreated. If the
2751b3cff10cSYuri Pankov.Fl e
2752b3cff10cSYuri Pankovoption is specified, then only the last element of the sent snapshot's file
2753b3cff10cSYuri Pankovsystem name
2754b3cff10cSYuri Pankov.Pq i.e. the name of the source file system itself
2755b3cff10cSYuri Pankovis used as the target file system name.
2756b3cff10cSYuri Pankov.Bl -tag -width "-F"
2757b3cff10cSYuri Pankov.It Fl F
2758b3cff10cSYuri PankovForce a rollback of the file system to the most recent snapshot before
2759b3cff10cSYuri Pankovperforming the receive operation. If receiving an incremental replication stream
2760b3cff10cSYuri Pankov.Po for example, one generated by
2761b3cff10cSYuri Pankov.Nm zfs Cm send Fl R Op Fl i Ns | Ns Fl I
2762b3cff10cSYuri Pankov.Pc ,
2763b3cff10cSYuri Pankovdestroy snapshots and file systems that do not exist on the sending side.
2764b3cff10cSYuri Pankov.It Fl d
2765b3cff10cSYuri PankovDiscard the first element of the sent snapshot's file system name, using the
2766b3cff10cSYuri Pankovremaining elements to determine the name of the target file system for the new
2767b3cff10cSYuri Pankovsnapshot as described in the paragraph above.
2768b3cff10cSYuri Pankov.It Fl e
2769b3cff10cSYuri PankovDiscard all but the last element of the sent snapshot's file system name, using
2770b3cff10cSYuri Pankovthat element to determine the name of the target file system for the new
2771b3cff10cSYuri Pankovsnapshot as described in the paragraph above.
2772b3cff10cSYuri Pankov.It Fl n
2773b3cff10cSYuri PankovDo not actually receive the stream. This can be useful in conjunction with the
2774b3cff10cSYuri Pankov.Fl v
2775b3cff10cSYuri Pankovoption to verify the name the receive operation would use.
2776a2cdcdd2SPaul Dagnelie.It Fl o Sy origin Ns = Ns Ar snapshot
2777a2cdcdd2SPaul DagnelieForces the stream to be received as a clone of the given snapshot.
2778a2cdcdd2SPaul DagnelieThis is only valid if the stream is an incremental stream whose source
2779a2cdcdd2SPaul Dagnelieis the same as the provided origin.
2780b3cff10cSYuri Pankov.It Fl u
2781c10c16deSRichard LoweFile system that is associated with the received stream is not mounted.
2782b3cff10cSYuri Pankov.It Fl v
2783c10c16deSRichard LowePrint verbose information about the stream and the time required to perform the
2784c10c16deSRichard Lowereceive operation.
2785*9c3fd121SMatthew Ahrens.It Fl s
2786*9c3fd121SMatthew AhrensIf the receive is interrupted, save the partially received state, rather
2787*9c3fd121SMatthew Ahrensthan deleting it.  Interruption may be due to premature termination of
2788*9c3fd121SMatthew Ahrensthe stream
2789*9c3fd121SMatthew Ahrens.Po e.g. due to network failure or failure of the remote system
2790*9c3fd121SMatthew Ahrensif the stream is being read over a network connection
2791*9c3fd121SMatthew Ahrens.Pc ,
2792*9c3fd121SMatthew Ahrensa checksum error in the stream, termination of the
2793*9c3fd121SMatthew Ahrens.Nm zfs Cm receive
2794*9c3fd121SMatthew Ahrensprocess, or unclean shutdown of the system.
2795*9c3fd121SMatthew Ahrens.Pp
2796*9c3fd121SMatthew AhrensThe receive can be resumed with a stream generated by
2797*9c3fd121SMatthew Ahrens.Nm zfs Cm send Fl t Ar token ,
2798*9c3fd121SMatthew Ahrenswhere the
2799*9c3fd121SMatthew Ahrens.Ar token
2800*9c3fd121SMatthew Ahrensis the value of the
2801*9c3fd121SMatthew Ahrens.Sy receive_resume_token
2802*9c3fd121SMatthew Ahrensproperty of the filesystem or volume which is received into.
2803*9c3fd121SMatthew Ahrens.Pp
2804*9c3fd121SMatthew AhrensTo use this flag, the storage pool must have the
2805*9c3fd121SMatthew Ahrens.Sy extensible_dataset
2806*9c3fd121SMatthew Ahrensfeature enabled.  See
2807*9c3fd121SMatthew Ahrens.Xr zpool-features 5
2808*9c3fd121SMatthew Ahrensfor details on ZFS feature flags.
2809b3cff10cSYuri Pankov.El
2810b3cff10cSYuri Pankov.It Xo
2811b3cff10cSYuri Pankov.Nm
2812*9c3fd121SMatthew Ahrens.Cm receive
2813*9c3fd121SMatthew Ahrens.Fl A
2814*9c3fd121SMatthew Ahrens.Ar filesystem Ns | Ns Ar volume
2815*9c3fd121SMatthew Ahrens.Xc
2816*9c3fd121SMatthew AhrensAbort an interrupted
2817*9c3fd121SMatthew Ahrens.Nm zfs Cm receive Fl s ,
2818*9c3fd121SMatthew Ahrensdeleting its saved partially received state.
2819*9c3fd121SMatthew Ahrens.It Xo
2820*9c3fd121SMatthew Ahrens.Nm
2821b3cff10cSYuri Pankov.Cm allow
2822b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
2823b3cff10cSYuri Pankov.Xc
2824c10c16deSRichard LoweDisplays permissions that have been delegated on the specified filesystem or
2825b3cff10cSYuri Pankovvolume. See the other forms of
2826b3cff10cSYuri Pankov.Nm zfs Cm allow
2827b3cff10cSYuri Pankovfor more information.
2828b3cff10cSYuri Pankov.It Xo
2829b3cff10cSYuri Pankov.Nm
2830b3cff10cSYuri Pankov.Cm allow
2831b3cff10cSYuri Pankov.Op Fl dglu
2832b3cff10cSYuri Pankov.Ar user Ns | Ns Ar group Ns Oo , Ns Ar user Ns | Ns Ar group Oc Ns ...
2833b3cff10cSYuri Pankov.Ar perm Ns | Ns @ Ns Ar setname Ns Oo , Ns Ar perm Ns | Ns @ Ns
2834b3cff10cSYuri Pankov.Ar setname Oc Ns ...
2835b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
2836c10c16deSRichard Lowe.br
2837b3cff10cSYuri Pankov.Nm
2838b3cff10cSYuri Pankov.Cm allow
2839b3cff10cSYuri Pankov.Op Fl dl
2840b3cff10cSYuri Pankov.Fl e Ns | Ns Sy everyone
2841b3cff10cSYuri Pankov.Ar perm Ns | Ns @ Ns Ar setname Ns Oo , Ns Ar perm Ns | Ns @ Ns
2842b3cff10cSYuri Pankov.Ar setname Oc Ns ...
2843b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
2844b3cff10cSYuri Pankov.Xc
2845b3cff10cSYuri PankovDelegates ZFS administration permission for the file systems to non-privileged
2846b3cff10cSYuri Pankovusers.
2847b3cff10cSYuri Pankov.Bl -tag -width "-d"
2848b3cff10cSYuri Pankov.It Fl d
2849b3cff10cSYuri PankovAllow only for the descendent file systems.
2850b3cff10cSYuri Pankov.It Fl e Ns | Ns Sy everyone
285152fd7480SMarcel TelkaSpecifies that the permissions be delegated to everyone.
2852b3cff10cSYuri Pankov.It Fl g Ar group Ns Oo , Ns Ar group Oc Ns ...
2853b3cff10cSYuri PankovExplicitly specify that permissions are delegated to the group.
2854b3cff10cSYuri Pankov.It Fl l
2855b3cff10cSYuri PankovAllow
2856b3cff10cSYuri Pankov.Qq locally
2857b3cff10cSYuri Pankovonly for the specified file system.
2858b3cff10cSYuri Pankov.It Fl u Ar user Ns Oo , Ns Ar user Oc Ns ...
2859b3cff10cSYuri PankovExplicitly specify that permissions are delegated to the user.
2860b3cff10cSYuri Pankov.It Ar user Ns | Ns Ar group Ns Oo , Ns Ar user Ns | Ns Ar group Oc Ns ...
2861b3cff10cSYuri PankovSpecifies to whom the permissions are delegated. Multiple entities can be
2862b3cff10cSYuri Pankovspecified as a comma-separated list. If neither of the
2863b3cff10cSYuri Pankov.Fl gu
2864b3cff10cSYuri Pankovoptions are specified, then the argument is interpreted preferentially as the
2865b3cff10cSYuri Pankovkeyword
2866b3cff10cSYuri Pankov.Sy everyone ,
2867b3cff10cSYuri Pankovthen as a user name, and lastly as a group name. To specify a user or group
2868b3cff10cSYuri Pankovnamed
2869b3cff10cSYuri Pankov.Qq everyone ,
2870b3cff10cSYuri Pankovuse the
2871b3cff10cSYuri Pankov.Fl g
2872b3cff10cSYuri Pankovor
2873b3cff10cSYuri Pankov.Fl u
2874b3cff10cSYuri Pankovoptions. To specify a group with the same name as a user, use the
2875b3cff10cSYuri Pankov.Fl g
2876b3cff10cSYuri Pankovoptions.
2877b3cff10cSYuri Pankov.It Xo
2878b3cff10cSYuri Pankov.Ar perm Ns | Ns @ Ns Ar setname Ns Oo , Ns Ar perm Ns | Ns @ Ns
2879b3cff10cSYuri Pankov.Ar setname Oc Ns ...
2880b3cff10cSYuri Pankov.Xc
2881b3cff10cSYuri PankovThe permissions to delegate. Multiple permissions may be specified as a
2882b3cff10cSYuri Pankovcomma-separated list. Permission names are the same as ZFS subcommand and
2883b3cff10cSYuri Pankovproperty names. See the property list below. Property set names,
2884b3cff10cSYuri Pankovwhich begin with
2885b3cff10cSYuri Pankov.Sy @ ,
2886b3cff10cSYuri Pankovmay be specified. See the
2887b3cff10cSYuri Pankov.Fl s
2888b3cff10cSYuri Pankovform below for details.
2889b3cff10cSYuri Pankov.El
2890b3cff10cSYuri Pankov.Pp
2891b3cff10cSYuri PankovIf neither of the
2892b3cff10cSYuri Pankov.Fl dl
2893c10c16deSRichard Loweoptions are specified, or both are, then the permissions are allowed for the
2894b3cff10cSYuri Pankovfile system or volume, and all of its descendents.
2895b3cff10cSYuri Pankov.Pp
2896b3cff10cSYuri PankovPermissions are generally the ability to use a ZFS subcommand or change a ZFS
2897b3cff10cSYuri Pankovproperty. The following permissions are available:
2898b3cff10cSYuri Pankov.Bd -literal
2899c10c16deSRichard LoweNAME             TYPE           NOTES
2900c10c16deSRichard Loweallow            subcommand     Must also have the permission that is being
2901c10c16deSRichard Lowe                                allowed
2902c10c16deSRichard Loweclone            subcommand     Must also have the 'create' ability and 'mount'
2903c10c16deSRichard Lowe                                ability in the origin file system
2904c10c16deSRichard Lowecreate           subcommand     Must also have the 'mount' ability
2905c10c16deSRichard Lowedestroy          subcommand     Must also have the 'mount' ability
29063b8be6bfSRichard Lowediff             subcommand     Allows lookup of paths within a dataset
29073b8be6bfSRichard Lowe                                given an object number, and the ability to
29083b8be6bfSRichard Lowe                                create snapshots necessary to 'zfs diff'.
2909c10c16deSRichard Lowemount            subcommand     Allows mount/umount of ZFS datasets
2910c10c16deSRichard Lowepromote          subcommand     Must also have the 'mount'
2911c10c16deSRichard Lowe                                and 'promote' ability in the origin file system
2912c10c16deSRichard Lowereceive          subcommand     Must also have the 'mount' and 'create' ability
2913c10c16deSRichard Lowerename           subcommand     Must also have the 'mount' and 'create'
2914c10c16deSRichard Lowe                                ability in the new parent
2915c10c16deSRichard Lowerollback         subcommand     Must also have the 'mount' ability
2916c10c16deSRichard Lowesend             subcommand
2917c10c16deSRichard Loweshare            subcommand     Allows sharing file systems over NFS or SMB
2918c10c16deSRichard Lowe                                protocols
2919c10c16deSRichard Lowesnapshot         subcommand     Must also have the 'mount' ability
2920b3cff10cSYuri Pankov
2921c10c16deSRichard Lowegroupquota       other          Allows accessing any groupquota@... property
2922c10c16deSRichard Lowegroupused        other          Allows reading any groupused@... property
2923c10c16deSRichard Loweuserprop         other          Allows changing any user property
2924c10c16deSRichard Loweuserquota        other          Allows accessing any userquota@... property
2925c10c16deSRichard Loweuserused         other          Allows reading any userused@... property
2926c10c16deSRichard Lowe
2927c10c16deSRichard Loweaclinherit       property
2928c10c16deSRichard Loweaclmode          property
2929c10c16deSRichard Loweatime            property
2930c10c16deSRichard Lowecanmount         property
2931c10c16deSRichard Lowecasesensitivity  property
2932c10c16deSRichard Lowechecksum         property
2933c10c16deSRichard Lowecompression      property
2934c10c16deSRichard Lowecopies           property
2935c10c16deSRichard Lowedevices          property
2936c10c16deSRichard Loweexec             property
2937a2afb611SJerry Jelinekfilesystem_limit property
2938c10c16deSRichard Lowemountpoint       property
2939c10c16deSRichard Lowenbmand           property
2940c10c16deSRichard Lowenormalization    property
2941c10c16deSRichard Loweprimarycache     property
2942c10c16deSRichard Lowequota            property
2943c10c16deSRichard Lowereadonly         property
2944c10c16deSRichard Lowerecordsize       property
2945c10c16deSRichard Lowerefquota         property
2946c10c16deSRichard Lowerefreservation   property
2947c10c16deSRichard Lowereservation      property
2948c10c16deSRichard Lowesecondarycache   property
2949c10c16deSRichard Lowesetuid           property
2950c10c16deSRichard Lowesharenfs         property
2951c10c16deSRichard Lowesharesmb         property
2952c10c16deSRichard Lowesnapdir          property
2953a2afb611SJerry Jelineksnapshot_limit   property
2954c10c16deSRichard Loweutf8only         property
2955c10c16deSRichard Loweversion          property
2956c10c16deSRichard Lowevolblocksize     property
2957c10c16deSRichard Lowevolsize          property
2958c10c16deSRichard Lowevscan            property
2959c10c16deSRichard Lowexattr            property
2960c10c16deSRichard Lowezoned            property
2961b3cff10cSYuri Pankov.Ed
2962b3cff10cSYuri Pankov.It Xo
2963b3cff10cSYuri Pankov.Nm
2964b3cff10cSYuri Pankov.Cm allow
2965b3cff10cSYuri Pankov.Fl c
2966b3cff10cSYuri Pankov.Ar perm Ns | Ns @ Ns Ar setname Ns Oo , Ns Ar perm Ns | Ns @ Ns
2967b3cff10cSYuri Pankov.Ar setname Oc Ns ...
2968b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
2969b3cff10cSYuri Pankov.Xc
2970b3cff10cSYuri PankovSets
2971b3cff10cSYuri Pankov.Qq create time
2972b3cff10cSYuri Pankovpermissions. These permissions are granted
2973b3cff10cSYuri Pankov.Pq locally
2974b3cff10cSYuri Pankovto the creator of any newly-created descendent file system.
2975b3cff10cSYuri Pankov.It Xo
2976b3cff10cSYuri Pankov.Nm
2977b3cff10cSYuri Pankov.Cm allow
2978b3cff10cSYuri Pankov.Fl s No @ Ns Ar setname
2979b3cff10cSYuri Pankov.Ar perm Ns | Ns @ Ns Ar setname Ns Oo , Ns Ar perm Ns | Ns @ Ns
2980b3cff10cSYuri Pankov.Ar setname Oc Ns ...
2981b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
2982b3cff10cSYuri Pankov.Xc
2983c10c16deSRichard LoweDefines or adds permissions to a permission set. The set can be used by other
2984b3cff10cSYuri Pankov.Nm zfs Cm allow
2985b3cff10cSYuri Pankovcommands for the specified file system and its descendents. Sets are evaluated
2986b3cff10cSYuri Pankovdynamically, so changes to a set are immediately reflected. Permission sets
2987b3cff10cSYuri Pankovfollow the same naming restrictions as ZFS file systems, but the name must begin
2988b3cff10cSYuri Pankovwith
2989b3cff10cSYuri Pankov.Sy @ ,
2990b3cff10cSYuri Pankovand can be no more than 64 characters long.
2991b3cff10cSYuri Pankov.It Xo
2992b3cff10cSYuri Pankov.Nm
2993b3cff10cSYuri Pankov.Cm unallow
2994b3cff10cSYuri Pankov.Op Fl dglru
2995b3cff10cSYuri Pankov.Ar user Ns | Ns Ar group Ns Oo , Ns Ar user Ns | Ns Ar group Oc Ns ...
2996b3cff10cSYuri Pankov.Oo Ar perm Ns | Ns @ Ns Ar setname Ns Oo , Ns Ar perm Ns | Ns @ Ns
2997b3cff10cSYuri Pankov.Ar setname Oc Ns ... Oc
2998b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
2999c10c16deSRichard Lowe.br
3000b3cff10cSYuri Pankov.Nm
3001b3cff10cSYuri Pankov.Cm unallow
3002b3cff10cSYuri Pankov.Op Fl dlr
3003b3cff10cSYuri Pankov.Fl e Ns | Ns Sy everyone
3004b3cff10cSYuri Pankov.Oo Ar perm Ns | Ns @ Ns Ar setname Ns Oo , Ns Ar perm Ns | Ns @ Ns
3005b3cff10cSYuri Pankov.Ar setname Oc Ns ... Oc
3006b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
3007c10c16deSRichard Lowe.br
3008b3cff10cSYuri Pankov.Nm
3009b3cff10cSYuri Pankov.Cm unallow
3010b3cff10cSYuri Pankov.Op Fl r
3011b3cff10cSYuri Pankov.Fl c
3012b3cff10cSYuri Pankov.Oo Ar perm Ns | Ns @ Ns Ar setname Ns Oo , Ns Ar perm Ns | Ns @ Ns
3013b3cff10cSYuri Pankov.Ar setname Oc Ns ... Oc
3014b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
3015b3cff10cSYuri Pankov.Xc
3016b3cff10cSYuri PankovRemoves permissions that were granted with the
3017b3cff10cSYuri Pankov.Nm zfs Cm allow
3018b3cff10cSYuri Pankovcommand. No permissions are explicitly denied, so other permissions granted are
3019b3cff10cSYuri Pankovstill in effect. For example, if the permission is granted by an ancestor. If no
3020b3cff10cSYuri Pankovpermissions are specified, then all permissions for the specified
3021b3cff10cSYuri Pankov.Ar user ,
3022b3cff10cSYuri Pankov.Ar group ,
3023b3cff10cSYuri Pankovor
3024b3cff10cSYuri Pankov.Sy everyone
3025b3cff10cSYuri Pankovare removed. Specifying
3026b3cff10cSYuri Pankov.Sy everyone
3027b3cff10cSYuri Pankov.Po or using the
3028b3cff10cSYuri Pankov.Fl e
3029b3cff10cSYuri Pankovoption
3030b3cff10cSYuri Pankov.Pc
3031b3cff10cSYuri Pankovonly removes the permissions that were granted to everyone, not all permissions
3032b3cff10cSYuri Pankovfor every user and group. See the
3033b3cff10cSYuri Pankov.Nm zfs Cm allow
3034b3cff10cSYuri Pankovcommand for a description of the
3035b3cff10cSYuri Pankov.Fl ldugec
3036b3cff10cSYuri Pankovoptions.
3037b3cff10cSYuri Pankov.Bl -tag -width "-r"
3038b3cff10cSYuri Pankov.It Fl r
3039c10c16deSRichard LoweRecursively remove the permissions from this file system and all descendents.
3040b3cff10cSYuri Pankov.El
3041b3cff10cSYuri Pankov.It Xo
3042b3cff10cSYuri Pankov.Nm
3043b3cff10cSYuri Pankov.Cm unallow
3044b3cff10cSYuri Pankov.Op Fl r
3045b3cff10cSYuri Pankov.Fl s @ Ns Ar setname
3046b3cff10cSYuri Pankov.Oo Ar perm Ns | Ns @ Ns Ar setname Ns Oo , Ns Ar perm Ns | Ns @ Ns
3047b3cff10cSYuri Pankov.Ar setname Oc Ns ... Oc
3048b3cff10cSYuri Pankov.Ar filesystem Ns | Ns Ar volume
3049b3cff10cSYuri Pankov.Xc
3050b3cff10cSYuri PankovRemoves permissions from a permission set. If no permissions are specified, then
3051b3cff10cSYuri Pankovall permissions are removed, thus removing the set entirely.
3052b3cff10cSYuri Pankov.It Xo
3053b3cff10cSYuri Pankov.Nm
3054b3cff10cSYuri Pankov.Cm hold
3055b3cff10cSYuri Pankov.Op Fl r
3056b3cff10cSYuri Pankov.Ar tag Ar snapshot Ns ...
3057b3cff10cSYuri Pankov.Xc
3058b3cff10cSYuri PankovAdds a single reference, named with the
3059b3cff10cSYuri Pankov.Ar tag
3060b3cff10cSYuri Pankovargument, to the specified snapshot or snapshots. Each snapshot has its own tag
3061b3cff10cSYuri Pankovnamespace, and tags must be unique within that space.
3062b3cff10cSYuri Pankov.Pp
3063c10c16deSRichard LoweIf a hold exists on a snapshot, attempts to destroy that snapshot by using the
3064b3cff10cSYuri Pankov.Nm zfs Cm destroy
3065b3cff10cSYuri Pankovcommand return
3066b3cff10cSYuri Pankov.Er EBUSY .
3067b3cff10cSYuri Pankov.Bl -tag -width "-r"
3068b3cff10cSYuri Pankov.It Fl r
3069b3cff10cSYuri PankovSpecifies that a hold with the given tag is applied recursively to the snapshots
3070b3cff10cSYuri Pankovof all descendent file systems.
3071b3cff10cSYuri Pankov.El
3072b3cff10cSYuri Pankov.It Xo
3073b3cff10cSYuri Pankov.Nm
3074b3cff10cSYuri Pankov.Cm holds
3075b3cff10cSYuri Pankov.Op Fl r
3076b3cff10cSYuri Pankov.Ar snapshot Ns ...
3077b3cff10cSYuri Pankov.Xc
3078c10c16deSRichard LoweLists all existing user references for the given snapshot or snapshots.
3079b3cff10cSYuri Pankov.Bl -tag -width "-r"
3080b3cff10cSYuri Pankov.It Fl r
3081c10c16deSRichard LoweLists the holds that are set on the named descendent snapshots, in addition to
3082c10c16deSRichard Lowelisting the holds on the named snapshot.
3083b3cff10cSYuri Pankov.El
3084b3cff10cSYuri Pankov.It Xo
3085b3cff10cSYuri Pankov.Nm
3086b3cff10cSYuri Pankov.Cm release
3087b3cff10cSYuri Pankov.Op Fl r
3088b3cff10cSYuri Pankov.Ar tag Ar snapshot Ns ...
3089b3cff10cSYuri Pankov.Xc
3090b3cff10cSYuri PankovRemoves a single reference, named with the
3091b3cff10cSYuri Pankov.Ar tag
3092b3cff10cSYuri Pankovargument, from the specified snapshot or snapshots. The tag must already exist
3093b3cff10cSYuri Pankovfor each snapshot. If a hold exists on a snapshot, attempts to destroy that
3094b3cff10cSYuri Pankovsnapshot by using the
3095b3cff10cSYuri Pankov.Nm zfs Cm destroy
3096b3cff10cSYuri Pankovcommand return
3097b3cff10cSYuri Pankov.Er EBUSY .
3098b3cff10cSYuri Pankov.Bl -tag -width "-r"
3099b3cff10cSYuri Pankov.It Fl r
3100c10c16deSRichard LoweRecursively releases a hold with the given tag on the snapshots of all
3101c10c16deSRichard Lowedescendent file systems.
3102b3cff10cSYuri Pankov.El
3103b3cff10cSYuri Pankov.It Xo
3104b3cff10cSYuri Pankov.Nm
3105b3cff10cSYuri Pankov.Cm diff
3106b3cff10cSYuri Pankov.Op Fl FHt
3107b3cff10cSYuri Pankov.Ar snapshot Ar snapshot Ns | Ns Ar filesystem
3108b3cff10cSYuri Pankov.Xc
31093b8be6bfSRichard LoweDisplay the difference between a snapshot of a given filesystem and another
31103b8be6bfSRichard Lowesnapshot of that filesystem from a later time or the current contents of the
3111b3cff10cSYuri Pankovfilesystem. The first column is a character indicating the type of change, the
3112b3cff10cSYuri Pankovother columns indicate pathname, new pathname
3113b3cff10cSYuri Pankov.Pq in case of rename ,
3114b3cff10cSYuri Pankovchange in link count, and optionally file type and/or change time. The types of
3115b3cff10cSYuri Pankovchange are:
3116b3cff10cSYuri Pankov.Bd -literal
31173b8be6bfSRichard Lowe-       The path has been removed
31183b8be6bfSRichard Lowe+       The path has been created
31193b8be6bfSRichard LoweM       The path has been modified
31203b8be6bfSRichard LoweR       The path has been renamed
3121b3cff10cSYuri Pankov.Ed
3122b3cff10cSYuri Pankov.Bl -tag -width "-F"
3123b3cff10cSYuri Pankov.It Fl F
3124b3cff10cSYuri PankovDisplay an indication of the type of file, in a manner similar to the
3125b3cff10cSYuri Pankov.Fl
3126b3cff10cSYuri Pankovoption of
3127b3cff10cSYuri Pankov.Xr ls 1 .
3128b3cff10cSYuri Pankov.Bd -literal
31293b8be6bfSRichard LoweB       Block device
31303b8be6bfSRichard LoweC       Character device
31313b8be6bfSRichard Lowe/       Directory
31323b8be6bfSRichard Lowe>       Door
31333b8be6bfSRichard Lowe|       Named pipe
31343b8be6bfSRichard Lowe@       Symbolic link
31353b8be6bfSRichard LoweP       Event port
31363b8be6bfSRichard Lowe=       Socket
31373b8be6bfSRichard LoweF       Regular file
3138b3cff10cSYuri Pankov.Ed
3139b3cff10cSYuri Pankov.It Fl H
3140b3cff10cSYuri PankovGive more parsable tab-separated output, without header lines and without
3141b3cff10cSYuri Pankovarrows.
3142b3cff10cSYuri Pankov.It Fl t
31433b8be6bfSRichard LoweDisplay the path's inode change time as the first column of output.
3144b3cff10cSYuri Pankov.El
3145b3cff10cSYuri Pankov.El
3146b3cff10cSYuri Pankov.Sh EXIT STATUS
3147b3cff10cSYuri PankovThe
3148b3cff10cSYuri Pankov.Nm
3149b3cff10cSYuri Pankovutility exits 0 on success, 1 if an error occurs, and 2 if invalid command line
3150b3cff10cSYuri Pankovoptions were specified.
3151b3cff10cSYuri Pankov.Sh EXAMPLES
3152b3cff10cSYuri Pankov.Bl -tag -width ""
3153b3cff10cSYuri Pankov.It Sy Example 1 No Creating a ZFS File System Hierarchy
3154b3cff10cSYuri PankovThe following commands create a file system named
3155b3cff10cSYuri Pankov.Em pool/home
3156b3cff10cSYuri Pankovand a file system named
3157b3cff10cSYuri Pankov.Em pool/home/bob .
3158b3cff10cSYuri PankovThe mount point
3159b3cff10cSYuri Pankov.Pa /export/home
3160b3cff10cSYuri Pankovis set for the parent file system, and is automatically inherited by the child
3161b3cff10cSYuri Pankovfile system.
3162b3cff10cSYuri Pankov.Bd -literal
3163b3cff10cSYuri Pankov# zfs create pool/home
3164b3cff10cSYuri Pankov# zfs set mountpoint=/export/home pool/home
3165b3cff10cSYuri Pankov# zfs create pool/home/bob
3166b3cff10cSYuri Pankov.Ed
3167b3cff10cSYuri Pankov.It Sy Example 2 No Creating a ZFS Snapshot
3168b3cff10cSYuri PankovThe following command creates a snapshot named
3169b3cff10cSYuri Pankov.Sy yesterday .
3170b3cff10cSYuri PankovThis snapshot is mounted on demand in the
3171b3cff10cSYuri Pankov.Pa .zfs/snapshot
3172b3cff10cSYuri Pankovdirectory at the root of the
3173b3cff10cSYuri Pankov.Em pool/home/bob
3174b3cff10cSYuri Pankovfile system.
3175b3cff10cSYuri Pankov.Bd -literal
3176b3cff10cSYuri Pankov# zfs snapshot pool/home/bob@yesterday
3177b3cff10cSYuri Pankov.Ed
3178b3cff10cSYuri Pankov.It Sy Example 3 No Creating and Destroying Multiple Snapshots
3179b3cff10cSYuri PankovThe following command creates snapshots named
3180b3cff10cSYuri Pankov.Sy yesterday
3181b3cff10cSYuri Pankovof
3182b3cff10cSYuri Pankov.Em pool/home
3183b3cff10cSYuri Pankovand all of its descendent file systems. Each snapshot is mounted on demand in
3184b3cff10cSYuri Pankovthe
3185b3cff10cSYuri Pankov.Pa .zfs/snapshot
3186b3cff10cSYuri Pankovdirectory at the root of its file system. The second command destroys the newly
3187b3cff10cSYuri Pankovcreated snapshots.
3188b3cff10cSYuri Pankov.Bd -literal
3189b3cff10cSYuri Pankov# zfs snapshot -r pool/home@yesterday
3190b3cff10cSYuri Pankov# zfs destroy -r pool/home@yesterday
3191b3cff10cSYuri Pankov.Ed
3192b3cff10cSYuri Pankov.It Sy Example 4 No Disabling and Enabling File System Compression
3193b3cff10cSYuri PankovThe following command disables the
3194b3cff10cSYuri Pankov.Sy compression
3195b3cff10cSYuri Pankovproperty for all file systems under
3196b3cff10cSYuri Pankov.Em pool/home .
3197b3cff10cSYuri PankovThe next command explicitly enables
3198b3cff10cSYuri Pankov.Sy compression
3199b3cff10cSYuri Pankovfor
3200b3cff10cSYuri Pankov.Em pool/home/anne .
3201b3cff10cSYuri Pankov.Bd -literal
3202b3cff10cSYuri Pankov# zfs set compression=off pool/home
3203b3cff10cSYuri Pankov# zfs set compression=on pool/home/anne
3204b3cff10cSYuri Pankov.Ed
3205b3cff10cSYuri Pankov.It Sy Example 5 No Listing ZFS Datasets
3206c10c16deSRichard LoweThe following command lists all active file systems and volumes in the system.
3207b3cff10cSYuri PankovSnapshots are displayed if the
3208b3cff10cSYuri Pankov.Sy listsnaps
3209b3cff10cSYuri Pankovproperty is
3210b3cff10cSYuri Pankov.Sy on .
3211b3cff10cSYuri PankovThe default is
3212b3cff10cSYuri Pankov.Sy off .
3213b3cff10cSYuri PankovSee
3214b3cff10cSYuri Pankov.Xr zpool 1M
3215b3cff10cSYuri Pankovfor more information on pool properties.
3216b3cff10cSYuri Pankov.Bd -literal
3217b3cff10cSYuri Pankov# zfs list
3218c10c16deSRichard LoweNAME                      USED  AVAIL  REFER  MOUNTPOINT
3219c10c16deSRichard Lowepool                      450K   457G    18K  /pool
3220c10c16deSRichard Lowepool/home                 315K   457G    21K  /export/home
3221c10c16deSRichard Lowepool/home/anne             18K   457G    18K  /export/home/anne
3222c10c16deSRichard Lowepool/home/bob             276K   457G   276K  /export/home/bob
3223b3cff10cSYuri Pankov.Ed
3224b3cff10cSYuri Pankov.It Sy Example 6 No Setting a Quota on a ZFS File System
3225b3cff10cSYuri PankovThe following command sets a quota of 50 Gbytes for
3226b3cff10cSYuri Pankov.Em pool/home/bob .
3227b3cff10cSYuri Pankov.Bd -literal
3228b3cff10cSYuri Pankov# zfs set quota=50G pool/home/bob
3229b3cff10cSYuri Pankov.Ed
3230b3cff10cSYuri Pankov.It Sy Example 7 No Listing ZFS Properties
3231b3cff10cSYuri PankovThe following command lists all properties for
3232b3cff10cSYuri Pankov.Em pool/home/bob .
3233b3cff10cSYuri Pankov.Bd -literal
3234b3cff10cSYuri Pankov# zfs get all pool/home/bob
3235c10c16deSRichard LoweNAME           PROPERTY              VALUE                  SOURCE
3236c10c16deSRichard Lowepool/home/bob  type                  filesystem             -
3237c10c16deSRichard Lowepool/home/bob  creation              Tue Jul 21 15:53 2009  -
3238c10c16deSRichard Lowepool/home/bob  used                  21K                    -
3239c10c16deSRichard Lowepool/home/bob  available             20.0G                  -
3240c10c16deSRichard Lowepool/home/bob  referenced            21K                    -
3241c10c16deSRichard Lowepool/home/bob  compressratio         1.00x                  -
3242c10c16deSRichard Lowepool/home/bob  mounted               yes                    -
3243c10c16deSRichard Lowepool/home/bob  quota                 20G                    local
3244c10c16deSRichard Lowepool/home/bob  reservation           none                   default
3245c10c16deSRichard Lowepool/home/bob  recordsize            128K                   default
3246c10c16deSRichard Lowepool/home/bob  mountpoint            /pool/home/bob         default
3247c10c16deSRichard Lowepool/home/bob  sharenfs              off                    default
3248c10c16deSRichard Lowepool/home/bob  checksum              on                     default
3249c10c16deSRichard Lowepool/home/bob  compression           on                     local
3250c10c16deSRichard Lowepool/home/bob  atime                 on                     default
3251c10c16deSRichard Lowepool/home/bob  devices               on                     default
3252c10c16deSRichard Lowepool/home/bob  exec                  on                     default
3253c10c16deSRichard Lowepool/home/bob  setuid                on                     default
3254c10c16deSRichard Lowepool/home/bob  readonly              off                    default
3255c10c16deSRichard Lowepool/home/bob  zoned                 off                    default
3256c10c16deSRichard Lowepool/home/bob  snapdir               hidden                 default
3257a3c49ce1SAlbert Leepool/home/bob  aclmode               discard                default
3258c10c16deSRichard Lowepool/home/bob  aclinherit            restricted             default
3259c10c16deSRichard Lowepool/home/bob  canmount              on                     default
3260c10c16deSRichard Lowepool/home/bob  xattr                 on                     default
3261c10c16deSRichard Lowepool/home/bob  copies                1                      default
3262c10c16deSRichard Lowepool/home/bob  version               4                      -
3263c10c16deSRichard Lowepool/home/bob  utf8only              off                    -
3264c10c16deSRichard Lowepool/home/bob  normalization         none                   -
3265c10c16deSRichard Lowepool/home/bob  casesensitivity       sensitive              -
3266c10c16deSRichard Lowepool/home/bob  vscan                 off                    default
3267c10c16deSRichard Lowepool/home/bob  nbmand                off                    default
3268c10c16deSRichard Lowepool/home/bob  sharesmb              off                    default
3269c10c16deSRichard Lowepool/home/bob  refquota              none                   default
3270c10c16deSRichard Lowepool/home/bob  refreservation        none                   default
3271c10c16deSRichard Lowepool/home/bob  primarycache          all                    default
3272c10c16deSRichard Lowepool/home/bob  secondarycache        all                    default
3273c10c16deSRichard Lowepool/home/bob  usedbysnapshots       0                      -
3274c10c16deSRichard Lowepool/home/bob  usedbydataset         21K                    -
3275c10c16deSRichard Lowepool/home/bob  usedbychildren        0                      -
3276c10c16deSRichard Lowepool/home/bob  usedbyrefreservation  0                      -
3277b3cff10cSYuri Pankov.Ed
3278b3cff10cSYuri Pankov.Pp
3279c10c16deSRichard LoweThe following command gets a single property value.
3280b3cff10cSYuri Pankov.Bd -literal
3281b3cff10cSYuri Pankov# zfs get -H -o value compression pool/home/bob
3282c10c16deSRichard Loweon
3283b3cff10cSYuri Pankov.Ed
3284c10c16deSRichard LoweThe following command lists all properties with local settings for
3285b3cff10cSYuri Pankov.Em pool/home/bob .
3286b3cff10cSYuri Pankov.Bd -literal
3287b3cff10cSYuri Pankov# zfs get -r -s local -o name,property,value all pool/home/bob
3288c10c16deSRichard LoweNAME           PROPERTY              VALUE
3289c10c16deSRichard Lowepool/home/bob  quota                 20G
3290c10c16deSRichard Lowepool/home/bob  compression           on
3291b3cff10cSYuri Pankov.Ed
3292b3cff10cSYuri Pankov.It Sy Example 8 No Rolling Back a ZFS File System
3293b3cff10cSYuri PankovThe following command reverts the contents of
3294b3cff10cSYuri Pankov.Em pool/home/anne
3295b3cff10cSYuri Pankovto the snapshot named
3296b3cff10cSYuri Pankov.Sy yesterday ,
3297b3cff10cSYuri Pankovdeleting all intermediate snapshots.
3298b3cff10cSYuri Pankov.Bd -literal
3299b3cff10cSYuri Pankov# zfs rollback -r pool/home/anne@yesterday
3300b3cff10cSYuri Pankov.Ed
3301b3cff10cSYuri Pankov.It Sy Example 9 No Creating a ZFS Clone
3302c10c16deSRichard LoweThe following command creates a writable file system whose initial contents are
3303b3cff10cSYuri Pankovthe same as
3304b3cff10cSYuri Pankov.Em pool/home/bob@yesterday .
3305b3cff10cSYuri Pankov.Bd -literal
3306b3cff10cSYuri Pankov# zfs clone pool/home/bob@yesterday pool/clone
3307b3cff10cSYuri Pankov.Ed
3308b3cff10cSYuri Pankov.It Sy Example 10 No Promoting a ZFS Clone
3309c10c16deSRichard LoweThe following commands illustrate how to test out changes to a file system, and
3310c10c16deSRichard Lowethen replace the original file system with the changed one, using clones, clone
3311c10c16deSRichard Lowepromotion, and renaming:
3312b3cff10cSYuri Pankov.Bd -literal
3313b3cff10cSYuri Pankov# zfs create pool/project/production
3314c10c16deSRichard Lowe  populate /pool/project/production with data
3315b3cff10cSYuri Pankov# zfs snapshot pool/project/production@today
3316b3cff10cSYuri Pankov# zfs clone pool/project/production@today pool/project/beta
3317c10c16deSRichard Lowe  make changes to /pool/project/beta and test them
3318b3cff10cSYuri Pankov# zfs promote pool/project/beta
3319b3cff10cSYuri Pankov# zfs rename pool/project/production pool/project/legacy
3320b3cff10cSYuri Pankov# zfs rename pool/project/beta pool/project/production
3321c10c16deSRichard Lowe  once the legacy version is no longer needed, it can be destroyed
3322b3cff10cSYuri Pankov# zfs destroy pool/project/legacy
3323b3cff10cSYuri Pankov.Ed
3324b3cff10cSYuri Pankov.It Sy Example 11 No Inheriting ZFS Properties
3325b3cff10cSYuri PankovThe following command causes
3326b3cff10cSYuri Pankov.Em pool/home/bob
3327b3cff10cSYuri Pankovand
3328b3cff10cSYuri Pankov.Em pool/home/anne
3329b3cff10cSYuri Pankovto inherit the
3330b3cff10cSYuri Pankov.Sy checksum
3331b3cff10cSYuri Pankovproperty from their parent.
3332b3cff10cSYuri Pankov.Bd -literal
3333b3cff10cSYuri Pankov# zfs inherit checksum pool/home/bob pool/home/anne
3334b3cff10cSYuri Pankov.Ed
3335b3cff10cSYuri Pankov.It Sy Example 12 No Remotely Replicating ZFS Data
3336c10c16deSRichard LoweThe following commands send a full stream and then an incremental stream to a
3337b3cff10cSYuri Pankovremote machine, restoring them into
3338b3cff10cSYuri Pankov.Em poolB/received/fs@a
3339b3cff10cSYuri Pankovand
3340b3cff10cSYuri Pankov.Em poolB/received/fs@b ,
3341b3cff10cSYuri Pankovrespectively.
3342b3cff10cSYuri Pankov.Em poolB
3343b3cff10cSYuri Pankovmust contain the file system
3344b3cff10cSYuri Pankov.Em poolB/received ,
3345b3cff10cSYuri Pankovand must not initially contain
3346b3cff10cSYuri Pankov.Em poolB/received/fs .
3347b3cff10cSYuri Pankov.Bd -literal
3348b3cff10cSYuri Pankov# zfs send pool/fs@a | \e
3349b3cff10cSYuri Pankov  ssh host zfs receive poolB/received/fs@a
3350b3cff10cSYuri Pankov# zfs send -i a pool/fs@b | \e
3351b3cff10cSYuri Pankov  ssh host zfs receive poolB/received/fs
3352b3cff10cSYuri Pankov.Ed
3353b3cff10cSYuri Pankov.It Sy Example 13 No Using the zfs receive -d Option
3354b3cff10cSYuri PankovThe following command sends a full stream of
3355b3cff10cSYuri Pankov.Em poolA/fsA/fsB@snap
3356b3cff10cSYuri Pankovto a remote machine, receiving it into
3357b3cff10cSYuri Pankov.Em poolB/received/fsA/fsB@snap .
3358b3cff10cSYuri PankovThe
3359b3cff10cSYuri Pankov.Em fsA/fsB@snap
3360b3cff10cSYuri Pankovportion of the received snapshot's name is determined from the name of the sent
3361b3cff10cSYuri Pankovsnapshot.
3362b3cff10cSYuri Pankov.Em poolB
3363b3cff10cSYuri Pankovmust contain the file system
3364b3cff10cSYuri Pankov.Em poolB/received .
3365b3cff10cSYuri PankovIf
3366b3cff10cSYuri Pankov.Em poolB/received/fsA
3367b3cff10cSYuri Pankovdoes not exist, it is created as an empty file system.
3368b3cff10cSYuri Pankov.Bd -literal
3369b3cff10cSYuri Pankov# zfs send poolA/fsA/fsB@snap | \e
3370b3cff10cSYuri Pankov  ssh host zfs receive -d poolB/received
3371b3cff10cSYuri Pankov.Ed
3372b3cff10cSYuri Pankov.It Sy Example 14 No Setting User Properties
3373b3cff10cSYuri PankovThe following example sets the user-defined
3374b3cff10cSYuri Pankov.Sy com.example:department
3375c10c16deSRichard Loweproperty for a dataset.
3376b3cff10cSYuri Pankov.Bd -literal
3377b3cff10cSYuri Pankov# zfs set com.example:department=12345 tank/accounting
3378b3cff10cSYuri Pankov.Ed
3379b3cff10cSYuri Pankov.It Sy Example 15 No Performing a Rolling Snapshot
3380c10c16deSRichard LoweThe following example shows how to maintain a history of snapshots with a
3381c10c16deSRichard Loweconsistent naming scheme. To keep a week's worth of snapshots, the user
3382c10c16deSRichard Lowedestroys the oldest snapshot, renames the remaining snapshots, and then creates
3383c10c16deSRichard Lowea new snapshot, as follows:
3384b3cff10cSYuri Pankov.Bd -literal
3385b3cff10cSYuri Pankov# zfs destroy -r pool/users@7daysago
3386b3cff10cSYuri Pankov# zfs rename -r pool/users@6daysago @7daysago
3387b3cff10cSYuri Pankov# zfs rename -r pool/users@5daysago @6daysago
3388b3cff10cSYuri Pankov# zfs rename -r pool/users@yesterday @5daysago
3389b3cff10cSYuri Pankov# zfs rename -r pool/users@yesterday @4daysago
3390b3cff10cSYuri Pankov# zfs rename -r pool/users@yesterday @3daysago
3391b3cff10cSYuri Pankov# zfs rename -r pool/users@yesterday @2daysago
3392b3cff10cSYuri Pankov# zfs rename -r pool/users@today @yesterday
3393b3cff10cSYuri Pankov# zfs snapshot -r pool/users@today
3394b3cff10cSYuri Pankov.Ed
3395b3cff10cSYuri Pankov.It Sy Example 16 No Setting sharenfs Property Options on a ZFS File System
3396b3cff10cSYuri PankovThe following commands show how to set
3397b3cff10cSYuri Pankov.Sy sharenfs
3398b3cff10cSYuri Pankovproperty options to enable
3399b3cff10cSYuri Pankov.Sy rw
3400b3cff10cSYuri Pankovaccess for a set of
3401b3cff10cSYuri Pankov.Sy IP
3402b3cff10cSYuri Pankovaddresses and to enable root access for system
3403b3cff10cSYuri Pankov.Sy neo
3404b3cff10cSYuri Pankovon the
3405b3cff10cSYuri Pankov.Em tank/home
3406b3cff10cSYuri Pankovfile system.
3407b3cff10cSYuri Pankov.Bd -literal
3408b3cff10cSYuri Pankov# zfs set sharenfs='rw=@123.123.0.0/16,root=neo' tank/home
3409b3cff10cSYuri Pankov.Ed
3410b3cff10cSYuri Pankov.Pp
3411b3cff10cSYuri PankovIf you are using
3412b3cff10cSYuri Pankov.Sy DNS
3413b3cff10cSYuri Pankovfor host name resolution, specify the fully qualified hostname.
3414b3cff10cSYuri Pankov.It Sy Example 17 No Delegating ZFS Administration Permissions on a ZFS Dataset
3415b3cff10cSYuri PankovThe following example shows how to set permissions so that user
3416b3cff10cSYuri Pankov.Sy cindys
3417b3cff10cSYuri Pankovcan create, destroy, mount, and take snapshots on
3418b3cff10cSYuri Pankov.Em tank/cindys .
3419b3cff10cSYuri PankovThe permissions on
3420b3cff10cSYuri Pankov.Em tank/cindys
3421b3cff10cSYuri Pankovare also displayed.
3422b3cff10cSYuri Pankov.Bd -literal
3423b3cff10cSYuri Pankov# zfs allow cindys create,destroy,mount,snapshot tank/cindys
3424b3cff10cSYuri Pankov# zfs allow tank/cindys
34255619b3f8SMarcel Telka---- Permissions on tank/cindys --------------------------------------
34265619b3f8SMarcel TelkaLocal+Descendent permissions:
3427c10c16deSRichard Lowe        user cindys create,destroy,mount,snapshot
3428b3cff10cSYuri Pankov.Ed
3429b3cff10cSYuri Pankov.Pp
3430b3cff10cSYuri PankovBecause the
3431b3cff10cSYuri Pankov.Em tank/cindys
3432b3cff10cSYuri Pankovmount point permission is set to 755 by default, user
3433b3cff10cSYuri Pankov.Sy cindys
3434b3cff10cSYuri Pankovwill be unable to mount file systems under
3435b3cff10cSYuri Pankov.Em tank/cindys .
3436b3cff10cSYuri PankovAdd an
3437b3cff10cSYuri Pankov.Sy ACE
3438b3cff10cSYuri Pankovsimilar to the following syntax to provide mount point access:
3439b3cff10cSYuri Pankov.Bd -literal
3440b3cff10cSYuri Pankov# chmod A+user:cindys:add_subdirectory:allow /tank/cindys
3441b3cff10cSYuri Pankov.Ed
3442b3cff10cSYuri Pankov.It Sy Example 18 No Delegating Create Time Permissions on a ZFS Dataset
3443b3cff10cSYuri PankovThe following example shows how to grant anyone in the group
3444b3cff10cSYuri Pankov.Sy staff
3445b3cff10cSYuri Pankovto create file systems in
3446b3cff10cSYuri Pankov.Em tank/users .
3447b3cff10cSYuri PankovThis syntax also allows staff members to destroy their own file systems, but not
3448b3cff10cSYuri Pankovdestroy anyone else's file system. The permissions on
3449b3cff10cSYuri Pankov.Em tank/users
3450b3cff10cSYuri Pankovare also displayed.
3451b3cff10cSYuri Pankov.Bd -literal
3452b3cff10cSYuri Pankov# zfs allow staff create,mount tank/users
3453b3cff10cSYuri Pankov# zfs allow -c destroy tank/users
3454b3cff10cSYuri Pankov# zfs allow tank/users
34555619b3f8SMarcel Telka---- Permissions on tank/users ---------------------------------------
34565619b3f8SMarcel TelkaPermission sets:
34575619b3f8SMarcel Telka        destroy
34585619b3f8SMarcel TelkaLocal+Descendent permissions:
3459c10c16deSRichard Lowe        group staff create,mount
3460b3cff10cSYuri Pankov.Ed
3461b3cff10cSYuri Pankov.It Sy Example 19 No Defining and Granting a Permission Set on a ZFS Dataset
3462c10c16deSRichard LoweThe following example shows how to define and grant a permission set on the
3463b3cff10cSYuri Pankov.Em tank/users
3464b3cff10cSYuri Pankovfile system. The permissions on
3465b3cff10cSYuri Pankov.Em tank/users
3466b3cff10cSYuri Pankovare also displayed.
3467b3cff10cSYuri Pankov.Bd -literal
3468b3cff10cSYuri Pankov# zfs allow -s @pset create,destroy,snapshot,mount tank/users
3469b3cff10cSYuri Pankov# zfs allow staff @pset tank/users
3470b3cff10cSYuri Pankov# zfs allow tank/users
34715619b3f8SMarcel Telka---- Permissions on tank/users ---------------------------------------
34725619b3f8SMarcel TelkaPermission sets:
3473c10c16deSRichard Lowe        @pset create,destroy,mount,snapshot
34745619b3f8SMarcel TelkaLocal+Descendent permissions:
34755619b3f8SMarcel Telka        group staff @pset
3476b3cff10cSYuri Pankov.Ed
3477b3cff10cSYuri Pankov.It Sy Example 20 No Delegating Property Permissions on a ZFS Dataset
3478c10c16deSRichard LoweThe following example shows to grant the ability to set quotas and reservations
3479b3cff10cSYuri Pankovon the
3480b3cff10cSYuri Pankov.Em users/home
3481b3cff10cSYuri Pankovfile system. The permissions on
3482b3cff10cSYuri Pankov.Em users/home
3483b3cff10cSYuri Pankovare also displayed.
3484b3cff10cSYuri Pankov.Bd -literal
3485b3cff10cSYuri Pankov# zfs allow cindys quota,reservation users/home
3486b3cff10cSYuri Pankov# zfs allow users/home
34875619b3f8SMarcel Telka---- Permissions on users/home ---------------------------------------
34885619b3f8SMarcel TelkaLocal+Descendent permissions:
3489c10c16deSRichard Lowe        user cindys quota,reservation
3490b3cff10cSYuri Pankovcindys% zfs set quota=10G users/home/marks
3491b3cff10cSYuri Pankovcindys% zfs get quota users/home/marks
3492c10c16deSRichard LoweNAME              PROPERTY  VALUE  SOURCE
3493c10c16deSRichard Loweusers/home/marks  quota     10G    local
3494b3cff10cSYuri Pankov.Ed
3495b3cff10cSYuri Pankov.It Sy Example 21 No Removing ZFS Delegated Permissions on a ZFS Dataset
3496c10c16deSRichard LoweThe following example shows how to remove the snapshot permission from the
3497b3cff10cSYuri Pankov.Sy staff
3498b3cff10cSYuri Pankovgroup on the
3499b3cff10cSYuri Pankov.Em tank/users
3500b3cff10cSYuri Pankovfile system. The permissions on
3501b3cff10cSYuri Pankov.Em tank/users
3502b3cff10cSYuri Pankovare also displayed.
3503b3cff10cSYuri Pankov.Bd -literal
3504b3cff10cSYuri Pankov# zfs unallow staff snapshot tank/users
3505b3cff10cSYuri Pankov# zfs allow tank/users
35065619b3f8SMarcel Telka---- Permissions on tank/users ---------------------------------------
35075619b3f8SMarcel TelkaPermission sets:
3508c10c16deSRichard Lowe        @pset create,destroy,mount,snapshot
35095619b3f8SMarcel TelkaLocal+Descendent permissions:
35105619b3f8SMarcel Telka        group staff @pset
3511b3cff10cSYuri Pankov.Ed
3512b3cff10cSYuri Pankov.It Sy Example 22 No Showing the differences between a snapshot and a ZFS Dataset
35133b8be6bfSRichard LoweThe following example shows how to see what has changed between a prior
3514b3cff10cSYuri Pankovsnapshot of a ZFS dataset and its current state. The
3515b3cff10cSYuri Pankov.Fl F
3516b3cff10cSYuri Pankovoption is used to indicate type information for the files affected.
3517b3cff10cSYuri Pankov.Bd -literal
35183b8be6bfSRichard Lowe# zfs diff -F tank/test@before tank/test
35193b8be6bfSRichard LoweM       /       /tank/test/
35203b8be6bfSRichard LoweM       F       /tank/test/linked      (+1)
35213b8be6bfSRichard LoweR       F       /tank/test/oldname -> /tank/test/newname
35223b8be6bfSRichard Lowe-       F       /tank/test/deleted
35233b8be6bfSRichard Lowe+       F       /tank/test/created
35243b8be6bfSRichard LoweM       F       /tank/test/modified
3525b3cff10cSYuri Pankov.Ed
3526b3cff10cSYuri Pankov.El
3527b3cff10cSYuri Pankov.Sh INTERFACE STABILITY
3528b3cff10cSYuri Pankov.Sy Commited .
3529b3cff10cSYuri Pankov.Sh SEE ALSO
3530b3cff10cSYuri Pankov.Xr gzip 1,
3531b3cff10cSYuri Pankov.Xr ssh 1 ,
3532b3cff10cSYuri Pankov.Xr mount 1M ,
3533b3cff10cSYuri Pankov.Xr share 1M ,
3534b3cff10cSYuri Pankov.Xr sharemgr 1M ,
3535b3cff10cSYuri Pankov.Xr unshare 1M ,
3536b3cff10cSYuri Pankov.Xr zonecfg 1M ,
3537b3cff10cSYuri Pankov.Xr zpool 1M ,
3538b3cff10cSYuri Pankov.Xr chmod 2 ,
3539b3cff10cSYuri Pankov.Xr stat 2 ,
3540b3cff10cSYuri Pankov.Xr write 2 ,
3541b3cff10cSYuri Pankov.Xr fsync 3C ,
3542b3cff10cSYuri Pankov.Xr dfstab 4 ,
3543b3cff10cSYuri Pankov.Xr acl 5 ,
3544b3cff10cSYuri Pankov.Xr attributes 5
3545