- 论坛徽章:
- 0
|
zpool add/remove
在zpool create/destroy一节中,我们讲了怎样创建和删除一个pool。我们之所以说ZFS简单易用,就是它把系统管理员从复杂而繁琐的管理工作中解放出来,从而将更多的时间花在系统的整体构架上,而不是被日常的管理束缚住手脚和头脑。记得九月份在上海出差参加Sun Tech Days活动,在展台上和很多来自各个行业的软件开发者,系统管理员,系统工程师聊。大家有一个共同的认识就是,现在的volume management + 文件系统的管理方式在做系统扩充和缩小时非常复杂,常常为此提前要做各方面的准备,实施计划,操作流程,回退计划等等。而且,往往这些操作需要宕机做offline工作。我想有过这方面经验的人大概都会有这样的经历。
那么,现在我们有了新的选择:ZFS。我们叫ZFS为文件系统,其实ZFS是集volume management和文件系统功能于一体。对于用户来说,它的volume management功能是透明的。ZFS提供了两个简单的命令add/remove来解决系统扩充和缩小需要。而且,一切都是online操作,一切在线业务都不需要停机。zfs add/remove语法如下:
--------------------------------------------------------------------------------
zpool add [-fn] pool vdev ...
zpool remove pool vdev
--------------------------------------------------------------------------------
注:当前remove操作只支持对hot spares设备的删除。
我们做一些实验,实验系统环境如下:
# format
Searching for disks...done
AVAILABLE DISK SELECTIONS:
0. c1t0d0 <SUN36G cyl 24620 alt 2 hd 27 sec 107>
/pci@8,600000/SUNW,qlc@2/fp@0,0/ssd@w21000004cf836e64,0
1. c1t2d0 <SEAGATE-ST336605FSUN36G-0438-33.92GB>
/pci@8,600000/SUNW,qlc@2/fp@0,0/ssd@w21000004cf836e65,0
2. c1t3d0 <SEAGATE-ST336605FSUN36G-0438-33.92GB>
/pci@8,600000/SUNW,qlc@2/fp@0,0/ssd@w21000004cf836e6a,0
3. c1t4d0 <SEAGATE-ST336605FSUN36G-0438-33.92GB>
/pci@8,600000/SUNW,qlc@2/fp@0,0/ssd@w21000004cf836e60,0
4. c2t1d0 <SEAGATE-ST318404LSUN18G-4207-16.87GB>
/pci@9,700000/scsi@3/sd@1,0
5. c2t2d0 <SEAGATE-ST318404LSUN18G-4207-16.87GB>
/pci@9,700000/scsi@3/sd@2,0
6. c2t4d0 <SEAGATE-ST318404LSUN18G-4207-16.87GB>
/pci@9,700000/scsi@3/sd@4,0
7. c2t5d0 <SEAGATE-ST318404LSUN18G-4207-16.87GB>
/pci@9,700000/scsi@3/sd@5,0
1. 建立一个pool,然后再增加其空间一倍。
# zpool create mypool c2t5d0
# zfs list
NAME USED AVAIL REFER MOUNTPOINT
mypool 85K 16.5G 24.5K /mypool
# zpool add mypool c2t4d0
# zfs list
NAME USED AVAIL REFER MOUNTPOINT
mypool 88K 33.0G 24.5K /mypool
我们可以看到,再mypool增加了一个新的disk后空间从16.5G变为33.0G。
# zpool status -v mypool
pool: mypool
state: ONLINE
scrub: none requested
config:
NAME STATE READ WRITE CKSUM
mypool ONLINE 0 0 0
c2t5d0 ONLINE 0 0 0
c2t4d0 ONLINE 0 0 0
errors: No known data errors
我们可以从上面zpool status的输出清晰的看出mypool的盘结构。
# zpool destroy mypool
删除mypool
2. 建立一个2路的mirror,再为其扩充空间。
# zpool destroy mymirror
# zpool create mymirror mirror c2t1d0 c2t2d0
# zfs list
NAME USED AVAIL REFER MOUNTPOINT
mymirror 86K 16.5G 24.5K /mymirror
# zpool status mymirror
pool: mymirror
state: ONLINE
scrub: none requested
config:
NAME STATE READ WRITE CKSUM
mymirror ONLINE 0 0 0
mirror ONLINE 0 0 0
c2t1d0 ONLINE 0 0 0
c2t2d0 ONLINE 0 0 0
errors: No known data errors
两个大小分别为16G的硬盘构成一个2路的mirror,容积仍然为16G。
# zpool add mymirror mirror c2t4d0 c2t5d0
# zpool status mymirror
pool: mymirror
state: ONLINE
scrub: none requested
config:
NAME STATE READ WRITE CKSUM
mymirror ONLINE 0 0 0
mirror ONLINE 0 0 0
c2t1d0 ONLINE 0 0 0
c2t2d0 ONLINE 0 0 0
mirror ONLINE 0 0 0
c2t4d0 ONLINE 0 0 0
c2t5d0 ONLINE 0 0 0
errors: No known data errors
# zfs list
NAME USED AVAIL REFER MOUNTPOINT
mymirror 88K 33.0G 24.5K /mymirror
结果显而易见,mymirror的大小变为33G。
# zpool destroy mymirror
3. 建立一个raidz池,增加hot spares设备,然后删除。
# zpool create mypool raidz c2t1d0 c2t2d0 c2t4d0 spare c2t5d0
# zfs list
NAME USED AVAIL REFER MOUNTPOINT
mypool 102K 33.1G 32.6K /mypool
# zpool status mypool
pool: mypool
state: ONLINE
scrub: none requested
config:
NAME STATE READ WRITE CKSUM
mypool ONLINE 0 0 0
raidz1 ONLINE 0 0 0
c2t1d0 ONLINE 0 0 0
c2t2d0 ONLINE 0 0 0
c2t4d0 ONLINE 0 0 0
spares
c2t5d0 AVAIL
errors: No known data errors
对于raidz/raidz1/raidz2来说,整个池的大小等于(N-P) * min(disk size)。N表示disk个数,P为冗余盘的个数,即1或者2。raidz是raidz1的alias。关于数据冗余,我会在以后专门拿出来讨论。hot spares设备不计入池空间。
# zpool remove mypool c2t5d0
hot spares设备被删除。
# zpool status mypool
pool: mypool
state: ONLINE
scrub: none requested
config:
NAME STATE READ WRITE CKSUM
mypool ONLINE 0 0 0
raidz1 ONLINE 0 0 0
c2t1d0 ONLINE 0 0 0
c2t2d0 ONLINE 0 0 0
c2t4d0 ONLINE 0 0 0
errors: No known data errors
# zfs list
NAME USED AVAIL REFER MOUNTPOINT
mypool 102K 33.1G 32.6K /mypool
# zpool destroy mypool
add/remove是对整个池的大小的修改,但如果我想将一个简单的stripe文件系统变成一个带冗余的mirror,该怎么办?或者想将一个3路mirror变成2路的又该如何?add/remove是没法做到这一点的。这就是我们下一次要探讨的zpool attach/detach。
http://blogs.sun.com/forrest/ent ... _2_zpool_add_remove |
|