<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Tasksequenz &#8211; Haikos Blog</title>
	<atom:link href="https://www.hertes.net/tag/tasksequenz/feed/" rel="self" type="application/rss+xml" />
	<link>https://www.hertes.net</link>
	<description>Blog von Haiko Hertes zu allen Themen rund um Microsoft, Cloud und Datacenter</description>
	<lastBuildDate>Wed, 02 Oct 2013 06:33:49 +0000</lastBuildDate>
	<language>de</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=6.9.4</generator>
	<item>
		<title>SCCM: PowerShell Skript, um fehlende Packages für Tasksequenzen ausfindig zu machen</title>
		<link>https://www.hertes.net/2013/06/sccm-powershell-skript-um-fehlende-packages-fur-tasksequenzen-ausfindig-zu-machen/</link>
					<comments>https://www.hertes.net/2013/06/sccm-powershell-skript-um-fehlende-packages-fur-tasksequenzen-ausfindig-zu-machen/#respond</comments>
		
		<dc:creator><![CDATA[Haiko]]></dc:creator>
		<pubDate>Wed, 12 Jun 2013 19:50:39 +0000</pubDate>
				<category><![CDATA[PowerShell]]></category>
		<category><![CDATA[System Center Configuration Manager]]></category>
		<category><![CDATA[Distribution Point]]></category>
		<category><![CDATA[DP]]></category>
		<category><![CDATA[SCCM]]></category>
		<category><![CDATA[Tasksequenz]]></category>
		<guid isPermaLink="false">http://www.hertes.net/?p=1693</guid>

					<description><![CDATA[In unserer produktiven SCCM-Umgebung werden insbesondere die größeren Content-Pakete per Prestaging und USB-Datenträger verteilt. Dabei kann es vorkommen, das man den Überblick, welches Paket noch auf welchem Distribution-Point fehlt bzw. für welche Tasksequenzen wo noch Pakete fehlen, verloren geht. Um dieses Problem zu lösen, habe ich ein PowerShell-Skript geschrieben. Dazu habe ich mich von Inhalten von Jason Scheffelmaer inspirieren lassen. Um das Skript nutzen zu können, benötigt man die SCCM.psm1 von Michael Niehaus. Das Skript wird ohne Parameter aufgerufen und fragt alle notwendigen Werte bei der Abarbeitung ab. Wichtig ist, dass die x86-Variante der PowerShell verwendet wird. Im Skript selber muss&#8230;]]></description>
										<content:encoded><![CDATA[<p>In unserer produktiven SCCM-Umgebung werden insbesondere die größeren Content-Pakete per Prestaging und USB-Datenträger verteilt. Dabei kann es vorkommen, das man den Überblick, welches Paket noch auf welchem Distribution-Point fehlt bzw. für welche Tasksequenzen wo noch Pakete fehlen, verloren geht.</p>
<p>Um dieses Problem zu lösen, habe ich ein PowerShell-Skript geschrieben. Dazu habe ich mich von Inhalten von Jason Scheffelmaer inspirieren lassen. Um das Skript nutzen zu können, benötigt man die <a href="http://blogs.technet.com/b/mniehaus/archive/2010/04/07/make-sure-a-configmgr-task-sequence-has-all-the-packages-it-needs.aspx" target="_blank">SCCM.psm1 von Michael Niehaus</a>.</p>
<p><span style="font-size: 13px; line-height: 19px;">Das Skript wird ohne Parameter aufgerufen und fragt alle notwendigen Werte bei der Abarbeitung ab. Wichtig ist, dass die x86-Variante der PowerShell verwendet wird. Im Skript selber muss noch der Pfad zur SCCM.psm1 angepasst werden.</span></p>
<p><span style="font-size: 13px; line-height: 19px;"> </span></p>
<pre lang="PowerShell" line="1"># Get-SCCMMissingTSPackages.ps1

# Author: Haiko Hertes
# Parts of the Script are taken from CheckTSPrompt.ps1 from Jason Scheffelmaer
# Needs sccm.psm1 from Michael Niehaus, tested with Version 1.5

# ------------- DISCLAIMER -------------------------------------------------
# This script code is provided as is with no guarantee or waranty concerning
# the usability or impact on systems and may be used, distributed, and
# modified in any way provided the parties agree and acknowledge the 
# Microsoft or Microsoft Partners have neither accountabilty or 
# responsibility for results produced by use of this script.
#
# Microsoft will not provide any support through any means.
# ------------- DISCLAIMER -------------------------------------------------

# The CheckPackages function checks each task sequence, finding all the packages
# that it references.  It then checks each appropriate DP to make sure that the
# needed packages are available on on those DPs.

function CheckPackages
{
    process
    {
        # Get the list of packages referenced by this task sequence
        $tsID = $_.PackageID
        $tsName = $_.Name

        # Setting up a Text-List of all DPs to see, which DP has all needed packages
        $DPsWithAllPackages = New-Object System.Collections.ArrayList
        foreach ($dp in $global:SelecteddpList)
        {
                $DPsWithAllPackages.Add($dp.Name)
        }

        Write-Host "###############################################################################################"
        Write-Host 'Checking the Packages for  Task Sequence $tsID ("' -NoNewLine; Write-Host $tsName -NoNewLine -ForegroundColor Yellow ; Write-Host '")'
        $tsReferences = Get-SCCMObject SMS_TaskSequenceReferencesInfo "PackageID='$tsID' and ProgramName='*'"    

        # Check each package
        Write-Verbose "Checking all packages..."
        foreach ($tsPackage in $tsReferences)
        {

            # Get a list of DPs for this package
            $tsPackageID = $tsPackage.ReferencePackageID

            Write-Verbose "Checking Package: $tspackageID"
            $tsReferenceDPs = Get-SCCMObject SMS_TaskSequenceReferenceDPs "TaskSequenceID='$tsID' and PackageID='$tsPackageID'"
            $packageNeededSomeWhere = $false
            $packageNeedingDPs = New-Object System.Collections.ArrayList

            # Check each DP to see if the package is on it
            foreach ($dp in $global:SelecteddpList)
            {
                $dpSiteCode = $dp.SiteCode
                $dpName = $dp.Name
                Write-Verbose "Checking DP $dpName"
                $found = $false
                foreach ($tsDP in $tsReferenceDPs)
                {

                    if ($tsDP.ServerNALPath -eq $dp.NALPath)
                    {
                        Write-Verbose "$tsPackageID - Package Found"
                        $found = $true
                        break
                    }
                }
                if ($found)
                {
                    New-Object PSObject -Property @{SiteCode=$dpSiteCode; PackageID=($tsPackageID); ServerName=($dp.ServerName); ShareName=($dp.ShareName); NALPath=($dp.NALPath); Result="Found"}
                }
                else
                {
                    # Check to see if this DP is a PXE Service Point, and if so mark as Not Needed.
                    if ($tsPackage.ReferencePackageType -eq 258 -or (-not $dp.NALPath.Contains("SMSPXEIMAGES$")))
                    {
                        Write-Verbose "$tsPackageID - Package Not Found"
                        $packageNeededSomehere = $true
                        $packageNeedingDPs.Add("$dpName |")
                        $DPsWithAllPackages.Remove($dp.Name)
                        New-Object PSObject -Property @{SiteCode=$dpSiteCode; PackageID=($tsPackageID); ServerName=($dp.ServerName); ShareName=($dp.ShareName); NALPath=($dp.NALPath); Result="Not Found"}
                    }
                    else
                    {
                        New-Object PSObject -Property @{SiteCode=$dpSiteCode; PackageID=($tsPackageID); ServerName=($dp.ServerName); ShareName=($dp.ShareName); NALPath=($dp.NALPath); Result="Not Needed"}
                    }
                }
            }
            If ($packageNeededSomehere -eq $true)
            {
                Write-Host "===&gt; " -NoNewLine; Write-Host "$tsPackageID" -ForegroundColor Red -NoNewline; Write-Host " is needed on: " -NoNewline; Write-Host $packageNeedingDPs
                $packageNeededSomehere = $false
            }
            else
            {
                Write-Host "===&gt; " -NoNewLine; Write-Host "$tsPackageID" -ForegroundColor Green -NoNewline; Write-Host " is found on ALL selected DPs!"
            }
        }
        Write-Host "Tasksequence " -NoNewline; Write-Host "$tspackageID" -ForegroundColor Yellow -NoNewline; Write-Host " could be used on " -NoNewLine; Write-Host "$DPsWithAllPackages" -ForegroundColor Yellow
        Write-Host "###############################################################################################"
    }
}

# ----------
# Main logic
# ----------

# Clear screen for the script
cls

# Prompt for ConfigMgr Server Name
$ConfigMgr_Server = Read-Host "Enter Hostname of SCCM-Server to connect to, [ENTER] for localhost"
If ($ConfigMgr_Server -eq ''){$ConfigMgr_Server = hostname}
Write-Verbose "$ConfigMgr_Server is selected"

# Connect to ConfigMgr
Import-Module "D:\SOURCES\SCCM.psm1" -force
Write-Host "Connecting to SCCM Server " -NoNewLine; Write-Host $ConfigMgr_Server -ForegroundColor Yellow
New-SCCMConnection -serverName $ConfigMgr_Server

# Get the list of all task sequences to choose from via a menu
Write-Host "Getting a list of all Task Sequences to select from"
Get-SCCMTaskSequencePackage | Sort-Object Name | ft Name,PackageID

# Prompt for Task Sequence to use when checking packages
$taskSequenceName = Read-Host 'Select Task Sequence (PackageID); [ENTER] to Cancel, "All" to check all Tasksequences'
If ($taskSequenceName -eq 'Cancel' -or $taskSequenceName -eq $null)
{

    Write-Host 'No Task Sequence selected or user selected "Cancel", exiting script...'
    Exit 

}
ElseIf ($taskSequenceName -eq 'All')
{
    $SelectedTS = $TaskSequences
}
Else
{
    $SelectedTS = $TaskSequences | ? {$_.Name -eq $taskSequenceName}
    $SelectedTSID = $SelectedTS.PackageID

}
$SelectedTSID = $taskSequenceName

# Get the list of all DPs to choose from via a menu
Write-Host "Getting a list of all Distribution Points to select from"
$global:dpList = Get-SCCMObject SMS_DistributionPointInfo
$DPNameList = ($global:dpList| Select-Object @{Name="Name"; Expression={$_.ServerName}}, NalPath, SiteCode, SiteName) | Sort-Object Name
($global:dpList| Select-Object @{Name="Name"; Expression={$_.ServerName}}, SiteCode, SiteName) | Sort-Object Name

# Prompt for Distribution Point to check the referenced packages against
$global:DPName = Read-Host 'Enter Name of desired Distribution Point (FQDN); [ENTER] for localhost, "All" to check all DPs'
If ($global:DPName -eq "")
{
    Write-Verbose "[ENTER] pressed, setting localhost"
    $global:DPName = ([System.Net.Dns]::GetHostByName(($env:computerName))).HostName
}

If ($global:DPName -eq 'All')
{
    Write-Verbose '"All" entered'
    $global:SelecteddpList =  $DPNameList
}
Else
{
    $global:SelecteddpList =  $DPNameList | ? {$_.Name -eq $global:DPName}
}

# Get the package status for all packages referenced 
# by the task sequence selected.
# Write-Host "Calling the CheckPackages function"
If ($taskSequenceName -eq 'All')
{
    Write-Verbose '"All" entered'
    $packageResults = Get-SCCMTaskSequencePackage | CheckPackages
}
Else
{
    Write-Verbose 'Selected DP is $SelectedTSID'
    $packageResults = Get-SCCMTaskSequencePackage -filter "PackageID='$SelectedTSID'"| CheckPackages
}</pre>
<p>&nbsp;</p>
<p><a href="https://www.hertes.net/wp-content/uploads/2013/06/sccm-ps1.png"><img fetchpriority="high" decoding="async" class="aligncenter size-full wp-image-1695" alt="sccm-ps1" src="https://www.hertes.net/wp-content/uploads/2013/06/sccm-ps1.png" width="997" height="583" srcset="https://www.hertes.net/wp-content/uploads/2013/06/sccm-ps1.png 997w, https://www.hertes.net/wp-content/uploads/2013/06/sccm-ps1-300x175.png 300w" sizes="(max-width: 997px) 100vw, 997px" /></a> <a href="https://www.hertes.net/wp-content/uploads/2013/06/sccm-ps2.png"><img decoding="async" class="aligncenter size-full wp-image-1696" alt="sccm-ps2" src="https://www.hertes.net/wp-content/uploads/2013/06/sccm-ps2.png" width="997" height="583" srcset="https://www.hertes.net/wp-content/uploads/2013/06/sccm-ps2.png 997w, https://www.hertes.net/wp-content/uploads/2013/06/sccm-ps2-300x175.png 300w" sizes="(max-width: 997px) 100vw, 997px" /></a></p>
<p>&nbsp;</p>
<p><em id="__mceDel"> Download-Link zum Skript:</em></p>
<p><a href="www.hertes.net/wp-content/uploads/2013/06/Get-SCCMMissingTSPackages.ps1" target="_blank">www.hertes.net/wp-content/uploads/2013/06/Get-SCCMMissingTSPackages.ps1</a></p>
<p><em>Link zur sccm.psm1:</em></p>
<p><a href="http://blogs.technet.com/b/mniehaus/archive/2010/04/07/make-sure-a-configmgr-task-sequence-has-all-the-packages-it-needs.aspx">http://blogs.technet.com/b/mniehaus/archive/2010/04/07/make-sure-a-configmgr-task-sequence-has-all-the-packages-it-needs.aspx</a></p>
<p>(Enthalten in <a href="http://blogs.technet.com/cfs-file.ashx/__key/communityserver-components-postattachments/00-03-32-36-07/CheckTaskSequences.zip">CheckTaskSequences.zip</a>)</p>
]]></content:encoded>
					
					<wfw:commentRss>https://www.hertes.net/2013/06/sccm-powershell-skript-um-fehlende-packages-fur-tasksequenzen-ausfindig-zu-machen/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>SCCM2012: Durch SEDO dauerhaft gesperrte Tasksequenzen entsperren</title>
		<link>https://www.hertes.net/2013/05/sccm2012-durch-sedo-dauerhaft-gesperrte-tasksequenzen-entsperren/</link>
					<comments>https://www.hertes.net/2013/05/sccm2012-durch-sedo-dauerhaft-gesperrte-tasksequenzen-entsperren/#comments</comments>
		
		<dc:creator><![CDATA[Haiko]]></dc:creator>
		<pubDate>Fri, 31 May 2013 12:59:05 +0000</pubDate>
				<category><![CDATA[SQL Server]]></category>
		<category><![CDATA[System Center Configuration Manager]]></category>
		<category><![CDATA[OSD]]></category>
		<category><![CDATA[SCCM]]></category>
		<category><![CDATA[SEDO]]></category>
		<category><![CDATA[SQL]]></category>
		<category><![CDATA[Tasksequenz]]></category>
		<guid isPermaLink="false">http://www.hertes.net/?p=1673</guid>

					<description><![CDATA[SEDO (Serialized Editing of Distributed Objects) soll im SCCM2012-Umfeld möglich machen, dass mehrere Admins gleichzeitig arbeiten, ohne sich gegenseitig in die Quere zu kommen. Wenn unter SCCM2007 ein Admin eine Tasksequenz bearbeitet hat, die noch bei einem anderen Admin zur Bearbeitung geöffnet war, dann &#8222;gewann&#8220; derjenige, der zuletzt gespeichert hat, was mitunter sehr ärgerlich war. Unter SCCM 2012 werden nun Tasksequenzen, die zum Bearbeiten geöffnet sind, gesperrt. Diese an sich sehr nützlich Funktion kann aber auch zu einem Problem werden. Die Sperre sollte nach 30 Minuten &#8222;Inaktivität&#8220; automatisch aufgehoben werden. Da dies aber ein Vorgang ist, den die SCCM-Konsole durchführt,&#8230;]]></description>
										<content:encoded><![CDATA[<p>SEDO (Serialized Editing of Distributed Objects) soll im SCCM2012-Umfeld möglich machen, dass mehrere Admins gleichzeitig arbeiten, ohne sich gegenseitig in die Quere zu kommen. Wenn unter SCCM2007 ein Admin eine Tasksequenz bearbeitet hat, die noch bei einem anderen Admin zur Bearbeitung geöffnet war, dann &#8222;gewann&#8220; derjenige, der zuletzt gespeichert hat, was mitunter sehr ärgerlich war.</p>
<p>Unter SCCM 2012 werden nun Tasksequenzen, die zum Bearbeiten geöffnet sind, gesperrt. Diese an sich sehr nützlich Funktion kann aber auch zu einem Problem werden. Die Sperre sollte nach 30 Minuten &#8222;Inaktivität&#8220; automatisch aufgehoben werden. Da dies aber ein Vorgang ist, den die SCCM-Konsole durchführt, kann es passieren, das eine gesperrte Tasksequenz dauerhaft gesperrt bleibt, wenn z.B. die Konsole abgestürzt ist.</p>
<p>Für die Sperrung ist die SQL-Tabelle SEDO_LockState zuständig.</p>
<p>Gesperrte Tasksequenzen kann man z.B. mit folgendem SQL-Statement abfragen:</p>
<pre lang="SQL" line="1">Select * FROM SEDO_LockState WHERE LockStateID != 0</pre>
<p><a href="https://www.hertes.net/wp-content/uploads/2013/05/TS_Screen2.png"><img decoding="async" class="aligncenter size-full wp-image-1683" alt="TS_Screen2" src="https://www.hertes.net/wp-content/uploads/2013/05/TS_Screen2.png" width="800" srcset="https://www.hertes.net/wp-content/uploads/2013/05/TS_Screen2.png 1160w, https://www.hertes.net/wp-content/uploads/2013/05/TS_Screen2-300x135.png 300w, https://www.hertes.net/wp-content/uploads/2013/05/TS_Screen2-1024x463.png 1024w" sizes="(max-width: 1160px) 100vw, 1160px" /></a></p>
<p>Das eine Tasksequenz gesperrt ist, wird auch beim Versuch, diese zu bearbeiten angezeigt:</p>
<p><a href="https://www.hertes.net/wp-content/uploads/2013/05/TS_Error.png"><img decoding="async" class="aligncenter size-full wp-image-1675" alt="TS_Error" src="https://www.hertes.net/wp-content/uploads/2013/05/TS_Error.png" width="700" height="301" srcset="https://www.hertes.net/wp-content/uploads/2013/05/TS_Error.png 700w, https://www.hertes.net/wp-content/uploads/2013/05/TS_Error-300x129.png 300w" sizes="(max-width: 700px) 100vw, 700px" /></a></p>
<p>Um nun eine Entsperrung zu erzwingen, ist folgendes SQL-Statement geeignet:</p>
<pre lang="SQL" line="1">UPDATE [CM_LPZ].[dbo].[SEDO_LockState]
SET [LockStateID] = 0
,[AssignedUser] = NULL
,[AssignedObjectLockContext] = NULL
,[AssignedMachine] = NULL
,[AssignmentTime] = NULL

WHERE [LockStateID] = '1'
GO</pre>
<p>(das &#8222;LPZ&#8220; in &#8222;CM_LPZ&#8220; ist durch den Sitecode zu ersetzen)</p>
<p>Aber Achtung: Microsoft unterstützt das manuelle Ändern der SQL-Datenbank nicht &#8211; ihr solltet also genau wissen, was ihr da tut!</p>
<p><a href="https://www.hertes.net/wp-content/uploads/2013/05/TS_Lösung.png"><img loading="lazy" decoding="async" class="aligncenter size-full wp-image-1674" alt="TS_Lösung" src="https://www.hertes.net/wp-content/uploads/2013/05/TS_Lösung.png" width="792" height="411" srcset="https://www.hertes.net/wp-content/uploads/2013/05/TS_Lösung.png 792w, https://www.hertes.net/wp-content/uploads/2013/05/TS_Lösung-300x155.png 300w" sizes="auto, (max-width: 792px) 100vw, 792px" /></a></p>
]]></content:encoded>
					
					<wfw:commentRss>https://www.hertes.net/2013/05/sccm2012-durch-sedo-dauerhaft-gesperrte-tasksequenzen-entsperren/feed/</wfw:commentRss>
			<slash:comments>2</slash:comments>
		
		
			</item>
	</channel>
</rss>
