本节介绍如何为群集配置创建磁盘集。在 Sun Cluster 环境中创建 Solaris Volume Manager 磁盘集时,该磁盘集会自动向 Sun Cluster 软件注册为 svm 类型的设备组。要创建或删除 svm 设备组,必须使用 Solaris Volume Manager 的命令和实用程序创建或删除设备组的底层磁盘集。
要创建供 Oracle Real Application Clusters 使用的 Solaris Volume Manager for Sun Cluster 磁盘集,请勿使用这些过程。请改为执行《Sun Cluster Data Service for Oracle RAC Guide for Solaris OS》中的“How to Create a Multi-Owner Disk Set in Solaris Volume Manager for Sun Cluster for the Oracle RAC Database”中的过程。
下表列出了您将执行以创建磁盘集的任务。按照以下顺序完成操作。
表 4–2 任务表:安装和配置 Solaris Volume Manager 软件
任务 |
指导 |
---|---|
使用 metaset 命令创建磁盘集。 | |
将驱动器添加到磁盘集。 | |
(可选)对磁盘集中的驱动器重新分区,以便为不同的分片分配空间。 | |
列出 DID 伪驱动程序映射,并在 /etc/lvm/md.tab 文件中定义卷。 | |
初始化 md.tab 文件。 |
请执行以下过程来创建磁盘集。
此过程提供了 Sun Cluster 命令的完整形式。此外,大多数命令还有简短格式。除了命令名称的形式以外,简写形式和完整形式的命令是相同的。有关命令及其简称的列表,请参见《Sun Cluster 系统管理指南(适用于 Solaris OS)》中的附录 B “Sun Cluster 面向对象的命令”。
SPARC:(Solaris 9)确定在创建新的磁盘集后,全局群集中是否将包含三个以上的磁盘集。
在该群集的任何节点上,检查 /kernel/drv/md.conf 文件中的 md_nsets 变量值。
如果群集中磁盘集的总数大于 md_nsets 的现有值减一,请将 md_nsets 的值增加到所需的值。
允许磁盘集数目具有的最大值为 md_nsets 的配置值减一。md_nsets 可能具有的最大值为 32,因此可以创建的磁盘集的最大数目为 31。
确保 /kernel/drv/md.conf 文件在群集的每个节点上都完全相同。
不按本指南操作可能会导致严重的 Solaris Volume Manager 错误,并且可能丢失数据。
如果更改了任一节点上的 md.conf 文件,请执行以下步骤以使这些更改生效。
在一个节点上成为超级用户。
从一个节点,关闭群集。
phys-schost# cluster shutdown -g0 -y |
重新引导群集的每个节点。
在基于 SPARC 的系统中执行以下操作:
ok boot |
在基于 x86 的系统中执行以下操作:
显示 GRUB 菜单后,选择相应的 Solaris 条目,然后按 Enter 键。GRUB 菜单显示类似于以下内容:
GNU GRUB version 0.95 (631K lower / 2095488K upper memory) +-------------------------------------------------------------------------+ | Solaris 10 /sol_10_x86 | | Solaris failsafe | | | +-------------------------------------------------------------------------+ Use the ^ and v keys to select which entry is highlighted. Press enter to boot the selected OS, 'e' to edit the commands before booting, or 'c' for a command-line. |
有关基于 GRUB 进行引导的更多信息,请参见《系统管理指南:基本管理》中的“使用 GRUB 引导基于 x86 的系统(任务图)”。
在群集的每个节点上,运行 devfsadm(1M) 命令。
您可以同时在群集的所有节点上运行此命令。
phys-schost# cldevice populate |
有关更多信息,请参见 cldevice(1CL) 手册页。
尝试创建任何磁盘集之前,请先在每个节点上检验该命令是否已完成处理。
即使仅从一个节点运行,该命令也会以远程方式在所有的节点上执行。要确定该命令是否已完成处理过程,请在群集中的每个节点上运行以下命令。
phys-schost# ps -ef | grep scgdevs |
确保要创建的磁盘集符合以下要求之一。
如果正好用两个磁盘串配置磁盘集,则磁盘集必须正好连接至两个节点并正好使用两个介体主机。这些介体主机必须是用于该磁盘集的两个主机。有关如何配置双串介体的详细信息,请参见配置双串介体。
如果为磁盘集配置了两个以上的磁盘串,则应确保任意两个磁盘串 S1 和 S2 上的驱动器数目之和都会超过第三个磁盘串 S3 上的驱动器数目。用一个公式来表示,该需求为 count(S1) + count(S2) > count(S3)。
确保有本地状态数据库的副本。
有关说明,请参见如何创建状态数据库副本。
成为将控制磁盘集的群集节点上的超级用户。
创建磁盘集。
以下命令可创建磁盘集并将其注册为 Sun Cluster 设备组。
phys-schost# metaset -s setname -a -h node1 node2 |
指定磁盘集名称。
添加(创建)磁盘集。
指定将控制磁盘集的主节点的名称。
指定将控制磁组集的辅助节点的名称
运行 metaset 命令以配置群集上的 Solaris Volume Manager 设备组时,默认情况下,该命令将指定一个辅助节点。创建设备组之后,可以使用 clsetup 实用程序更改设备组中所需的辅助节点数目。有关如何更改 numsecondaries 属性的更多信息,请参阅《Sun Cluster 系统管理指南(适用于 Solaris OS)》中的“管理设备组”。
如果要配置复制的 Solstice DiskSuite 或 Solaris Volume Manager 设备组,请为该设备组设置复制属性。
phys-schost# cldevicegroup sync device-group-name |
有关数据复制的更多信息,请参见《Sun Cluster 系统管理指南(适用于 Solaris OS)》中的第 4 章 “数据复制方法”。
检验新磁盘集的状态。
phys-schost# metaset -s setname |
根据需要设置设备组的属性。
phys-schost# cldevicegroup set -p name=value devicegroup |
指定一个设备组属性。
指定属性的名称。
指定属性的值或设置。
指定设备组的名称。设备组名称与磁盘集名称相同。
有关设备组属性的信息,请参见 cldevicegroup(1CL)。
以下命令将创建 dg-schost-1 和 dg-schost-2 这两个磁盘集,同时将节点 phys-schost-1 和 phys-schost-2 指定为潜在的主节点。
phys-schost# metaset -s dg-schost-1 -a -h phys-schost-1 phys-schost-2 phys-schost# metaset -s dg-schost-2 -a -h phys-schost-1 phys-schost-2 |
将驱动器添加至磁盘集。请转至将驱动器添加到磁盘集。
将驱动器添加到磁盘集时,卷管理软件将按照以下原则对驱动器进行重新分区,以便将磁盘集的状态数据库放入驱动器。
每个驱动器都有一小部分被保留用于 Solaris Volume Manager 软件。在带有卷目录 (VTOC) 标记的设备中,使用分片 7。在带有 可扩展固件接口 (EFI) 标记的设备中,使用分片 6。每个驱动器上的剩余空间将放到分片 0 中。
将驱动器添加到磁盘集中时,只有在目标分片配置不正确的情况下才会对驱动器进行重新分区。
重新分区时,驱动器中的所有现有数据都将丢失。
如果目标分片是从 0 柱面开始的,而驱动器分区的大小又足以包含一个状态数据库副本,则驱动器不会进行重新分区。
确保已创建磁盘集。有关说明,请参见如何创建磁盘集。
成为超级用户。
phys-schost# cldevice show | grep Device |
选择由将要控制或可能要控制磁盘集的群集节点共享的驱动器。
向磁盘集中添加驱动器时,请使用格式为 /dev/did/rdsk/dN 的完整 DID 设备名称。
在以下示例中,DID 设备 /dev/did/rdsk/d3 的条目表明该驱动器由 phys-schost-1 和 phys-schost-2 共享。
=== DID Device Instances === DID Device Name: /dev/did/rdsk/d1 Full Device Path: phys-schost-1:/dev/rdsk/c0t0d0 DID Device Name: /dev/did/rdsk/d2 Full Device Path: phys-schost-1:/dev/rdsk/c0t6d0 DID Device Name: /dev/did/rdsk/d3 Full Device Path: phys-schost-1:/dev/rdsk/c1t1d0 Full Device Path: phys-schost-2:/dev/rdsk/c1t1d0 … |
成为磁盘集的拥有者。
phys-schost# cldevicegroup switch -n node devicegroup |
指定拥有设备组所有权的节点。
指定设备组名称,该名称与磁盘集名称相同。
将驱动器添加到磁盘集。
使用完整的 DID 路径名称。
phys-schost# metaset -s setname -a /dev/did/rdsk/dN |
指定磁盘集的名称,该名称与设备组名称相同。
给磁盘集添加驱动器。
在向磁盘集中添加驱动器时,不要使用低级别的设备名称 (cNtXdY)。因为低级别设备名称是本地名称,并且在整个群集中不是唯一的,所以使用该名称可能使元集无法切换。
检验磁盘集和驱动器的状态。
phys-schost# metaset -s setname |
metaset 命令将驱动器 /dev/did/rdsk/d1 和 /dev/did/rdsk/d2 添加到磁盘集 dg-schost-1 中。
phys-schost# metaset -s dg-schost-1 -a /dev/did/rdsk/d1 /dev/did/rdsk/d2 |
要将驱动器重新分区以便在卷中使用,请转至如何对磁盘集中的驱动器重新分区。
否则,请转至如何创建 md.tab 文件以使用 md.tab 文件定义元设备或卷。
metaset(1M) 命令将磁盘集中的驱动器重新分区,以便保留每个驱动器的一小部分以供 Solaris Volume Manager 软件使用。在带有卷目录 (VTOC) 标记的设备中,使用分片 7。在带有 可扩展固件接口 (EFI) 标记的设备中,使用分片 6。每个驱动器上的剩余空间将放到分片 0 中。为了更有效地使用驱动器,请使用以下过程修改磁盘布局。如果将空间分配给 VTOC 分片 1 至 6 或 EFI 分片 1 至 5,则可在设置 Solaris Volume Manager 卷时使用这些分片。
成为超级用户。
使用 format 命令更改磁盘集中每个驱动器的磁盘分区情况。
将驱动器重新分区时,必须满足以下条件,以防止 metaset(1M) 命令将该驱动器重新分区。
创建分片 7(对于 VTOC)或分片 6(对于 EFI),该分片应从柱面 0 开始,大小应足以容纳一个状态数据库副本。请参见 Solaris Volume Manager 管理指南来确定您的卷管理器软件版本的状态数据库副本的大小。
将目标分片中的 Flag 字段设置为 wu(可读写,无法卸载)。不要将其设置为只读。
不要让目标分片覆盖驱动器上的任何其他分片。
有关详细信息,请参见 format(1M) 手册页。
使用 md.tab 文件定义卷。请转至如何创建 md.tab 文件。
在群集中的每个节点上创建一个 /etc/lvm/md.tab 文件。使用 md.tab 文件为您创建的磁盘集定义 Solaris Volume Manager 卷。
如果要使用本地卷,请确保本地卷名称与用于构成磁盘集的设备 ID 名称不同。例如,如果在磁盘集中使用了设备 ID 名称 /dev/did/dsk/d3,请勿将名称 /dev/md/dsk/d3 用于本地卷。此要求不适用于共享卷,共享卷使用命名约定 /dev/md/setname/{r}dsk/d#。
成为超级用户。
列出可供在创建 md.tab 文件时参考的 DID 映射。
请使用 md.tab 文件中的完整 DID 设备名称代替低级别设备名称 (cN tXdY)。DID 设备名称采用的格式为 /dev/did/rdsk/dN。
phys-schost# cldevice show | grep Device |
=== DID Device Instances === DID Device Name: /dev/did/rdsk/d1 Full Device Path: phys-schost-1:/dev/rdsk/c0t0d0 DID Device Name: /dev/did/rdsk/d2 Full Device Path: phys-schost-1:/dev/rdsk/c0t6d0 DID Device Name: /dev/did/rdsk/d3 Full Device Path: phys-schost-1:/dev/rdsk/c1t1d0 Full Device Path: phys-schost-2:/dev/rdsk/c1t1d0 … |
创建一个 /etc/lvm/md.tab 文件,并使用您的首选文本编辑器编辑该文件。
如果将用于子镜像的驱动器上已经有数据,在设置卷之前必须先备份这些数据。然后将数据恢复到镜像上。
为避免群集环境内不同节点上的本地卷之间产生混淆,请使用一种可以使每个本地卷名称在整个群集中都唯一的命名方案。例如,对于节点 1,选择 d100 到 d199 之间的名称。对于节点 2,则使用 d200 到 d299 之间的名称。
有关如何创建 md.tab 文件的详细信息,请参见 Solaris Volume Manager 文档和 md.tab(4) 手册页。
下面的样例 md.tab 文件定义了名为 dg-schost-1 的磁盘集。md.tab 文件中各行的顺序并不重要。
dg-schost-1/d0 -m dg-schost-1/d10 dg-schost-1/d20 dg-schost-1/d10 1 1 /dev/did/rdsk/d1s0 dg-schost-1/d20 1 1 /dev/did/rdsk/d2s0 |
样例 md.tab 文件的结构如下所示。
第一行将设备 d0 定义为卷 d10 和 d20 的镜像。-m 表示该设备为镜像设备。
dg-schost-1/d0 -m dg-schost-1/d0 dg-schost-1/d20 |
第二行将卷 d10(d0 的第一个子镜像)定义为单向存储条。
dg-schost-1/d10 1 1 /dev/did/rdsk/d1s0 |
第三行将卷 d20(d0 的第二个子镜像)定义为单向存储条。
dg-schost-1/d20 1 1 /dev/did/rdsk/d2s0 |
激活在 md.tab 文件中定义的卷。请转至如何激活卷。
执行此过程可激活在 md.tab 文件中定义的 Solaris Volume Manager 卷。
成为超级用户。
确保 md.tab 文件位于 /etc/lvm 目录中。
确保您对将要在其中执行命令的节点上的磁盘集具有拥有权。
获取磁盘集的拥有权。
phys-schost# cldevicegroup switch -n node devicegroup |
指定拥有所有权的节点。
指定磁盘集名称。
激活在 md.tab 文件中定义的磁盘集所属卷。
phys-schost# metainit -s setname -a |
指定磁盘集名称。
激活 md.tab 文件中的所有卷。
如有必要,请从另一个连接到驱动器的节点运行 metainit(1M) 命令。该步骤对于群集对拓扑是必需的,因为在此类拓扑中,并非所有节点都能访问驱动器。
检查卷的状态。
phys-schost# metastat -s setname |
有关更多信息,请参见 metastat(1M) 手册页。
(可选的)捕获磁盘分区信息,以供将来参考之用。
phys-schost# prtvtoc /dev/rdsk/cNtXdYsZ > filename |
应将该文件存储在群集外部的某个位置。如果对磁盘配置进行了任何更改,请再次运行此命令以捕获更改后的配置信息。如果磁盘发生故障需要更换,则可以使用此信息来恢复磁盘分区配置。有关更多信息,请参见 prtvtoc(1M) 手册页。
(可选的)创建群集配置的备份。
对群集配置的归档备份有助于您更方便地恢复群集配置。有关更多信息,请参见《Sun Cluster 系统管理指南(适用于 Solaris OS)》中的“如何备份群集配置”。
在以下示例中,在 md.tab 文件中为磁盘集 dg-schost-1 定义的所有卷均被激活。
phys-schost# metainit -s dg-schost-1 -a |
如果群集包含正好配置了两个磁盘附件的磁盘集并且包含两个节点,请添加双串介体。请转至配置双串介体。
否则,请转至如何创建群集文件系统以创建群集文件系统。