Freigeben einer Sperre für ein SEDO-Enabled-Objekt

So geben Sie eine explizite Sperre für ein SEDO-fähiges Objekt frei

  1. Erstellen einer instance der SMS_ObjectLock WMI-Klasse

  2. Rufen Sie das Methodenparameterobjekt für die ReleaseLock Methode ab.

  3. Weisen Sie der -Eigenschaft den Objektpfad des Objekts zu, das Sie entsperren ObjectRelPath möchten.

  4. Erstellen Sie ein InvokeMethodOptions Objekt instance. Fügen Sie in der Context-Eigenschaft ein Name-Wert-Paar hinzu. Der Name muss "MachineName" sein, und der Wert muss der Name des Computers sein, der die Sperre freigibt. Weitere Informationen finden Sie unter Abrufen einer Sperre für ein SEDO-Enabled-Objekt.

  5. Rufen Sie InvokeMethod für die SMS_ObjectLock instance auf.

  6. InvokeMethod gibt eine SMS_ObjectLockRequest instance zurück. Überprüfen Sie die RequestState Eigenschaften und LockState , um weitere Informationen zum Erfolg oder Fehler der Anforderung zu erhalten.

Beispiel

Im folgenden Beispiel wird eine Sperre für ein SMS_ConfigurationItem Objekt instance freigegeben.

class Program
{
    static void Main(string[] args)
    {
        ManagementScope scope = new ManagementScope(@"\siteservername\root\sms\site_ABC");
        ReleaseLock(scope);
    }

    public static void ReleaseLock(ManagementScope scope)
    {
        ManagementPath path = new ManagementPath("SMS_ObjectLock");
        ManagementClass objectLock = new ManagementClass(scope, path, null);

        ManagementBaseObject inParams = objectLock.GetMethodParameters("ReleaseLock");
        inParams["ObjectRelPath"] = "SMS_ConfigurationItem.CI_ID=30";

        InvokeMethodOptions options = new InvokeMethodOptions();
        options.Context.Add("MachineName", "RequestingComputer");

        ManagementBaseObject result = objectLock.InvokeMethod("ReleaseLock", inParams, options);

    }
}

Das SMS_ObjectLockRequest-Objekt enthält die folgenden Eigenschaften:

Eigenschaft Beschreibung
Requestid Eindeutiger Bezeichner der Anforderung.
ObjectRelPath Der Pfad des Objekts, für das die Sperre angefordert wird.
RequestState Gibt den Erfolg oder Fehler der Anforderung an.
LockState Gibt den aktuellen Zustand der angeforderten Sperre an.
AssignedUser Gibt den aktuell zugewiesenen Benutzer der angeforderten Sperre an.
AssignedObjectLockContext Gibt ObjectLockContext an, dem die Sperre derzeit zugewiesen ist.
AssignedMachine Gibt den aktuell zugewiesenen Computer der angeforderten Sperre an.
AssignedSiteCode Gibt den aktuellen Standort der angeforderten Sperre an.
AssignedTimeUTC Gibt den Zeitpunkt an, zu dem die angeforderte Sperre zugewiesen wurde.

RequestState In der folgenden Tabelle werden die möglichen Anforderungsstatuswerte angezeigt. Die Anforderungszustände Granted, GrantedAfterTimeout und GrantedLockWasOrphaned geben eine erfolgreiche Anforderung an, und der Benutzer kann dann Änderungen am Objekt vornehmen und speichern. Alle anderen Anforderungen weisen auf einen Fehler hin.

RequestStateID RequestStateName
0 Unbekannt
2 Angefordert
3 RequestedCanceled
4 ResponseReceived
10 Gewährt
11 GrantedAfterTimeout
12 GrantedLockWasOrphaned
20 DeniedLockAlreadyAssigned
21 DeniedInvalidObjectVersion
22 DeniedLockNotFound
23 DeniedLockNotLocal
24 DeniedRequestTimedOut
50 Fehler
52 ErrorRequestNotFound
53 ErrorRequestTimedOut

LockState In der folgenden Tabelle werden die möglichen Sperrzustandswerte angezeigt.

LockStateID LockStateName
0 Nicht zugewiesen
1 Zugewiesen
2 Angefordert
3 PendingAssignment
4 Timedout
5 NotFound

Kompilieren des Codes

Für das C#-Beispiel ist Folgendes erforderlich:

Namespaces

System

System.Management

Assembly

Robuste Programmierung

Weitere Informationen zur Fehlerbehandlung finden Sie unter Informationen zu Configuration Manager Fehlern.

Siehe auch

Configuration Manager SEDO