zpool-remove.8
| ZPOOL-REMOVE(8) | System Manager's Manual | ZPOOL-REMOVE(8) |
NAME
zpool-remove —
remove devices from ZFS storage pool
SYNOPSIS
zpool |
remove [-npw]
pool device… |
zpool |
remove -s
pool |
DESCRIPTION
zpoolremove[-npw] pool device…- Removes the specified device from the pool. This command supports removing
hot spare, cache, log, and both mirrored and non-redundant primary
top-level vdevs, including dedup and special vdevs.
Top-level vdevs can only be removed if the primary pool storage does not contain a top-level raidz vdev, all top-level vdevs have the same sector size, and the keys for all encrypted datasets are loaded.
Removing a top-level vdev reduces the total amount of space in the storage pool. The specified device will be evacuated by copying all allocated space from it to the other devices in the pool. In this case, the
zpoolremovecommand initiates the removal and returns, while the evacuation continues in the background. The removal progress can be monitored withzpoolstatus. If an I/O error is encountered during the removal process it will be canceled. The device_removal feature flag must be enabled to remove a top-level vdev, see zpool-features(7).A mirrored top-level device (log or data) can be removed by specifying the top- level mirror for the same. Non-log devices or data devices that are part of a mirrored configuration can be removed using the
zpooldetachcommand.-n- Do not actually perform the removal ("No-op"). Instead, print the estimated amount of memory that will be used by the mapping table after the removal completes. This is nonzero only for top-level vdevs.
zpoolremove-spool- Stops and cancels an in-progress removal of a top-level vdev.
EXAMPLES
Example 1: Removing a Mirrored top-level (Log or Data) Device
The following commands remove the mirrored log device mirror-2 and mirrored top-level data device mirror-1.
Given this configuration:
pool: tank
state: ONLINE
scrub: none requested
config:
NAME STATE READ WRITE CKSUM
tank ONLINE 0 0 0
mirror-0 ONLINE 0 0 0
sda ONLINE 0 0 0
sdb ONLINE 0 0 0
mirror-1 ONLINE 0 0 0
sdc ONLINE 0 0 0
sdd ONLINE 0 0 0
logs
mirror-2 ONLINE 0 0 0
sde ONLINE 0 0 0
sdf ONLINE 0 0 0
The command to remove the mirrored log mirror-2 is:
# zpool
remove tank
mirror-2At this point, the log device no longer exists (both sides of the mirror have been removed):
pool: tank
state: ONLINE
scan: none requested
config:
NAME STATE READ WRITE CKSUM
tank ONLINE 0 0 0
mirror-0 ONLINE 0 0 0
sda ONLINE 0 0 0
sdb ONLINE 0 0 0
mirror-1 ONLINE 0 0 0
sdc ONLINE 0 0 0
sdd ONLINE 0 0 0
The command to remove the mirrored data mirror-1 is:
# zpool
remove tank
mirror-1After mirror-1 has been evacuated, the pool remains redundant, but the total amount of space is reduced:
pool: tank
state: ONLINE
scan: none requested
config:
NAME STATE READ WRITE CKSUM
tank ONLINE 0 0 0
mirror-0 ONLINE 0 0 0
sda ONLINE 0 0 0
sdb ONLINE 0 0 0
SEE ALSO
zpool-add(8), zpool-detach(8), zpool-labelclear(8), zpool-offline(8), zpool-replace(8), zpool-split(8)
| March 16, 2022 | Debian |