如何在具有管理员权限的 Windows 任务计划程序中设置 Powershell 脚本?

How to setup a Powershell Script in Windows Task Scheduler with admin permissions?

我正在运行使用以下 PowerShell 脚本创建 Tableau 备份并使用 Windows 任务计划程序将其上传到 Google 云存储。

#Tableau Server backup
&$tsm maintenance backup -f $Backups_file -d -u $User -p $Password


CD "C:\Program Files (x86)\Google\Cloud SDK\google-cloud-sdk\bin"
$backups_folder = "D:\Tableau Server\data\tabsvc\files\backups\" #default backup path for Tableau installation #&$tsm configuration get -k basefilepath.backuprestore
$filename = get-childitem -path $backups_folder -Filter "*.tsbak" | where-object { -not $_.PSIsContainer } | sort-object -Property $_.CreationTime | select-object -last 1 
$fullpath = Join-Path $backups_folder $filename 
gsutil cp $fullpath  gs://my_bucket/backups #upload the latest backup to GCP

我使用命令:

powershell -Command  "start-process -verb runAs "powershell " -argumentlist "E:\Tableau\test.ps1""

提示以下信息:

运行脚本,创建备份并成功上传到 GCS。

现在我需要使用 Windows Task Scheduler 自动执行此脚本,我按如下方式进行操作:

Program/script: powershell
Add arguments (optional): -Command  "start-process -verb runAs "powershell " -argumentlist "E:\Tableau\test.ps1""

我将任务设置为 运行,用户 SYSTEM 具有最高权限:

在这种情况下,没有任何反应。

我尝试了创建备份但未上传到 GCS 的其他命令。当我使用命令 powershell -executionpolicy bypass -file 'E:\Tableau\Tableau Backup\test.ps1 在 CMD 上手动 运行 时,我收到以下错误:

PS D:\Tableau Server\data\tabsvc\files\backups> powershell -executionpolicy bypass -file 'E:\Tableau\Tableau Backup\test
.ps1'
CommandException: Error opening file "file://D:\Tableau Server\data\tabsvc\files\backups\TableauBackup-2020-06-06.tsbak"
: [Errno 13] Permission denied: u'D:\Tableau Server\data\tabsvc\files\backups\TableauBackup-2020-06-06.tsbak'.

很明显,使用 gsutil 命令时出现权限错误。当我以管理员身份手动启动 cmd 时,命令 运行s 很顺利。

最后一条命令在从 non-administrator 提升的 CMD 触发时运行顺利,但在 Windows 任务计划程序中设置时将无法运行:

C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe -ExecutionPolicy Bypass -Command  "start-process -verb runAs "powershell " -argumentlist "E:\Tableau\test.ps1""

我也试过 this,它不会在任务计划程序上工作,当 运行 进入 CMD 时会手动 运行,但也会失败,权限被拒绝,就像我之前的命令一样列出:

powershell.exe -NoProfile -NoLogo -NonInteractive -ExecutionPolicy Bypass -File "E:\Tableau\test.ps1"

如何正确设置我的Windows Task Scheduler 以成功运行 这个脚本?

这最终对我有用。

Program/script: powershell
Add arguments (optional): -ExecutionPolicy Bypass -command "E:\Tableau\test.ps1 2>&1 > E:\Tableau\test_output.txt"

或者在从管理员提升的 CMD 到 运行 的单个命令中:

powershell -ExecutionPolicy Bypass -command "E:\Tableau\test.ps1 2>&1 > E:\Tableau\test_output.txt"

真正的问题是我 运行 在 Google 云 VM 上执行此操作,我需要更改 VM 的范围才能访问所有 API。

在我这样做之后,我能够 运行 脚本成功。

我也无法启动脚本,经过大量搜索后无济于事。没有 -ExecutionPolicy,没有命令,没有文件,"" 和 '' 之间没有区别。

我只是将命令 I 运行 放在 powershell 的参数选项卡中:./scripts.ps1 parameter1 11 parameter2 xx 等等。现在调度程序工作了。 程序:Powershell.exe 开始于:C:/location/of/script/