简体中文版经机器翻译而成,仅供参考。如与英语版出现任何冲突,应以英语版为准。

使用API配置CIFS和NFS文件共享

您可以使用 Active IQ Unified Manager 中提供的配置 API 在 Storage Virtual Machine ( SVM )上配置 CIFS 共享和 NFS 文件共享。此配置工作流详细介绍了在创建文件共享之前检索 SVM 密钥,性能服务级别和存储效率策略的步骤。

下图说明了文件共享配置工作流中的每个步骤。其中包括配置 CIFS 共享和 NFS 文件共享。

创建文件共享
注

确保满足以下要求:

  • 已将 ONTAP 集群添加到 Unified Manager 中,并已获取集群密钥。

  • 已在集群上创建 SVM 。

  • SVM 支持 CIFS 和 NFS 服务。如果 SVM 不支持所需的服务,则配置文件共享可能会失败。

  • FCP 端口处于联机状态,可用于端口配置。

  1. 确定要创建 CIFS 共享的 SVM 上的数据 LIF 或访问端点是否可用。获取 SVM 上可用访问端点的列表:

    类别 HTTP 动词 路径

    存储提供程序

    获取

    ` 存储提供程序 / 访问端点` ` /storage-provider/access-Endpoints/\ { key }`

    • 示例 curc*

    curl -X GET "https://<hostname>/api/storage-provider/access-endpoints?resource.key=7d5a59b3-953a-11e8-8857-00a098dcc959" -H "accept: application/json" -H "Authorization: Basic <Base64EncodedCredentials>"
  2. 如果您的访问端点位于列表中,请获取访问端点密钥,否则请创建访问端点。

    注

    确保您创建的访问端点已启用 CIFS 协议。除非您创建的访问端点启用了 CIFS 协议,否则配置 CIFS 共享将失败。

    类别 HTTP 动词 路径

    存储提供程序

    发布

    ` 存储提供商 / 访问端点`

    • 示例 curc*

      您必须输入要创建的访问端点的详细信息作为输入参数。

    curl -X POST "https://<hostname>/api/storage-provider/access-endpoints" -H "accept: application/json" -H "Content-Type: application/json" -H "Authorization: Basic <Base64EncodedCredentials>"
    { \"data_protocols\": \"nfs\",
    \"fileshare\": { \"key\": \"cbd1757b-0580-11e8-bd9d-00a098d39e12:type=volume,uuid=f3063d27-2c71-44e5-9a69-a3927c19c8fc\" },
    \"gateway\": \"10.132.72.12\",
    \"ip\": { \"address\": \"10.162.83.26\",
    \"ha_address\": \"10.142.83.26\",
    \"netmask\": \"255.255.0.0\" },
    \"lun\": { \"key\": \"cbd1757b-0580-11e8-bd9d-00a098d39e12:type=lun,uuid=d208cc7d-80a3-4755-93d4-5db2c38f55a6\" },
    \"mtu\": 15000, \"name\": \"aep1\",
    \"svm\": { \"key\": \"cbd1757b-0580-11e8-bd9d-00a178d39e12:type=vserver,uuid=1d1c3198-fc57-11e8-99ca-00a098d38e12\" },
    \"vlan\": 10}"

    + JSON 输出将显示一个作业对象密钥,您可以使用该密钥验证您创建的访问端点。

  3. 验证访问端点:

    类别 HTTP 动词 路径

    管理服务器

    获取

    ` /management-server/jobs/\ { key }`

  4. 确定您需要创建 CIFS 共享还是 NFS 文件共享。要创建 CIFS 共享,请执行以下子步骤:

    1. 确定是否在 SVM 上配置了 CIFS 服务器,即确定是否在 SVM 上创建了 Active Directory 映射。

      类别 HTTP 动词 路径

      存储提供程序

      获取

      ` 存储提供程序 /active-directory-mappings`

    2. 如果已创建 Active Directory 映射,请使用密钥,否则请在 SVM 上创建 Active Directory 映射。

      类别 HTTP 动词 路径

      存储提供程序

      发布

      ` 存储提供程序 /active-directory-mappings`

      • 示例 curc*

      您必须输入用于创建 Active Directory 映射的详细信息作为输入参数。

    curl -X POST "https://<hostname>/api/storage-provider/active-directories-mappings" -H "accept: application/json" -H "Content-Type: application/json" -H "Authorization: Basic <Base64EncodedCredentials>"
    { \"_links\": {},
    \"dns\": \"10.000.000.000\",
    \"domain\": \"example.com\",
    \"password\": \"string\",
    \"svm\": { \"key\": \"9f4ddea-e395-11e9-b660-005056a71be9:type=vserver,uuid=191a554a-f0ce-11e9-b660-005056a71be9\" },
    \"username\": \"string\"}"

    + 这是一个同步调用,您可以在输出中验证是否创建了 Active Directory 映射。如果出现错误,则会显示错误消息,以便您对请求进行故障排除并重新运行。

  5. 获取要在其中创建 CIFS 共享或 NFS 文件共享的 SVM 的 SVM 密钥,如 _Verifying SVM on clusters 工作流主题中所述。

  6. 运行以下 API 并从响应中检索此密钥,以获取性能服务级别的密钥。

    类别 HTTP 动词 路径

    存储提供程序

    获取

    ` 存储提供商 /performation-service-levels`

    注

    您可以通过将 ssystem_defined 输入参数设置为 true 来检索系统定义的性能服务级别的详细信息。从输出中,获取要应用于文件共享的性能服务级别的密钥。

  7. 或者,也可以通过运行以下 API 并从响应中检索要应用于文件共享的存储效率策略的存储效率策略密钥。

    类别 HTTP 动词 路径

    存储提供程序

    获取

    ` 存储提供程序 / 存储效率策略`

  8. 创建文件共享。您可以通过指定访问控制列表和导出策略来创建同时支持 CIFS 和 NFS 的文件共享。以下子步骤提供了有关创建文件共享以仅支持卷上的一个协议的信息。创建 NFS 共享后,您还可以更新 NFS 文件共享以包括访问控制列表。有关信息,请参见 _Modifying storage workloads _ 主题。

    1. 要仅创建 CIFS 共享,请收集有关访问控制列表( ACL )的信息。要创建 CIFS 共享,请为以下输入参数提供有效值。配置 CIFS/SMB 共享时,系统会为您分配的每个用户组创建一个 ACL 。根据您为 ACL 和 Active Directory 映射输入的值,将在创建 CIFS 共享时为其确定访问控制和映射。

      • 包含示例值的 cURL 命令 *

      {
        "access_control": {
          "acl": [
            {
              "permission": "read",
              "user_or_group": "everyone"
            }
          ],
          "active_directory_mapping": {
            "key": "3b648c1b-d965-03b7-20da-61b791a6263c"
          },
    2. 要仅创建 NFS 文件共享,请收集有关导出策略的信息。要创建 NFS 文件共享,请为以下输入参数提供有效值。根据您的值,导出策略会在创建 NFS 文件共享时附加到该文件共享。

      注

      配置 NFS 共享时,您可以通过提供所有必需值来创建导出策略,也可以提供导出策略密钥并重复使用现有导出策略。如果要重复使用 Storage VM 的导出策略,则需要添加导出策略密钥。除非您知道该密钥,否则可以使用 ` /datacenter/protocols/nfs/export-policies` API 检索导出策略密钥。要创建新策略,必须输入以下示例中显示的规则。对于输入的规则, API 将尝试通过匹配主机, Storage VM 和规则来搜索现有导出策略。如果存在现有导出策略,则会使用该策略。否则,将创建新的导出策略。

      • 包含示例值的 cURL 命令 *

      "export_policy": {
            "key": "7d5a59b3-953a-11e8-8857-00a098dcc959:type=export_policy,uuid=1460288880641",
            "name_tag": "ExportPolicyNameTag",
            "rules": [
              {
                "clients": [
                  {
                    "match": "0.0.0.0/0"
                  }

    配置访问控制列表和导出策略后,为 CIFS 和 NFS 文件共享的强制输入参数提供有效值:

注

存储效率策略是用于创建文件共享的可选参数。

类别 HTTP 动词 路径

存储提供程序

发布

` 存储提供程序 / 文件共享`

JSON 输出将显示一个作业对象密钥,您可以使用该密钥验证您创建的文件共享。。使用查询作业时返回的作业对象密钥验证文件共享创建:

类别 HTTP 动词 路径

管理服务器

获取

` /management-server/jobs/\ { key }`

在响应结束时,您会看到所创建文件共享的密钥。

    ],
    "job_results": [
        {
            "name": "fileshareKey",
            "value": "7d5a59b3-953a-11e8-8857-00a098dcc959:type=volume,uuid=e581c23a-1037-11ea-ac5a-00a098dcc6b6"
        }
    ],
    "_links": {
        "self": {
            "href": "/api/management-server/jobs/06a6148bf9e862df:-2611856e:16e8d47e722:-7f87"
        }
    }
}
  1. 使用返回的密钥运行以下 API ,以验证文件共享的创建:

    类别 HTTP 动词 路径

    存储提供程序

    获取

    ` /storage-provider/file-shares/\ { key }`

    • JSON 输出示例 *

      您可以看到, ` /storage-provider/file-shares` 的 POST 方法在内部调用每个函数所需的所有 API 并创建对象。例如,它会调用 ` /storage-provider/performance-service-levels/` API 来为文件共享分配性能服务级别。

    {
        "key": "7d5a59b3-953a-11e8-8857-00a098dcc959:type=volume,uuid=e581c23a-1037-11ea-ac5a-00a098dcc6b6",
        "name": "FileShare_377",
        "cluster": {
            "uuid": "7d5a59b3-953a-11e8-8857-00a098dcc959",
            "key": "7d5a59b3-953a-11e8-8857-00a098dcc959:type=cluster,uuid=7d5a59b3-953a-11e8-8857-00a098dcc959",
            "name": "AFFA300-206-68-70-72-74",
            "_links": {
                "self": {
                    "href": "/api/datacenter/cluster/clusters/7d5a59b3-953a-11e8-8857-00a098dcc959:type=cluster,uuid=7d5a59b3-953a-11e8-8857-00a098dcc959"
                }
            }
        },
        "svm": {
            "uuid": "b106d7b1-51e9-11e9-8857-00a098dcc959",
            "key": "7d5a59b3-953a-11e8-8857-00a098dcc959:type=vserver,uuid=b106d7b1-51e9-11e9-8857-00a098dcc959",
            "name": "RRT_ritu_vs1",
            "_links": {
                "self": {
                    "href": "/api/datacenter/svm/svms/7d5a59b3-953a-11e8-8857-00a098dcc959:type=vserver,uuid=b106d7b1-51e9-11e9-8857-00a098dcc959"
                }
            }
        },
        "assigned_performance_service_level": {
            "key": "1251e51b-069f-11ea-980d-fa163e82bbf2",
            "name": "Value",
            "peak_iops": 75,
            "expected_iops": 75,
            "_links": {
                "self": {
                    "href": "/api/storage-provider/performance-service-levels/1251e51b-069f-11ea-980d-fa163e82bbf2"
                }
            }
        },
        "recommended_performance_service_level": {
            "key": null,
            "name": "Idle",
            "peak_iops": null,
            "expected_iops": null,
            "_links": {}
        },
        "space": {
            "size": 104857600
        },
        "assigned_storage_efficiency_policy": {
            "key": null,
            "name": "Unassigned",
            "_links": {}
        },
        "access_control": {
            "acl": [
                {
                    "user_or_group": "everyone",
                    "permission": "read"
                }
            ],
            "export_policy": {
                "id": 1460288880641,
                "key": "7d5a59b3-953a-11e8-8857-00a098dcc959:type=export_policy,uuid=1460288880641",
                "name": "default",
                "rules": [
                    {
                        "anonymous_user": "65534",
                        "clients": [
                            {
                                "match": "0.0.0.0/0"
                            }
                        ],
                        "index": 1,
                        "protocols": [
                            "nfs3",
                            "nfs4"
                        ],
                        "ro_rule": [
                            "sys"
                        ],
                        "rw_rule": [
                            "sys"
                        ],
                        "superuser": [
                            "none"
                        ]
                    },
                    {
                        "anonymous_user": "65534",
                        "clients": [
                            {
                                "match": "0.0.0.0/0"
                            }
                        ],
                        "index": 2,
                        "protocols": [
                            "cifs"
                        ],
                        "ro_rule": [
                            "ntlm"
                        ],
                        "rw_rule": [
                            "ntlm"
                        ],
                        "superuser": [
                            "none"
                        ]
                    }
                ],
                "_links": {
                    "self": {
                        "href": "/api/datacenter/protocols/nfs/export-policies/7d5a59b3-953a-11e8-8857-00a098dcc959:type=export_policy,uuid=1460288880641"
                    }
                }
            }
        },
        "_links": {
            "self": {
                "href": "/api/storage-provider/file-shares/7d5a59b3-953a-11e8-8857-00a098dcc959:type=volume,uuid=e581c23a-1037-11ea-ac5a-00a098dcc6b6"
            }
        }
    }