Skip to main content

Use PowerShell to remove packages from the Distribution Points

This post is inspired by one of the activities which we had to recently do.

We have a lot of branch DP's where we want to cleanup all the obsolete packages (which are not used anymore). This can be done manually by going in the ConfigMgr Console Packages node and updating the DP's manually for each package.

But where is fun in doing that ...Lol

I couldn't find much on the internet ..So I tested it in my Lab first and then in QA in our environment and then did it in PROD.

For this post demonstration I am showing this on my LAB (ConfigMgr12) but it does work with ConfigMgr07.

Note- ConfigMgr 2012 R2 has this cmdlet Remove-CMContentDistribution which can do this but am showing the method which will work with all ConfigMgr versions (hopefully).

Right now I have distributed 3 packages to the only DP (DexSCCM) in my environment.



Now we can get the same Information about which DP the particular package is Distributed by querying the SMS_DistributionPoint Class. See below:




Now If you want to remove suppose the Package with ID DEX00001 (USMT package) then I just have to go ahead and remove this object. See me do it:





ConfigMgr Console does reflect the change:



[UPDATE] - You can see the SMSProv.log that will have entry of you deleting an instance of SMS_DistributionPoint.

Once I knew this...it was very easy to quickly wrap a function which will remove a list of PackageIDs supplied to it from a DP name.

Have uploaded the Script in Technet Repositoy (tested in ConfigMgr 07 and 12). Give it a try and if you like it give it a good rating.

Once you use this method then it may take some time for the package to be removed and free Disk Space on the DP. For me it was around 1 hour (in the PROD environment)...So be patient and get a Coffee while the Script cleans up your DPs ;)


Popular posts from this blog

Test connectivity via a specific network interface

Recently while working on a Private cloud implementation, I came across a scenario where I needed to test connectivity of a node to the AD/DNS via multiple network adapters.  Many of us would know that having multiple network routes is usually done to take care of redundancy. So that if a network adapter goes down, one can use the other network interface to reach out to the node. In order to make it easy for everyone to follow along, below is an analogy for the above scenario: My laptop has multiple network adapters (say Wi-Fi and Ethernet) connected to the same network. Now how do I test connectivity to a Server on the network only over say Wi-Fi network adapter?

PowerShell + SCCM : Run CM cmdlets remotely

Today I saw a tweet about using implicit remoting to load the Configuration Manager on my machine by Justin Mathews . It caught my eye as I have never really tried it, but theoretically it can be done. Note - The second tweet says "Cannot find a provider with the name CMSite", resolution to which is in the Troubleshooting section at the end.

PowerShell : Trust network share to load modules & ps1

Problem Do you have a central network share, where you store all the scripts or PowerShell modules ? What happens if you try to run the script from a network share ? or if you have scripts (local) which invoke scripts or import PowerShell modules stored on this network share ? Well you would see a security warning like below (Note - I have set execution policy as 'Unrestricted' not 'bypass' here): Run a .ps1 from the network share Well this is a similar warning, which you get when you download scripts from Internet. As the message says run Unblock-File cmdlet to unblock the script and then run it, let's try it.