Add 'zpool status -i' option
Only display the full details of the vdev initialization state in 'zpool status' output when requested with the -i option. By default display '(initializing)' after vdevs when they are being actively initialized. This is consistent with the established precident of appending '(resilvering), etc' and fits within the default 80 column terminal width making it easy to read. Additionally, updated the 'zpool initialize' documentation to make it clear the options are mutually exclusive, but allow duplicate options like all other zfs/zpool commands. Reviewed by: Matt Ahrens <mahrens@delphix.com> Reviewed-by: loli10K <ezomori.nozomu@gmail.com> Reviewed-by: Tim Chase <tim@chase2k.com> Reviewed-by: George Wilson <george.wilson@delphix.com> Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov> Closes #8230
This commit is contained in:
parent
c10d37dd9f
commit
a769fb53a1
|
@ -364,14 +364,15 @@ get_usage(zpool_help_t idx)
|
||||||
case HELP_REOPEN:
|
case HELP_REOPEN:
|
||||||
return (gettext("\treopen [-n] <pool>\n"));
|
return (gettext("\treopen [-n] <pool>\n"));
|
||||||
case HELP_INITIALIZE:
|
case HELP_INITIALIZE:
|
||||||
return (gettext("\tinitialize [-cs] <pool> [<device> ...]\n"));
|
return (gettext("\tinitialize [-c | -s] <pool> "
|
||||||
|
"[<device> ...]\n"));
|
||||||
case HELP_SCRUB:
|
case HELP_SCRUB:
|
||||||
return (gettext("\tscrub [-s | -p] <pool> ...\n"));
|
return (gettext("\tscrub [-s | -p] <pool> ...\n"));
|
||||||
case HELP_RESILVER:
|
case HELP_RESILVER:
|
||||||
return (gettext("\tresilver <pool> ...\n"));
|
return (gettext("\tresilver <pool> ...\n"));
|
||||||
case HELP_STATUS:
|
case HELP_STATUS:
|
||||||
return (gettext("\tstatus [-c [script1,script2,...]] "
|
return (gettext("\tstatus [-c [script1,script2,...]] "
|
||||||
"[-gLpPsvxD] [-T d|u] [pool] ... \n"
|
"[-igLpPsvxD] [-T d|u] [pool] ... \n"
|
||||||
"\t [interval [count]]\n"));
|
"\t [interval [count]]\n"));
|
||||||
case HELP_UPGRADE:
|
case HELP_UPGRADE:
|
||||||
return (gettext("\tupgrade\n"
|
return (gettext("\tupgrade\n"
|
||||||
|
@ -506,7 +507,7 @@ usage(boolean_t requested)
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* zpool initialize [-cs] <pool> [<vdev> ...]
|
* zpool initialize [-c | -s] <pool> [<vdev> ...]
|
||||||
* Initialize all unused blocks in the specified vdevs, or all vdevs in the pool
|
* Initialize all unused blocks in the specified vdevs, or all vdevs in the pool
|
||||||
* if none specified.
|
* if none specified.
|
||||||
*
|
*
|
||||||
|
@ -532,7 +533,8 @@ zpool_do_initialize(int argc, char **argv)
|
||||||
while ((c = getopt_long(argc, argv, "cs", long_options, NULL)) != -1) {
|
while ((c = getopt_long(argc, argv, "cs", long_options, NULL)) != -1) {
|
||||||
switch (c) {
|
switch (c) {
|
||||||
case 'c':
|
case 'c':
|
||||||
if (cmd_type != POOL_INITIALIZE_DO) {
|
if (cmd_type != POOL_INITIALIZE_DO &&
|
||||||
|
cmd_type != POOL_INITIALIZE_CANCEL) {
|
||||||
(void) fprintf(stderr, gettext("-c cannot be "
|
(void) fprintf(stderr, gettext("-c cannot be "
|
||||||
"combined with other options\n"));
|
"combined with other options\n"));
|
||||||
usage(B_FALSE);
|
usage(B_FALSE);
|
||||||
|
@ -540,7 +542,8 @@ zpool_do_initialize(int argc, char **argv)
|
||||||
cmd_type = POOL_INITIALIZE_CANCEL;
|
cmd_type = POOL_INITIALIZE_CANCEL;
|
||||||
break;
|
break;
|
||||||
case 's':
|
case 's':
|
||||||
if (cmd_type != POOL_INITIALIZE_DO) {
|
if (cmd_type != POOL_INITIALIZE_DO &&
|
||||||
|
cmd_type != POOL_INITIALIZE_SUSPEND) {
|
||||||
(void) fprintf(stderr, gettext("-s cannot be "
|
(void) fprintf(stderr, gettext("-s cannot be "
|
||||||
"combined with other options\n"));
|
"combined with other options\n"));
|
||||||
usage(B_FALSE);
|
usage(B_FALSE);
|
||||||
|
@ -1792,6 +1795,7 @@ typedef struct status_cbdata {
|
||||||
boolean_t cb_dedup_stats;
|
boolean_t cb_dedup_stats;
|
||||||
boolean_t cb_print_status;
|
boolean_t cb_print_status;
|
||||||
boolean_t cb_print_slow_ios;
|
boolean_t cb_print_slow_ios;
|
||||||
|
boolean_t cb_print_vdev_init;
|
||||||
vdev_cmd_data_list_t *vcdl;
|
vdev_cmd_data_list_t *vcdl;
|
||||||
} status_cbdata_t;
|
} status_cbdata_t;
|
||||||
|
|
||||||
|
@ -2040,6 +2044,8 @@ print_status_config(zpool_handle_t *zhp, status_cbdata_t *cb, const char *name,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Optionally display vdev initialization status for leaves */
|
||||||
|
if (cb->cb_print_vdev_init && children == 0) {
|
||||||
if ((vs->vs_initialize_state == VDEV_INITIALIZE_ACTIVE ||
|
if ((vs->vs_initialize_state == VDEV_INITIALIZE_ACTIVE ||
|
||||||
vs->vs_initialize_state == VDEV_INITIALIZE_SUSPENDED ||
|
vs->vs_initialize_state == VDEV_INITIALIZE_SUSPENDED ||
|
||||||
vs->vs_initialize_state == VDEV_INITIALIZE_COMPLETE) &&
|
vs->vs_initialize_state == VDEV_INITIALIZE_COMPLETE) &&
|
||||||
|
@ -2050,9 +2056,10 @@ print_status_config(zpool_handle_t *zhp, status_cbdata_t *cb, const char *name,
|
||||||
|
|
||||||
time_t t = vs->vs_initialize_action_time;
|
time_t t = vs->vs_initialize_action_time;
|
||||||
int initialize_pct = 100;
|
int initialize_pct = 100;
|
||||||
if (vs->vs_initialize_state != VDEV_INITIALIZE_COMPLETE) {
|
if (vs->vs_initialize_state !=
|
||||||
initialize_pct = (vs->vs_initialize_bytes_done * 100 /
|
VDEV_INITIALIZE_COMPLETE) {
|
||||||
(vs->vs_initialize_bytes_est + 1));
|
initialize_pct = (vs->vs_initialize_bytes_done *
|
||||||
|
100 / (vs->vs_initialize_bytes_est + 1));
|
||||||
}
|
}
|
||||||
|
|
||||||
(void) localtime_r(&t, &zaction_ts);
|
(void) localtime_r(&t, &zaction_ts);
|
||||||
|
@ -2075,6 +2082,14 @@ print_status_config(zpool_handle_t *zhp, status_cbdata_t *cb, const char *name,
|
||||||
|
|
||||||
(void) printf(gettext(" (%d%% initialized%s)"),
|
(void) printf(gettext(" (%d%% initialized%s)"),
|
||||||
initialize_pct, zbuf);
|
initialize_pct, zbuf);
|
||||||
|
} else {
|
||||||
|
(void) printf(gettext(" (uninitialized)"));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (vs->vs_initialize_state == VDEV_INITIALIZE_ACTIVE &&
|
||||||
|
children == 0) {
|
||||||
|
(void) printf(gettext(" (initializing)"));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
(void) printf("\n");
|
(void) printf("\n");
|
||||||
|
@ -7477,10 +7492,11 @@ status_callback(zpool_handle_t *zhp, void *data)
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* zpool status [-c [script1,script2,...]] [-gLpPsvx] [-T d|u] [pool] ...
|
* zpool status [-c [script1,script2,...]] [-igLpPsvx] [-T d|u] [pool] ...
|
||||||
* [interval [count]]
|
* [interval [count]]
|
||||||
*
|
*
|
||||||
* -c CMD For each vdev, run command CMD
|
* -c CMD For each vdev, run command CMD
|
||||||
|
* -i Display vdev initialization status.
|
||||||
* -g Display guid for individual vdev name.
|
* -g Display guid for individual vdev name.
|
||||||
* -L Follow links when resolving vdev path name.
|
* -L Follow links when resolving vdev path name.
|
||||||
* -p Display values in parsable (exact) format.
|
* -p Display values in parsable (exact) format.
|
||||||
|
@ -7504,7 +7520,7 @@ zpool_do_status(int argc, char **argv)
|
||||||
char *cmd = NULL;
|
char *cmd = NULL;
|
||||||
|
|
||||||
/* check options */
|
/* check options */
|
||||||
while ((c = getopt(argc, argv, "c:gLpPsvxDT:")) != -1) {
|
while ((c = getopt(argc, argv, "c:igLpPsvxDT:")) != -1) {
|
||||||
switch (c) {
|
switch (c) {
|
||||||
case 'c':
|
case 'c':
|
||||||
if (cmd != NULL) {
|
if (cmd != NULL) {
|
||||||
|
@ -7530,6 +7546,9 @@ zpool_do_status(int argc, char **argv)
|
||||||
}
|
}
|
||||||
cmd = optarg;
|
cmd = optarg;
|
||||||
break;
|
break;
|
||||||
|
case 'i':
|
||||||
|
cb.cb_print_vdev_init = B_TRUE;
|
||||||
|
break;
|
||||||
case 'g':
|
case 'g':
|
||||||
cb.cb_name_flags |= VDEV_NAME_GUID;
|
cb.cb_name_flags |= VDEV_NAME_GUID;
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -116,7 +116,7 @@
|
||||||
.Op Ar newpool Oo Fl t Oc
|
.Op Ar newpool Oo Fl t Oc
|
||||||
.Nm
|
.Nm
|
||||||
.Cm initialize
|
.Cm initialize
|
||||||
.Op Fl cs
|
.Op Fl c | Fl s
|
||||||
.Ar pool
|
.Ar pool
|
||||||
.Op Ar device Ns ...
|
.Op Ar device Ns ...
|
||||||
.Nm
|
.Nm
|
||||||
|
@ -187,7 +187,7 @@
|
||||||
.Nm
|
.Nm
|
||||||
.Cm status
|
.Cm status
|
||||||
.Oo Fl c Ar SCRIPT Oc
|
.Oo Fl c Ar SCRIPT Oc
|
||||||
.Op Fl DgLpPsvx
|
.Op Fl DigLpPsvx
|
||||||
.Op Fl T Sy u Ns | Ns Sy d
|
.Op Fl T Sy u Ns | Ns Sy d
|
||||||
.Oo Ar pool Oc Ns ...
|
.Oo Ar pool Oc Ns ...
|
||||||
.Op Ar interval Op Ar count
|
.Op Ar interval Op Ar count
|
||||||
|
@ -1603,7 +1603,7 @@ Will also set -o cachefile=none when not explicitly specified.
|
||||||
.It Xo
|
.It Xo
|
||||||
.Nm
|
.Nm
|
||||||
.Cm initialize
|
.Cm initialize
|
||||||
.Op Fl cs
|
.Op Fl c | Fl s
|
||||||
.Ar pool
|
.Ar pool
|
||||||
.Op Ar device Ns ...
|
.Op Ar device Ns ...
|
||||||
.Xc
|
.Xc
|
||||||
|
@ -2199,7 +2199,7 @@ and automatically import it.
|
||||||
.Nm
|
.Nm
|
||||||
.Cm status
|
.Cm status
|
||||||
.Op Fl c Op Ar SCRIPT1 Ns Oo , Ns Ar SCRIPT2 Oc Ns ...
|
.Op Fl c Op Ar SCRIPT1 Ns Oo , Ns Ar SCRIPT2 Oc Ns ...
|
||||||
.Op Fl DgLpPsvx
|
.Op Fl DigLpPsvx
|
||||||
.Op Fl T Sy u Ns | Ns Sy d
|
.Op Fl T Sy u Ns | Ns Sy d
|
||||||
.Oo Ar pool Oc Ns ...
|
.Oo Ar pool Oc Ns ...
|
||||||
.Op Ar interval Op Ar count
|
.Op Ar interval Op Ar count
|
||||||
|
@ -2226,6 +2226,8 @@ output. See the
|
||||||
option of
|
option of
|
||||||
.Nm zpool Cm iostat
|
.Nm zpool Cm iostat
|
||||||
for complete details.
|
for complete details.
|
||||||
|
.It Fl i
|
||||||
|
Display vdev initialization status.
|
||||||
.It Fl g
|
.It Fl g
|
||||||
Display vdev GUIDs instead of the normal device names. These GUIDs
|
Display vdev GUIDs instead of the normal device names. These GUIDs
|
||||||
can be used in place of device names for the zpool
|
can be used in place of device names for the zpool
|
||||||
|
|
|
@ -21,7 +21,7 @@ function initialize_prog_line # pool disk
|
||||||
{
|
{
|
||||||
typeset pool="$1"
|
typeset pool="$1"
|
||||||
typeset disk="$2"
|
typeset disk="$2"
|
||||||
zpool status "$pool" | grep "$disk" | grep "initialized"
|
zpool status -i "$pool" | grep "$disk" | grep "[[:digit:]]* initialized"
|
||||||
}
|
}
|
||||||
|
|
||||||
function initialize_progress # pool disk
|
function initialize_progress # pool disk
|
||||||
|
|
Loading…
Reference in New Issue