如何在VMware中添加新磁盘并设置多写模式以模拟Oracle RAC共享磁盘?

2026-04-28 22:384阅读0评论SEO基础
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1378个文字,预计阅读时间需要6分钟。

如何在VMware中添加新磁盘并设置多写模式以模拟Oracle RAC共享磁盘?

请提供需要改写的伪原创内容,我将根据您的要求进行修改。

VMware里添加磁盘必须关机,否则多写入器不可选

直接在运行中的虚拟机上点“添加硬盘”,共享类型下拉菜单里根本不会出现“多写入器”选项——这是 vmware 的硬限制。只有当虚拟机处于完全关闭状态(不是挂起、不是休眠),在“编辑虚拟机设置 → 添加 → 硬盘 → 创建新虚拟磁盘”流程中,才能看到并选择该选项。

常见错误现象:共享类型灰显、仅显示“无”或“可读写”,或者添加后在另一台虚拟机里选不到该磁盘。

  • 务必确认虚拟机电源状态为“已关闭”,不是“客户机已关机”(后者可能只是操作系统退出,VM still running)
  • SCSI 控制器必须是新建的,不能复用默认的 SCSI 0:0;建议新增一个 SCSI 1:0 专用控制器
  • 磁盘类型必须选“厚置备立即置零”,“精简置备”或“厚置备延迟置零”均不支持多写入器
  • 磁盘模式必须设为“独立-持久”,“独立-非持久”或“从属”都会导致 RAC 启动时校验失败

两台虚拟机挂载同一块磁盘:路径和配置必须完全一致

Oracle RAC 要求所有节点看到的共享磁盘设备名、容量、扇区对齐、控制器绑定方式完全一致。VMware 不会自动同步这些元信息,靠人工核对。

实操关键点:

  • A 虚拟机添加磁盘后,记下完整路径,例如:[datastore1] rac-cluster/rac1.vmdk —— 注意含方括号和斜杠,大小写敏感
  • B 虚拟机添加设备时,必须选“使用现有虚拟磁盘”,然后精确粘贴该路径,不能通过浏览选择(浏览可能返回不同路径别名)
  • B 虚拟机的 SCSI 控制器编号、设备节点(如 SCSI 1:0)、共享类型磁盘模式三项必须与 A 完全相同,连空格都不能差
  • 添加完成后,在两台虚拟机里都执行 ls -l /dev/disks/by-id/,确认看到相同 WWN 或 scsi-xxx 设备名;RAC 安装前必须确保这点

Linux 侧识别不到 /dev/sdX?检查 udev 规则和 multipath

即使 VMware 层配置正确,Linux 内核也可能把同一块共享磁盘识别成多个路径(比如 /dev/sdb/dev/sdc),导致 ASM 无法稳定使用。

这不是 VMware 错误,而是 Linux 多路径行为导致的典型问题:

  • 先运行 fdisk -l | grep "Disk /dev/sd",看是否列出多个同容量磁盘设备
  • 检查是否启用了 multipathd:运行 systemctl status multipathd,若启用,需在 /etc/multipath.conf 中屏蔽共享磁盘(用 WWN 或 vendor/model 匹配),否则 multipath 会自动聚合它们,ASM 会拒绝访问聚合后的 /dev/mapper/mpathx
  • 更稳妥做法是禁用 multipath 对 RAC 磁盘的管理:在 /etc/multipath.conf 中添加 blacklist { devnode "^sd[b-z]" }(根据实际设备范围调整),然后重启服务
  • 确认 udev 规则是否固定设备名:RAC 推荐用 /dev/oracleasm 或基于 WWN 的软链接(如 /dev/disk/by-id/scsi-36000c29...),避免依赖 /dev/sdX 这种易变名

CBT(变更块跟踪)和多写入器冲突,必须关闭

如果虚拟机启用了 CBT(常用于 vSphere 备份加速),又同时开启多写入器,VMware 会报错:Cannot enable CBT on a disk with multi-writer mode enabled,且虚拟机无法启动。

这是因为 CBT 需要独占磁盘写入日志,而多写入器允许多个 VM 并发写入同一块磁盘,二者底层机制互斥。

  • 关闭 CBT 方法:编辑虚拟机设置 → 选项 → 高级 → 配置参数 → 找到 ctkEnabled,设为 false;再找 scsi0:0.ctkEnabled(按实际控制器和磁盘编号替换),也设为 false
  • 修改后必须彻底关闭虚拟机(不是重启),再开机才生效
  • 注意:关闭 CBT 会影响后续基于快照的备份效率,但对 RAC 功能本身无影响;生产环境若需两者共存,只能改用 Raw Device Mapping(RDM)模式
多写入器配置本身不难,真正卡住人的永远是路径一致性、Linux 设备名稳定性、以及 CBT 这类隐式开关的冲突。尤其是路径拼写差一个字符、控制器编号不一致、或忘了关 CBT,都会让 OCR 磁盘初始化失败,而错误日志往往只报“ASM cannot discover disk”,不会告诉你 VMware 层哪步错了。

本文共计1378个文字,预计阅读时间需要6分钟。

如何在VMware中添加新磁盘并设置多写模式以模拟Oracle RAC共享磁盘?

请提供需要改写的伪原创内容,我将根据您的要求进行修改。

VMware里添加磁盘必须关机,否则多写入器不可选

直接在运行中的虚拟机上点“添加硬盘”,共享类型下拉菜单里根本不会出现“多写入器”选项——这是 vmware 的硬限制。只有当虚拟机处于完全关闭状态(不是挂起、不是休眠),在“编辑虚拟机设置 → 添加 → 硬盘 → 创建新虚拟磁盘”流程中,才能看到并选择该选项。

常见错误现象:共享类型灰显、仅显示“无”或“可读写”,或者添加后在另一台虚拟机里选不到该磁盘。

  • 务必确认虚拟机电源状态为“已关闭”,不是“客户机已关机”(后者可能只是操作系统退出,VM still running)
  • SCSI 控制器必须是新建的,不能复用默认的 SCSI 0:0;建议新增一个 SCSI 1:0 专用控制器
  • 磁盘类型必须选“厚置备立即置零”,“精简置备”或“厚置备延迟置零”均不支持多写入器
  • 磁盘模式必须设为“独立-持久”,“独立-非持久”或“从属”都会导致 RAC 启动时校验失败

两台虚拟机挂载同一块磁盘:路径和配置必须完全一致

Oracle RAC 要求所有节点看到的共享磁盘设备名、容量、扇区对齐、控制器绑定方式完全一致。VMware 不会自动同步这些元信息,靠人工核对。

实操关键点:

  • A 虚拟机添加磁盘后,记下完整路径,例如:[datastore1] rac-cluster/rac1.vmdk —— 注意含方括号和斜杠,大小写敏感
  • B 虚拟机添加设备时,必须选“使用现有虚拟磁盘”,然后精确粘贴该路径,不能通过浏览选择(浏览可能返回不同路径别名)
  • B 虚拟机的 SCSI 控制器编号、设备节点(如 SCSI 1:0)、共享类型磁盘模式三项必须与 A 完全相同,连空格都不能差
  • 添加完成后,在两台虚拟机里都执行 ls -l /dev/disks/by-id/,确认看到相同 WWN 或 scsi-xxx 设备名;RAC 安装前必须确保这点

Linux 侧识别不到 /dev/sdX?检查 udev 规则和 multipath

即使 VMware 层配置正确,Linux 内核也可能把同一块共享磁盘识别成多个路径(比如 /dev/sdb/dev/sdc),导致 ASM 无法稳定使用。

这不是 VMware 错误,而是 Linux 多路径行为导致的典型问题:

  • 先运行 fdisk -l | grep "Disk /dev/sd",看是否列出多个同容量磁盘设备
  • 检查是否启用了 multipathd:运行 systemctl status multipathd,若启用,需在 /etc/multipath.conf 中屏蔽共享磁盘(用 WWN 或 vendor/model 匹配),否则 multipath 会自动聚合它们,ASM 会拒绝访问聚合后的 /dev/mapper/mpathx
  • 更稳妥做法是禁用 multipath 对 RAC 磁盘的管理:在 /etc/multipath.conf 中添加 blacklist { devnode "^sd[b-z]" }(根据实际设备范围调整),然后重启服务
  • 确认 udev 规则是否固定设备名:RAC 推荐用 /dev/oracleasm 或基于 WWN 的软链接(如 /dev/disk/by-id/scsi-36000c29...),避免依赖 /dev/sdX 这种易变名

CBT(变更块跟踪)和多写入器冲突,必须关闭

如果虚拟机启用了 CBT(常用于 vSphere 备份加速),又同时开启多写入器,VMware 会报错:Cannot enable CBT on a disk with multi-writer mode enabled,且虚拟机无法启动。

这是因为 CBT 需要独占磁盘写入日志,而多写入器允许多个 VM 并发写入同一块磁盘,二者底层机制互斥。

  • 关闭 CBT 方法:编辑虚拟机设置 → 选项 → 高级 → 配置参数 → 找到 ctkEnabled,设为 false;再找 scsi0:0.ctkEnabled(按实际控制器和磁盘编号替换),也设为 false
  • 修改后必须彻底关闭虚拟机(不是重启),再开机才生效
  • 注意:关闭 CBT 会影响后续基于快照的备份效率,但对 RAC 功能本身无影响;生产环境若需两者共存,只能改用 Raw Device Mapping(RDM)模式
多写入器配置本身不难,真正卡住人的永远是路径一致性、Linux 设备名稳定性、以及 CBT 这类隐式开关的冲突。尤其是路径拼写差一个字符、控制器编号不一致、或忘了关 CBT,都会让 OCR 磁盘初始化失败,而错误日志往往只报“ASM cannot discover disk”,不会告诉你 VMware 层哪步错了。