클래스 공급자 등록

WMI 클래스 공급자를 만들려면 __ClassProviderRegistration 인스턴스를 사용하여 공급자를 나타내는 __Win32Provider 인스턴스를 등록해야 합니다. COM 개체로서 공급자는 운영 체제 및 WMI에 등록해야 합니다. 다음 절차에서는 공급자 등록에 설명된 대로 등록 프로세스를 이미 구현했다고 가정합니다. 공급자가 WMI 리포지토리에 대부분의 데이터를 저장하고 해당 데이터가 WMI 초기화에서만 업데이트되는 경우 클래스를 푸시(push) 클래스 공급자로 등록합니다. 제공하는 데이터가 자주 변경되고 WMI의 모든 요청에서 코드에 의해 동적으로 검색되는 경우 공급자를 풀(pull) 클래스 공급자로 등록합니다.

다음 절차에서는 푸시 클래스 공급자를 등록하는 방법을 설명합니다.

푸시 클래스 공급자를 등록하려면 다음을 따릅니다.

다음 절차에서는 풀 클래스 공급자를 등록하는 방법을 설명합니다.

풀 클래스 공급자를 등록하려면 다음을 따릅니다.

  1. 공급자를 설명하는 __Win32Provider 클래스의 인스턴스를 만듭니다.

  2. 공급자의 기능 집합을 설명하는 __ClassProviderRegistration 클래스의 인스턴스를 만듭니다.

    __ClassProviderRegistration 인스턴스 내에서 다음을 수행합니다.

    1. InteractionType 속성을 설정하여 공급자가 푸시 또는 풀 공급자인지 여부를 나타냅니다.

    2. DynamicProvider 한정자를 모두 사용하여 클래스에 태그를 지정합니다.

      Dynamic 한정자는 WMI가 공급자를 사용하여 클래스 인스턴스를 검색해야 함을 나타냅니다. Provider 한정자는 WMI에서 사용해야 하는 공급자의 이름을 지정합니다.

    3. ResultSetQueries, ReferencedSetQueriesUnsupportedQueries 속성을 정의합니다.

      해당 쿼리 속성은 지원되는 클래스에 대한 자세한 정보를 설명합니다.

클래스의 지원되는 다양한 메서드를 설명하는 것 외에도 __ClassProviderRegistration 클래스에는 일련의 쿼리를 설명하는 세 가지 속성도 있습니다. 이 세 가지 속성을 함께 사용하면 클래스 공급자가 제공하는 클래스의 전체 범위를 설명합니다. 각 쿼리 속성에는 지원되는 클래스의 형식을 지정하는 “스키마 쿼리”라는 WQL SELECT 문이 포함되어 있습니다. 스키마 쿼리는 meta_class라는 특수 클래스 이름을 지정합니다. 다음 표에서는 쿼리 속성 목록을 보여 줍니다.

속성 설명
ResultSetQueries 공급자가 제공하는 결과 집합에 대한 정보를 포함합니다. WMI는 이 정보를 사용하여 애플리케이션의 쿼리를 충족하기 위해 공급자를 호출할지 여부를 결정합니다. 이 속성은 공급자가 제공할 수 있는 모든 클래스 집합 또는 사용 가능한 클래스의 상위 집합을 설명하지만 하위 집합은 설명하지 않습니다. WMI를 사용하려면 공급자가 이 속성에 하나 이상의 쿼리를 지정해야 합니다.
다음 예제에서는 공급자가 Win32_LogicalDisk 클래스를 참조하는 연결 클래스를 제공할 때 ResultSetQueries를 설정하는 방법을 보여 줍니다.
SELECT * FROM meta_class WHERE __Class = "Win32_LogicalDisk"
다음 예제에서는 공급자가 알 수 없는 다른 클래스를 참조하는 클래스를 제공할 때 일반 쿼리를 지정하는 방법을 보여 줍니다.
SELECT * FROM meta_class
다음 예제에서는 공급자가 지정된 클래스의 부모 클래스가 아닌 하위 클래스만 제공할 때 ResultSetQueries를 설정하는 방법을 보여 줍니다.
SELECT * FROM meta_class WHERE __Dynasty = "MyClass"
다음 예제에서는 공급자가 모든 클래스 및 하위 클래스를 제공할 때 특수 __this 속성을 사용하고 ResultSetQueries를 설정하는 방법을 보여 줍니다.
SELECT * FROM meta_class WHERE __this ISA "MyClass"
ReferencedSetQueries 연결 및 참조가 요청되는 스키마 쿼리에서 공급자를 바이패스할지 여부를 결정합니다. 연결 클래스를 제공할 수 있는 공급자는 ReferencedSetQueries 속성에 쿼리를 하나 이상 포함해야 합니다.
UnsupportedQueries 클래스 공급자가 제공하지 않는 결과 집합에 대한 정보를 포함합니다. WMI는 이 속성을 사용하여 ResultSetQueries에 포함된 클래스 집합을 뺍니다. 예를 들어 클래스 공급자는 ResultSetQueries에서 MyClass로부터 파생된 모든 클래스에 대한 지원을 지정하고 UnsupportedQueries에서 하나의 특정 파생 클래스에 대한 지원 부족을 지정할 수 있습니다.
공급자가 쿼리 처리 기능에 대해 등록할 수 있는 정보가 많을수록 더 빠르게 실행됩니다. UnsupportedQueries 속성에 하나 이상의 쿼리를 입력하는 것은 특정적인 방법이며 공급자가 제공하지 않는 클래스를 사용하는 경우 특히 중요합니다. UnsupportedQueries 속성의 쿼리에 나열된 클래스에 대한 요청이 이루어지면 WMI는 클래스 자체를 제공하거나 대체 공급자를 호출하여 제공할 수 있습니다.

WMI는 OR 절을 지원하지 않으므로 각 클래스에 대해 별도의 쿼리를 만들어야 합니다.

다음 쿼리는 클래스 공급자가 MyClass1, MyClass2 및 MyClass3을 제공할 때 ResultSetQueries에 지정됩니다.

SELECT * FROM meta_class WHERE __Class = "MyClass1"
SELECT * FROM meta_class WHERE __Class = "MyClass2"
SELECT * FROM meta_class WHERE __Class = "MyClass3"

관리자만 __Win32Provider__ClassProviderRegistration 인스턴스를 만들어 공급자를 등록하거나 삭제할 수 있습니다.