1ba4a712dd
This bring huge amount of changes, I'll enumerate only user-visible changes: - Delegated Administration Allows regular users to perform ZFS operations, like file system creation, snapshot creation, etc. - L2ARC Level 2 cache for ZFS - allows to use additional disks for cache. Huge performance improvements mostly for random read of mostly static content. - slog Allow to use additional disks for ZFS Intent Log to speed up operations like fsync(2). - vfs.zfs.super_owner Allows regular users to perform privileged operations on files stored on ZFS file systems owned by him. Very careful with this one. - chflags(2) Not all the flags are supported. This still needs work. - ZFSBoot Support to boot off of ZFS pool. Not finished, AFAIK. Submitted by: dfr - Snapshot properties - New failure modes Before if write requested failed, system paniced. Now one can select from one of three failure modes: - panic - panic on write error - wait - wait for disk to reappear - continue - serve read requests if possible, block write requests - Refquota, refreservation properties Just quota and reservation properties, but don't count space consumed by children file systems, clones and snapshots. - Sparse volumes ZVOLs that don't reserve space in the pool. - External attributes Compatible with extattr(2). - NFSv4-ACLs Not sure about the status, might not be complete yet. Submitted by: trasz - Creation-time properties - Regression tests for zpool(8) command. Obtained from: OpenSolaris
203 lines
7.3 KiB
Bash
203 lines
7.3 KiB
Bash
#!/bin/sh
|
|
# $FreeBSD$
|
|
|
|
dir=`dirname $0`
|
|
. ${dir}/../../misc.sh
|
|
|
|
echo "1..56"
|
|
|
|
disks_create 7
|
|
names_create 1
|
|
|
|
expect_ok ${ZPOOL} create ${name0} ${disk0} log ${disk1}
|
|
expect_ok ${ZPOOL} status -x ${name0}
|
|
expect "pool '${name0}' is healthy" ${ZPOOL} status -x ${name0}
|
|
exp=`(
|
|
echo " pool: ${name0}"
|
|
echo " state: ONLINE"
|
|
echo " scrub: none requested"
|
|
echo "config:"
|
|
echo " NAME STATE READ WRITE CKSUM"
|
|
echo " ${name0} ONLINE 0 0 0"
|
|
echo " ${disk0} ONLINE 0 0 0"
|
|
echo " logs ONLINE 0 0 0"
|
|
echo " ${disk1} ONLINE 0 0 0"
|
|
echo "errors: No known data errors"
|
|
)`
|
|
expect "${exp}" ${ZPOOL} status ${name0}
|
|
expect_ok ${ZPOOL} destroy ${name0}
|
|
expect_fl ${ZPOOL} status -x ${name0}
|
|
expect_fl ${ZPOOL} destroy ${name0}
|
|
|
|
expect_ok ${ZPOOL} create ${name0} ${disk0} log mirror ${disk1} ${disk2} ${disk3}
|
|
expect_ok ${ZPOOL} status -x ${name0}
|
|
expect "pool '${name0}' is healthy" ${ZPOOL} status -x ${name0}
|
|
exp=`(
|
|
echo " pool: ${name0}"
|
|
echo " state: ONLINE"
|
|
echo " scrub: none requested"
|
|
echo "config:"
|
|
echo " NAME STATE READ WRITE CKSUM"
|
|
echo " ${name0} ONLINE 0 0 0"
|
|
echo " ${disk0} ONLINE 0 0 0"
|
|
echo " logs ONLINE 0 0 0"
|
|
echo " mirror ONLINE 0 0 0"
|
|
echo " ${disk1} ONLINE 0 0 0"
|
|
echo " ${disk2} ONLINE 0 0 0"
|
|
echo " ${disk3} ONLINE 0 0 0"
|
|
echo "errors: No known data errors"
|
|
)`
|
|
expect "${exp}" ${ZPOOL} status ${name0}
|
|
expect_ok ${ZPOOL} destroy ${name0}
|
|
expect_fl ${ZPOOL} status -x ${name0}
|
|
expect_fl ${ZPOOL} destroy ${name0}
|
|
|
|
expect_ok ${ZPOOL} create ${name0} mirror ${disk0} ${disk1} log ${disk2}
|
|
expect_ok ${ZPOOL} status -x ${name0}
|
|
expect "pool '${name0}' is healthy" ${ZPOOL} status -x ${name0}
|
|
exp=`(
|
|
echo " pool: ${name0}"
|
|
echo " state: ONLINE"
|
|
echo " scrub: none requested"
|
|
echo "config:"
|
|
echo " NAME STATE READ WRITE CKSUM"
|
|
echo " ${name0} ONLINE 0 0 0"
|
|
echo " mirror ONLINE 0 0 0"
|
|
echo " ${disk0} ONLINE 0 0 0"
|
|
echo " ${disk1} ONLINE 0 0 0"
|
|
echo " logs ONLINE 0 0 0"
|
|
echo " ${disk2} ONLINE 0 0 0"
|
|
echo "errors: No known data errors"
|
|
)`
|
|
expect "${exp}" ${ZPOOL} status ${name0}
|
|
expect_ok ${ZPOOL} destroy ${name0}
|
|
expect_fl ${ZPOOL} status -x ${name0}
|
|
expect_fl ${ZPOOL} destroy ${name0}
|
|
|
|
expect_ok ${ZPOOL} create ${name0} mirror ${disk0} ${disk1} log mirror ${disk2} ${disk3} ${disk4}
|
|
expect_ok ${ZPOOL} status -x ${name0}
|
|
expect "pool '${name0}' is healthy" ${ZPOOL} status -x ${name0}
|
|
exp=`(
|
|
echo " pool: ${name0}"
|
|
echo " state: ONLINE"
|
|
echo " scrub: none requested"
|
|
echo "config:"
|
|
echo " NAME STATE READ WRITE CKSUM"
|
|
echo " ${name0} ONLINE 0 0 0"
|
|
echo " mirror ONLINE 0 0 0"
|
|
echo " ${disk0} ONLINE 0 0 0"
|
|
echo " ${disk1} ONLINE 0 0 0"
|
|
echo " logs ONLINE 0 0 0"
|
|
echo " mirror ONLINE 0 0 0"
|
|
echo " ${disk2} ONLINE 0 0 0"
|
|
echo " ${disk3} ONLINE 0 0 0"
|
|
echo " ${disk4} ONLINE 0 0 0"
|
|
echo "errors: No known data errors"
|
|
)`
|
|
expect "${exp}" ${ZPOOL} status ${name0}
|
|
expect_ok ${ZPOOL} destroy ${name0}
|
|
expect_fl ${ZPOOL} status -x ${name0}
|
|
expect_fl ${ZPOOL} destroy ${name0}
|
|
|
|
expect_ok ${ZPOOL} create ${name0} raidz ${disk0} ${disk1} ${disk2} log ${disk3}
|
|
expect_ok ${ZPOOL} status -x ${name0}
|
|
expect "pool '${name0}' is healthy" ${ZPOOL} status -x ${name0}
|
|
exp=`(
|
|
echo " pool: ${name0}"
|
|
echo " state: ONLINE"
|
|
echo " scrub: none requested"
|
|
echo "config:"
|
|
echo " NAME STATE READ WRITE CKSUM"
|
|
echo " ${name0} ONLINE 0 0 0"
|
|
echo " raidz1 ONLINE 0 0 0"
|
|
echo " ${disk0} ONLINE 0 0 0"
|
|
echo " ${disk1} ONLINE 0 0 0"
|
|
echo " ${disk2} ONLINE 0 0 0"
|
|
echo " logs ONLINE 0 0 0"
|
|
echo " ${disk3} ONLINE 0 0 0"
|
|
echo "errors: No known data errors"
|
|
)`
|
|
expect "${exp}" ${ZPOOL} status ${name0}
|
|
expect_ok ${ZPOOL} destroy ${name0}
|
|
expect_fl ${ZPOOL} status -x ${name0}
|
|
expect_fl ${ZPOOL} destroy ${name0}
|
|
|
|
expect_ok ${ZPOOL} create ${name0} raidz1 ${disk0} ${disk1} ${disk2} log mirror ${disk3} ${disk4} ${disk5}
|
|
expect_ok ${ZPOOL} status -x ${name0}
|
|
expect "pool '${name0}' is healthy" ${ZPOOL} status -x ${name0}
|
|
exp=`(
|
|
echo " pool: ${name0}"
|
|
echo " state: ONLINE"
|
|
echo " scrub: none requested"
|
|
echo "config:"
|
|
echo " NAME STATE READ WRITE CKSUM"
|
|
echo " ${name0} ONLINE 0 0 0"
|
|
echo " raidz1 ONLINE 0 0 0"
|
|
echo " ${disk0} ONLINE 0 0 0"
|
|
echo " ${disk1} ONLINE 0 0 0"
|
|
echo " ${disk2} ONLINE 0 0 0"
|
|
echo " logs ONLINE 0 0 0"
|
|
echo " mirror ONLINE 0 0 0"
|
|
echo " ${disk3} ONLINE 0 0 0"
|
|
echo " ${disk4} ONLINE 0 0 0"
|
|
echo " ${disk5} ONLINE 0 0 0"
|
|
echo "errors: No known data errors"
|
|
)`
|
|
expect "${exp}" ${ZPOOL} status ${name0}
|
|
expect_ok ${ZPOOL} destroy ${name0}
|
|
expect_fl ${ZPOOL} status -x ${name0}
|
|
expect_fl ${ZPOOL} destroy ${name0}
|
|
|
|
expect_ok ${ZPOOL} create ${name0} raidz2 ${disk0} ${disk1} ${disk2} ${disk3} log ${disk4}
|
|
expect_ok ${ZPOOL} status -x ${name0}
|
|
expect "pool '${name0}' is healthy" ${ZPOOL} status -x ${name0}
|
|
exp=`(
|
|
echo " pool: ${name0}"
|
|
echo " state: ONLINE"
|
|
echo " scrub: none requested"
|
|
echo "config:"
|
|
echo " NAME STATE READ WRITE CKSUM"
|
|
echo " ${name0} ONLINE 0 0 0"
|
|
echo " raidz2 ONLINE 0 0 0"
|
|
echo " ${disk0} ONLINE 0 0 0"
|
|
echo " ${disk1} ONLINE 0 0 0"
|
|
echo " ${disk2} ONLINE 0 0 0"
|
|
echo " ${disk3} ONLINE 0 0 0"
|
|
echo " logs ONLINE 0 0 0"
|
|
echo " ${disk4} ONLINE 0 0 0"
|
|
echo "errors: No known data errors"
|
|
)`
|
|
expect "${exp}" ${ZPOOL} status ${name0}
|
|
expect_ok ${ZPOOL} destroy ${name0}
|
|
expect_fl ${ZPOOL} status -x ${name0}
|
|
expect_fl ${ZPOOL} destroy ${name0}
|
|
|
|
expect_ok ${ZPOOL} create ${name0} raidz2 ${disk0} ${disk1} ${disk2} ${disk3} log mirror ${disk4} ${disk5} ${disk6}
|
|
expect_ok ${ZPOOL} status -x ${name0}
|
|
expect "pool '${name0}' is healthy" ${ZPOOL} status -x ${name0}
|
|
exp=`(
|
|
echo " pool: ${name0}"
|
|
echo " state: ONLINE"
|
|
echo " scrub: none requested"
|
|
echo "config:"
|
|
echo " NAME STATE READ WRITE CKSUM"
|
|
echo " ${name0} ONLINE 0 0 0"
|
|
echo " raidz2 ONLINE 0 0 0"
|
|
echo " ${disk0} ONLINE 0 0 0"
|
|
echo " ${disk1} ONLINE 0 0 0"
|
|
echo " ${disk2} ONLINE 0 0 0"
|
|
echo " ${disk3} ONLINE 0 0 0"
|
|
echo " logs ONLINE 0 0 0"
|
|
echo " mirror ONLINE 0 0 0"
|
|
echo " ${disk4} ONLINE 0 0 0"
|
|
echo " ${disk5} ONLINE 0 0 0"
|
|
echo " ${disk6} ONLINE 0 0 0"
|
|
echo "errors: No known data errors"
|
|
)`
|
|
expect "${exp}" ${ZPOOL} status ${name0}
|
|
expect_ok ${ZPOOL} destroy ${name0}
|
|
expect_fl ${ZPOOL} status -x ${name0}
|
|
expect_fl ${ZPOOL} destroy ${name0}
|
|
|
|
disks_destroy
|