I do a fair amount of script writing to make my life easier. If it’s a repeated job, I try and automate it so that my time is freed up for more important (interesting) things. This is especially true if the task is tedious (with many manual steps) or involves lots of waiting around (like an Exchange CU). I have a fair number of Powershell scripts which run from Task Scheduler under Windows Server 2016. There are a lot of options to configure, so this can be complex. I’ll share the cheatcode way of doing this at the end.
- Load Task Scheduler.
- Click
Create Task
- Under the General tab, fill in a Name and Description. We’ll circle back to the other options at the end.
- Click Triggers. Most of my jobs run on a time-based schedule, not events (like computer startup). Setup the schedule that you need.
- Under the Actions tab, click New. Another window will appear. Leave the Action as
Start a program
.
If the script runs under Powershell 5.1, addPowershell
to the Program/Script field.
If the script runs under Powershell 7, add"C:\Program Files\PowerShell\7\pwsh.exe"
to the Program/Script field. It’s important to have the quotes so that the parser doesn’t freak out over the space in ‘Program Files’.
Add the following Arguments:-executionpolicy bypass -command "& '\\SERVER\SCRIPT REPOSITORY \script.ps1'"
. Again, I need double quotes around my UNC because of the space. - I usually clear the Power options under the Conditions tab. If the OS thinks that our server is now running on battery power, we have bigger issues.
- Under Settings, I usually adjust Stop the task if it runs longer than… field to something appropriate for the job schedule.
- Back to the General tab. Under the Security Options, I add the service account that my scripts run under. I set the task to Run whether the user is logged in or not, with highest priviledges to bypass any UAC problems and Configure for Windows Server 2016. (I have no idea what the real-world implications of setting the OS field are, since my scripts seem to work with this is also set to ‘Windows Server 2008’).
- Click
OK
. You’ll be prompted for the password of the credentials you used in #8. At the end of all this, I like to manually run the task by right-clicking it. This is a final sanity check that everything works. It’s easier for me to check at the time of setup (instead of the first time it runs) because my brain is already in that space.
Since I promised the cheatcode way of doing this, here’s how I like to add new tasks that are similar to existing ones. Since most of mine are scripts, the Task Scheduler settings are pretty much identical. This method helps avoid problems when editing the Arguments field - the string is so long and the field window is so small that I always have to scroll and I hate trying to figure out if I’ve keyed things in properly.
- In Task Scheduler, Find a task that closely matches the new one you’re implementing.
- Select it, right-click and choose
Export
. - Save the XML file someone easily accessed, like the Desktop.
- Right-click the resulting file and open it in Notepad (or the editor of your choice).
- Update the
<Description>
,<URI>
and<Arguments>
fields with the correct values. - Save the file.
- Back in Task Scheduler, select
Import Task
. - Browse to the XML file you just edited, and Open it.
- Task scheduler will add a new task. You’ll have to re-enter the password and possibly adjust the schedule, but everything else should be correct.