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

Die*_*ano 5 windows powershell windows-task-scheduler gcloud

我正在运行以下 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
Run Code Online (Sandbox Code Playgroud)

我使用命令:

powershell -Command  "start-process -verb runAs "powershell " -argumentlist "E:\Tableau\test.ps1""
Run Code Online (Sandbox Code Playgroud)

会提示以下消息:

迅速的

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

现在我需要使用 Windows 任务计划程序自动执行此脚本,我的操作如下:

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

命令设置

我将任务设置为由用户 SYSTEM 以最高权限运行:

用户和权限

在这种情况下,什么也不会发生。

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

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'.
Run Code Online (Sandbox Code Playgroud)

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

当从非管理员提升的 CMD 触发时,最后一个命令可以顺利运行,但在 Windows 任务计划程序中设置时将无法运行:

C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe -ExecutionPolicy Bypass -Command  "start-process -verb runAs "powershell " -argumentlist "E:\Tableau\test.ps1""
Run Code Online (Sandbox Code Playgroud)

我也尝试过这个,它在任务计划程序上不起作用,在遇到 CMD 时将手动运行,但也会因权限被拒绝而失败,如我列出的上一个命令:

powershell.exe -NoProfile -NoLogo -NonInteractive -ExecutionPolicy Bypass -File "E:\Tableau\test.ps1"
Run Code Online (Sandbox Code Playgroud)

如何正确设置 myWindows 任务计划程序以成功运行此脚本?

Die*_*ano 5

这最终对我有用。

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

或者通过管理员提升的 CMD 运行单个命令:

powershell -ExecutionPolicy Bypass -command "E:\Tableau\test.ps1 2>&1 > E:\Tableau\test_output.txt"
Run Code Online (Sandbox Code Playgroud)

真正的问题是我在 Google Cloud VM 上运行它,我需要更改 VM 的范围才能访问所有 API。

完成此操作后,我能够成功运行该脚本。