4 .\" The contents of this file are subject to the terms of the
5 .\" Common Development and Distribution License (the "License").
6 .\" You may not use this file except in compliance with the License.
8 .\" You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 .\" or http://www.opensolaris.org/os/licensing.
10 .\" See the License for the specific language governing permissions
11 .\" and limitations under the License.
13 .\" When distributing Covered Code, include this CDDL HEADER in each
14 .\" file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 .\" If applicable, add the following below this CDDL HEADER, with the
16 .\" fields enclosed by brackets "[]" replaced with your own identifying
17 .\" information: Portions Copyright [yyyy] [name of copyright owner]
21 .\" Copyright (c) 2007, Sun Microsystems, Inc. All Rights Reserved.
22 .\" Copyright (c) 2012, 2018 by Delphix. All rights reserved.
23 .\" Copyright (c) 2012 Cyril Plisko. All Rights Reserved.
24 .\" Copyright (c) 2017 Datto Inc.
25 .\" Copyright (c) 2018 George Melikov. All Rights Reserved.
26 .\" Copyright 2017 Nexenta Systems, Inc.
27 .\" Copyright (c) 2017 Open-E, Inc. All Rights Reserved.
35 .Nd display logical I/O statistics for ZFS storage pools
39 .Op Oo Oo Fl c Ar SCRIPT Oc Oo Fl lq Oc Oc Ns | Ns Fl rw
40 .Op Fl T Sy u Ns | Ns Sy d
42 .Oo Ar pool Ns … Ns | Ns Oo Ar pool vdev Ns … Oc Ns | Ns Ar vdev Ns … Oc
43 .Op Ar interval Op Ar count
46 Displays logical I/O statistics for the given pools/vdevs.
47 Physical I/O statistics may be observed via
49 If writes are located nearby, they may be merged into a single
51 Additional I/O may be generated depending on the level of vdev redundancy.
52 To filter output, you may pass in a list of pools, a pool and list of vdevs
53 in that pool, or a list of any vdevs from any pool.
54 If no items are specified, statistics for every pool in the system are shown.
57 the statistics are printed every
62 flag is specified the headers are displayed only once, otherwise they are
63 displayed periodically.
66 is specified, the command exits after
69 The first report printed is always the statistics since boot regardless of whether
74 However, this behavior can be suppressed with the
77 Also note that the units of
81 that are printed in the report are in base 1024.
82 To get the raw values, use the
86 .It Fl c Op Ar SCRIPT1 Ns Oo , Ns Ar SCRIPT2 Oc Ns …
87 Run a script (or scripts) on each vdev and include the output as a new column
91 Users can run any script found in their
93 directory or from the system
96 Script names containing the slash
98 character are not allowed.
99 The default search path can be overridden by setting the
100 .Sy ZPOOL_SCRIPTS_PATH
101 environment variable.
102 A privileged user can only run
105 .Sy ZPOOL_SCRIPTS_AS_ROOT
106 environment variable set.
107 If a script requires the use of a privileged command, like
109 then it's recommended you allow the user access to it in
111 or add the user to the
112 .Pa /etc/sudoers.d/zfs
117 is passed without a script name, it prints a list of all scripts.
119 also sets verbose mode
120 .No \&( Ns Fl v Ns No \&).
122 Script output should be in the form of "name=value".
123 The column name is set to "name" and the value is set to "value".
124 Multiple lines can be used to output multiple columns.
125 The first line of output not in the
126 "name=value" format is displayed without a column title,
127 and no more output after that is displayed.
128 This can be useful for printing error messages.
129 Blank or NULL values are printed as a '-' to make output AWKable.
131 The following environment variables are set before running each script:
132 .Bl -tag -compact -width "VDEV_ENC_SYSFS_PATH"
134 Full path to the vdev
136 Underlying path to the vdev
138 For use with device mapper, multipath, or partitioned vdevs.
139 .It Sy VDEV_ENC_SYSFS_PATH
140 The sysfs path to the enclosure for the vdev (if any).
142 .It Fl T Sy u Ns | Ns Sy d
143 Display a time stamp.
146 for a printed representation of the internal representation of time.
151 for standard date format.
155 Display vdev GUIDs instead of the normal device names.
156 These GUIDs can be used in place of device names for the zpool
157 detach/offline/remove/replace commands.
160 Do not display headers, and separate fields by a
161 single tab instead of arbitrary space.
163 Display real paths for vdevs resolving all symbolic links.
164 This can be used to look up the current block device name regardless of the
166 path used to open it.
168 Print headers only once when passed
170 Display numbers in parsable (exact) values.
171 Time values are in nanoseconds.
173 Display full paths for vdevs instead of only the last component of the path.
174 This can be used in conjunction with the
178 Print request size histograms for the leaf vdev's I/O.
179 This includes histograms of individual I/O (ind) and aggregate I/O (agg).
180 These stats can be useful for observing how well I/O aggregation is working.
181 Note that TRIM I/O may exceed 16M, but will be counted as 16M.
183 Verbose statistics Reports usage statistics for individual vdevs within the
184 pool, in addition to the pool-wide statistics.
186 Normally the first line of output reports the statistics since boot:
189 Display latency histograms:
190 .Bl -tag -compact -width "asyncq_read/write"
192 Total I/O time (queuing + disk I/O time).
194 Disk I/O time (time reading/writing the disk).
196 Amount of time I/O spent in synchronous priority queues.
197 Does not include disk time.
199 Amount of time I/O spent in asynchronous priority queues.
200 Does not include disk time.
202 Amount of time I/O spent in scrub queue.
203 Does not include disk time.
206 Include average latency statistics:
207 .Bl -tag -compact -width "asyncq_read/write"
209 Average total I/O time (queuing + disk I/O time).
211 Average disk I/O time (time reading/writing the disk).
213 Average amount of time I/O spent in synchronous priority queues.
214 Does not include disk time.
216 Average amount of time I/O spent in asynchronous priority queues.
217 Does not include disk time.
219 Average queuing time in scrub queue.
220 Does not include disk time.
222 Average queuing time in trim queue.
223 Does not include disk time.
226 Include active queue statistics.
227 Each priority queue has both pending
232 Pending requests are waiting to be issued to the disk,
233 and active requests have been issued to disk and are waiting for completion.
234 These stats are broken out by priority queue:
235 .Bl -tag -compact -width "asyncq_read/write"
236 .It Sy syncq_read/write
237 Current number of entries in synchronous priority
239 .It Sy asyncq_read/write
240 Current number of entries in asynchronous priority queues.
242 Current number of entries in scrub queue.
244 Current number of entries in trim queue.
247 All queue statistics are instantaneous measurements of the number of
248 entries in the queues.
249 If you specify an interval,
250 the measurements will be sampled from the end of the interval.