自訂交換器屬性定義和註冊
Hyper-V 可延伸交換器原則的自訂屬性定義會使用 Managed 物件格式 (MOF) 類別定義,向 WMI 管理層註冊。 除了定義自訂參數屬性屬性的結構成員之外,MOF 類別也必須包含下列專案:
唯一識別自訂參數屬性的 UUID。
可唯一識別可延伸交換器擴充功能的 GUID。 這個 GUID 會宣告為 MOF 類別的 ExtensionId 限定詞,而且必須符合擴充功能 INF 檔案中宣告的 NetCfgInstanceId 專案值。
描述性類別名稱字串。 廠商的名稱必須包含在字串中。
以下顯示可延伸交換器原則之自訂屬性的 MOF 類別範例。
#pragma namespace("\\\\.\\root\\virtualization\\v2")
[ Dynamic,
UUID("FF36C3A6-D2F1-46ed-A376-32B43D6B8390"),
ExtensionId("5CBF81BE-5055-47CD-9055-A76B2B4E369E"),
Provider("VmmsWmiInstanceAndMethodProvider"),
Locale(0x409),
InterfaceVersion("1"),
InterfaceRevison("0"),
DisplayName("Fabrikam, Inc. Switch Settings Friendly Name") : Amended,
Description("Fabrikam, Inc. Switch Settings detailed description.") : Amended]
class Fabrikam_SwitchCustomSettingData : Msvm_EthernetSwitchFeatureSettingData {
[ Read,
Write,
WmiDataId(1),
InterfaceVersion("1"),
InterfaceRevision("0"),
Description (
"int32 setting.") : Amended]
uint32 SwitchSettingIntA = 0;
[ Read,
Write,
WmiDataId(2),
InterfaceVersion("1"),
InterfaceRevision("0"),
Description (
"int64 setting.") : Amended]
uint64 SwitchSettingIntB = 0;
};
交換器原則之自訂屬性的 MOF 類別會使用 MOF 編譯器 (Mofcomp.exe) ,在 CIM) 存放庫中註冊一般資訊 (模型。 註冊之後,可以透過 PowerShell Cmdlet 和 WMI 型應用程式來設定 MOF 類別。
下列範例顯示必須輸入的命令,才能註冊包含自訂埠屬性之 MOF 類別的檔案 (Fabrikam_SwitchCustomSettingData.mof) 。
net stop vmms
mofcomp -N:root\virtualization\v2 Fabrikam_SwitchCustomSettingData.mof
net start vmms
如需如何使用 MOF 編譯器的詳細資訊,請參閱 編譯驅動程式的 MOF 檔案。
下列範例示範如何設定範例功能。 在此範例中,Fabrikam_SwitchCustomSettingData MOF 類別是用來設定名為 「TestSwitch」 的參數。
# Retrieve the template object for the custom configuration. We know the ID already so
# we can retrieve it directly, otherwise Get-VMSystemSwitchExtensionSwitchFeature can list all available
# properties.
PS C:\> $feature = Get-VMSystemSwitchExtensionSwitchFeature -FeatureId FF36C3A6-D2F1-46ed-A376-32B43D6B8390
# Output the values
PS C:\temp> $feature
Id : ff36c3a6-d2f1-46ed-a376-32b43d6b8390
ExtensionId : 5CBF81BE-5055-47CD-9055-A76B2B4E369E
ExtensionName : Fabrican Extension
Name : Fabrikam, Inc. Switch Settings Friendly Name
ComputerName : TEST_SERVER
SettingData : \\TEST_SERVER\root\virtualization\v2:VendorName_SwitchCustomSettingData.InstanceID="Microsoft:Definition\\
FF36C3A6-D2F1-46ED-A376-32B43D6B8390\\Default"
# Cast the SettingsData to a WMI object to see the actual configurable values.
PS C:\> $wmiObj = [wmi]$feature.SettingData
PS C:\> $wmiObj
__GENUS : 2
__CLASS : Fabrikam_SwitchCustomSettingData
__SUPERCLASS : Msvm_EthernetSwitchFeatureSettingData
__DYNASTY : CIM_ManagedElement
__RELPATH : Fabrikam_SwitchCustomSettingData .InstanceID="Microsoft:Definition\\FF36C3A6-D2F1-46ED-A376-32B43D
6B8390\\Default"
__PROPERTY_COUNT : 6
__DERIVATION : {Msvm_EthernetSwitchFeatureSettingData, Msvm_FeatureSettingData, CIM_SettingData,
CIM_ManagedElement}
__SERVER : TEST_SERVER
__NAMESPACE : root\virtualization\v2
__PATH : \\TEST_SERVER\root\virtualization\v2:Fabrikam_SwitchCustomSettingData .InstanceID="Microsoft:Definiti
on\\FF36C3A6-D2F1-46ED-A376-32B43D6B8390\\Default"
Caption : Fabrikam, Inc. Switch Settings Friendly Name
Description : Fabrikam, Inc. Switch Settings detailed description.
ElementName : Fabrikam, Inc. Switch Settings Friendly Name
InstanceID : Microsoft:Definition\FF36C3A6-D2F1-46ED-A376-32B43D6B8390\Default
SwitchSettingIntA : 0
SwitchSettingIntB : 0
PSComputerName : TEST_SERVER
# Update the property settings and add to the NIC attached to TestVm
PS C:\> $wmiObj.SwitchSettingIntA = 100
PS C:\> $wmiObj.SwitchSettingIntB = 9999
PS C:\> Add-VMSwitchExtensionSwitchFeature -VMSwitchExtensionFeature $feature -SwitchName TestSwitch
# Validate that the properties are now set on the VM’s NIC
PS C:\> $feature = Get-VmSwitchExtensionSwitchFeature -FeatureId FF36C3A6-D2F1-46ed-A376-32B43D6B8390 -SwitchName TestSwitch
PS C:\> [wmi]$feature.SettingData
__GENUS : 2
__CLASS : Fabrikam_SwitchCustomSettingData
__SUPERCLASS : Msvm_EthernetSwitchFeatureSettingData
__DYNASTY : CIM_ManagedElement
__RELPATH : Fabrikam_SwitchCustomSettingData .InstanceID="Microsoft:88835394-FDE1-437C-B249-D840575154E2\\FF36
C3A6-D2F1-46ED-A376-32B43D6B8390\\F9EA07E7-7B73-431A-8705-26EC2B592306"
__PROPERTY_COUNT : 6
__DERIVATION : {Msvm_EthernetSwitchFeatureSettingData, Msvm_FeatureSettingData, CIM_SettingData,
CIM_ManagedElement}
__SERVER : TEST_SERVER
__NAMESPACE : root\virtualization\v2
__PATH : \\TEST_SERVER\root\virtualization\v2:Fabrikam_SwitchCustomSettingData .InstanceID="Microsoft:88835394
-FDE1-437C-B249-D840575154E2\\FF36C3A6-D2F1-46ED-A376-32B43D6B8390\\F9EA07E7-7B73-431A-8705-26EC2B5
92306"
Caption : Fabrikam, Inc. Switch Settings Friendly Name
Description : Fabrikam, Inc. Switch Settings detailed description.
ElementName : Fabrikam, Inc. Switch Settings Friendly Name
InstanceID : Microsoft:88835394-FDE1-437C-B249-D840575154E2\FF36C3A6-D2F1-46ED-A376-32B43D6B8390\F9EA07E7-7B73-4
31A-8705-26EC2B592306
SwitchSettingIntA : 100
SwitchSettingIntB : 9999
PSComputerName : TEST_SERVER
如需可延伸交換器延伸模組如何管理交換器原則的詳細資訊,請參閱 管理交換器原則。