Partager via


Pre-download content before application installation

This is one of those tricks that many of the experienced ConfigMgr/SCCM admins out there already know about but I wanted to spread the knowledge for all those not yet familiar with the trick.

The scenario often comes up where there is a need (slow links, network congestion concerns, etc.) to get your application files out to client machines and into their cache prior to installation, to provide a better installation experience.  For mandatory deployments this happens automatically.  You make the application available now but have a mandatory deadline at some appropriate time in the future, say 2 days from now on Monday.  The ConfigMgr client will see this configuration and start pulling the files into the client's cache so they will be local and ready for fast execution on Monday (after a quick CRC check to make sure files haven’t changed since download.  However, if you are doing an optional machine based deployment then ConfigMgr has no idea if the install will EVER kick, so no pre-download is done.

I have encountered customer scenarios where the desire is still to have the files pre-deployed to the client machines because they know that many folks will start doing optional installs once allowed.  In this case you can take advantage of the above functionality, even though the actual install will be optional.

In the package/program model you create your package with all the necessary files and you create your program to run the desired command line as normal but you also make another program.  This other program does something simple and silent, like an ipconfig or such.  This you make mandatory and deploy out immediately.  Because the package files are associated with the program they will start downloading and cone down the simple program will run, basically doing nothing.  With the files now in the ConfigMgr cache they will be ready for when the 2nd program runs, at which time they will be checked and used.

In the application model things are a little more difficult because deployment types don’t share binaries like they do in the package model.  In this scenario you have to do a little more work such that a package (or application) copies files down to some temp location then your optional deployment has to be changed to execute from the temp location instead of the normal ConfigMgr cache.  Not so clean and nice. L

Comments

  • Anonymous
    October 09, 2015
    Good topic for a post! I'm running into this with customers now. One other thing I've tested with Applications is setting the required deployment with a future deadline... monitor the status until all/most target machines are at "In Progress/Content Downloaded"... then replace the required deployment with an available deployment... when the available deployment is run, it'll run from the cache. Tip, hide the required deployment in software center so users don't try to run until pre-maturely. This can get tedious if you have a lot of deployments to manage, but at low volume it seems like a good option!
    • Anonymous
      April 26, 2017
      How do you monitor them? any specific report that i can use?
  • Anonymous
    October 12, 2015
    I just posted a feature request for this on user voice, if you think it would be a useful addition to the product please comment on my idea and vote it up!https://configurationmanager.uservoice.com/forums/300492-ideas/suggestions/10177275-option-to-pre-download-content-to-client-cache-for