Linux :将直连卷或 SAN 卷添加到存储节点

如果存储节点包含的存储卷少于 16 个,则可以通过添加新的块存储设备,使其对 Linux 主机可见,并将新的块设备映射添加到 StorageGRID 用于存储节点的 StorageGRID Webscale 配置文件来增加其容量。

开始之前

注意: 在软件升级,恢复操作步骤或其他扩展操作步骤处于活动状态时,请勿尝试向存储节点添加存储卷。

关于本任务

添加存储卷时,此存储节点将暂时不可用。您应一次在一个存储节点上执行此操作步骤,以避免影响面向客户端的网格服务。

过程

  1. 安装新的存储硬件。
    有关详细信息,请参见硬件供应商提供的文档。
  2. 创建所需大小的新块存储卷。
    • 连接新磁盘驱动器并根据需要更新 RAID 控制器配置,或者在共享存储阵列上分配新的 SAN LUN 并允许 Linux 主机访问这些 LUN 。
    • 请使用与现有存储节点上的存储卷相同的永久性命名方案。
    • 如果使用 StorageGRID 节点迁移功能,请使作为此存储节点迁移目标的其他 Linux 主机可以看到新卷。
    有关详细信息,请参见有关为 StorageGRID Red Hat Enterprise Linux 或 CentOS 部署安装 StorageGRID Webscale 的说明。
  3. 以 root 身份或使用具有 sudo 权限的帐户登录到支持存储节点的 Linux 主机。
  4. 确认新存储卷在 Linux 主机上可见。
    您可能需要重新扫描设备。
  5. 运行以下命令以临时禁用存储节点:sudo storagegrid node stop <node-name>
  6. 使用 vim 或 pico 等文本编辑器编辑存储节点的节点配置文件,该文件位于 /etc/storagegrid/nodes/<node-name>.conf
  7. 找到节点配置文件中包含现有对象存储块设备映射的部分。
    在此示例中,此部分 以粗体显示
    node_type = VM_Storage_Node
    admin_ip = 10.1.0.2
    block_device_var_local = /dev/mapper/sgws-SN1-var-local
    block_device_RANGEDB_00 = /dev/mapper/sgws-SN1-rangedb-0
    block_device_RANGEDB_01 = /dev/mapper/sgws-SN1-rangedb-1
    block_device_RANGEDB_02 = /dev/mapper/sgws-SN1-rangedb-2
    block_device_RANGEDB_03 = /dev/mapper/sgws-SN1-rangedb-3
    grid_network_target = bond0.1001.
    admin_network_target = bond0.1002.
    client_network_target = bond0.1003
    GRID_NETWORK_IP = 10.1.0.3
    grid_network_mask = 255.255.255.0
    grid_network_gateway = 10.1.0.1
  8. 添加与为此存储节点添加的块存储卷对应的新对象存储块设备映射。
    确保从下一 BLOCK_DEVICE_RANGEDB_NN个开始。请勿留下空隙。
    • 对于上述示例,请从 BLOCK_DEVICE_RANGEDB_04开始。
    • 在以下示例中,节点中添加了四个新的块存储卷。新映射 以粗体显示
    node_type = VM_Storage_Node
    admin_ip = 10.1.0.2
    block_device_var_local = /dev/mapper/sgws-SN1-var-local
    block_device_RANGEDB_00 = /dev/mapper/sgws-SN1-rangedb-0
    block_device_RANGEDB_01 = /dev/mapper/sgws-SN1-rangedb-1
    block_device_RANGEDB_02 = /dev/mapper/sgws-SN1-rangedb-2
    block_device_RANGEDB_03 = /dev/mapper/sgws-SN1-rangedb-3
    block_device_RANGEDB_04 = /dev/mapper/sgws-SN1-rangedb-4
    block_device_RANGEDB_05 = /dev/mapper/sgws-SN1-rangedb-5
    block_device_RANGEDB_06 = /dev/mapper/sgws-SN1-rangedb-6
    block_device_RANGEDB_07 = /dev/mapper/sgws-SN1-rangedb-7
    grid_network_target = bond0.1001.
    admin_network_target = bond0.1002.
    client_network_target = bond0.1003
    GRID_NETWORK_IP = 10.1.0.3
    grid_network_mask = 255.255.255.0
    grid_network_gateway = 10.1.0.1
  9. 运行以下命令以验证对存储节点的节点配置文件所做的更改:
    sudo storagegrid node validate <node-name>

    解决所有错误或警告,然后再继续下一步。

    注: 如果您发现类似以下内容的错误,则表示节点配置文件正在尝试将 <node-name> 用于 <PURPOSE><path-name> 的块设备映射到 Linux 文件系统中的给定。 但该位置没有有效的块设备专用文件(或指向块设备专用文件的软链接)。
    正在检查节点… 的配置文件
    错误: block_device_<purpose = <path-name>
    路径名称 > 不是有效的块设备
    验证输入的是否正确 <path-name>
  10. 运行以下命令以重新启动具有新块设备映射的节点:
    sudo storagegrid node start <node-name>
  11. 使用 Passwords.txt 文件中列出的密码以管理员身份登录到存储节点。
  12. 检查服务是否正确启动:
    1. 查看服务器上所有服务的状态列表: sudo storagegrid-status
      状态将自动更新。
    2. 请等待所有服务均已运行或已验证。
    3. 退出状态屏幕: Ctrl+C
  13. 配置新存储以供存储节点使用:
    1. 配置新存储卷: sudo add_rangedbs.rb
      此脚本将查找任何新存储卷并提示您对其进行格式化。
    2. 输入 y 以格式化存储卷。
    3. 如果先前已对任何卷进行格式化,请确定是否要重新格式化这些卷。
      • 输入 y 以重新格式化。
      • 输入 n 以跳过重新格式化。
      已格式化存储卷。
    4. 当系统询问时,输入 y 以停止存储服务。

      存储服务将停止, setup_rangedbs.sh 脚本将运行。在卷准备好用作卷集之后,服务将重新启动。

  14. 检查服务是否正确启动:
    1. 查看服务器上所有服务的状态列表: sudo storagegrid-status
      状态将自动更新。
    2. 请等待所有服务均已运行或已验证。
    3. 退出状态屏幕: Ctrl+C
  15. 验证存储节点是否联机:
    1. 使用支持的浏览器登录到网格管理器。
      您必须具有维护或根访问权限。
    2. 选择 Support。 然后,在菜单的工具部分中,选择 Grid Topology
    3. 选择site > Storage Node > LDR > Storage
    4. 选择 Configuration 选项卡,然后选择 Main 选项卡。
    5. 如果 Storage State - Desired 下拉列表设置为只读或脱机,请选择 Online
    6. 单击 Apply Changes
  16. 要查看新对象存储,请执行以下操作:
    1. 选择Nodes > site > Storage Node > Storage
    2. Object Stores 表中查看详细信息。

结果

现在,您可以使用存储节点的扩展容量来保存对象数据。