样书配置

实例角色

样书在 NetScaler 实例上支持以下配置:

  • 对称配置 - 当配置包应用于多个 NetScaler 实例并且部署在所有实例上的配置都相同时。
  • 非对称配置 - 当配置包应用于多个 NetScaler 实例且部署在所有实例上的配置不同时。例如,在默认的 Microsoft Skype for Business 样书中,必须在每个 NetScaler 实例上部署不同的配置。

StyleBooks 的“实例角色”功能可帮助您创建非对称配置。在这里,可以为配置包中的每个 NetScaler 实例分配不同的角色。该角色确定 NetScaler 实例接收的配置包的配置对象。

注意事项:

  • 样本中的一组实例角色是在创建样本时定义的。
  • 创建或更新配置包时,角色会分配给特定 ADC 实例。

目标角色部分

在样书中,“目标角色”通常放在“导入样书”部分之后和“参数”部分之前。样书支持的所有角色都在“目标角色”部分中声明。

在以下样书示例中,在“目标角色”部分中定义了两个角色-A 和 B。

target-roles:-name:Aname:Bmin-targets:2max-targets:5

您可以看到角色 B 还定义了两个可选的子属性min-targetsmax-targets

min-targets指定从此样书创建配置包时分配此角色的 ADC 实例的最小强制数量。max-targets指定从此样书创建配置包时可以分配此角色的 ADC 实例的最大数量。

如果未指定这些子属性,则可以为该角色配置的 ADC 实例数量没有限制。对于最小目标 = 0,与角色关联的配置是可选的。对于最小目标 = 1,必须进行配置,并且必须为该角色配置至少一个 ADC 实例。

角色“默认”

除了明确定义的角色外,所有样书都有一个隐式角色。此隐式角色称为默认角色,其使用方式与样书中的任何其他角色一样。创建配置包时,如果没有为 ADC 实例分配特定角色,则该实例将隐式分配给“默认”角色。然后,该实例会接收由具有“默认”角色的组件生成的任何配置对象。

具有角色的组件

定义了样书可以支持的角色(包括“默认”角色)后,可以在样书的组件部分中使用这些角色。如果希望仅在发挥特定角色的 ADC 实例上部署组件,则可以将角色属性指定为组件的一部分,如以下组件示例所示:

-name:C1type:ns::lbvserverroles:-Aproperties:name:lb1servicetype:HTTPipv46:1.1.1.1port:80

在此示例中,组件生成在扮演角色一个的实例上部署的lbvserver。组件的角色属性为list,可以为该组件分配多个角色。这些角色本应在样书的target-roles部分中声明。

注意

如果样书中的组件未指定角色属性,则无论角色如何,该组件生成的配置对象都将在所有 NetScaler 实例上创建。您可以有效地使用此功能创建可应用于配置包的所有实例的配置对象。

以具有两个角色和四个组件的样书为例。

  • 组件 C1 具有角色 A 和 B
  • 组件 C2 具有作用 B
  • 组件 C3 未定义任何角色
  • 组件 C4 的角色为“默认”

此样书的组件部分如下所示:

components:-name:C1type:ns::lbvserverroles:-A-Bproperties:name:lb1servicetype:HTTPipv46:1.1.1.1port:80-name:C2type:ns::lbvserverroles:-Bproperties:name:lb2servicetype:HTTPipv46:12.12.12.12port:80-name:C3type:ns::lbvserverproperties:name:lb3servicetype:HTTPipv46:13.13.13.13port:80-name:C4type:ns::lbvserverroles:-defaultproperties:name:lb4servicetype:HTTPipv46:14.14.14.14port:80

组件 C3 未定义角色,这意味着无论其角色如何,该组件都部署在所有实例上。另一方面,组件 C4 具有“默认”角色,这意味着它适用于没有分配明确角色的任何实例。

现在,考虑您想使用此样书创建一个配置包,然后将其部署在五个 ADC 实例上。您可以通过以下方式将角色分配给实例:

  • 角色 A 被分配给实例 T1、T2、T3 和 T4
  • 角色 B 被分配给实例 T2、T3 和 T4
  • 未为实例 T5 分配任何角色

下图汇总了角色分配,并显示了每个 ADC 实例收到的生成的配置:

角色分配摘要

组件 C3 部署在所有实例上,无论角色如何,因为该组件没有roles属性。

下图显示了创建示例配置包时的角色分配:

角色分配的配置包

使用“试运行”功能查看和验证:

  • 角色的分配
  • 在每个 ADC 实例上创建的配置对象

构建您的样书

StyleBook“演示目标角色”的完整内容如下:

---name:demo-target-rolesnamespace:com.example.stylebooksversion:"1.2"schema-version:"1.0"import-stylebooks:-namespace:netscaler.nitro.configprefix:nsversion:"10.5"parameters:-name:appnametype:stringrequired:truekey:truetarget-roles:-name:A-name:Bmin-targets:2max-targets:5components:-name:C1type:ns::lbvserverroles:-A-Bproperties:name:lb1servicetype:HTTPipv46:1.1.1.1port:80-name:C2type:ns::lbvserverroles:-Bproperties:name:lb2servicetype:HTTPipv46:12.12.12.12port:80-name:C3type:ns::lbvserverproperties:name:lb3servicetype:HTTPipv46:13.13.13.13port:80-name:C4type:ns::lbvserverroles:-defaultproperties:name:lb4servicetype:HTTPipv46:14.14.14.14port:80

下图显示了为示例配置包创建的对象:

在 ADC 实例中为配置包创建的对象

使用 API

使用 REST API 时,您可以在创建或更新配置包时为每个 ADC 实例指定角色,如下所示。在“目标”块中,指定要在其上部署各个组件的特定 NetScaler 实例的 UUID。

"targets":[{"id":"","roles":["一个“]},]

我们提供了一个完整的示例 REST API 供您参考。

POST />/stylebook/nitro/v1/config/stylebooks/com.example.stylebooks/1.2/demo-target-roles/configpacks

{ "configpack": { "parameters": { "appname": "app1" }, "targets": [ { "id": "f53c35c3-a6bc-4619-b4b4-ad7ab6a94ddb", "roles": ["A"] }, { "id": "c08caa1c-1011-48aa-b8c7-9aed1cd38ed0", "roles": ["A", "B"] }, { "id": "88ac90cb-a5cb-445b-8617-f83d0ef6174e", "roles": ["A", "B"] }, { "id": "bf7b0f74-7a83-4856-86f4-dcc951d3141e", "roles": ["A", "B"] }, { "id": "fa5d97ab-ca29-4adf-b451-06e7a234e3da", "roles": ["default"] } ] } } 
实例角色