it-roy-ru.com

Указание директории "start-in" в команде schtasks в windows

Я понимаю, что на этот вопрос "ответили" в следующей теме: Указание текущего каталога для запланированных задач с помощью schtasks.exe

Тем не менее, мне все еще трудно понять ответ и точно определить, как будет выглядеть результат для моей ситуации.

Моя команда schtasks выглядит так:

Schtasks /Create /TR "C:\Program Files\Java\jre6\bin\javaw.exe main.MoveFile input.txt" /SC WEEKLY /TN mytask

Я хочу указать начало в каталоге "C:\My Library". Помещение "\" до того, как раздел tr заполнит начальный каталог "C:\Program Files\Java\jre6\bin".

Я много возился с этим, но я просто не могу заставить его работать.

18
Benny

Не уверен, в какой версии Windows вы работаете, но, прочитав другой вопрос, похоже, что задачи в Vista/Server 2008 не предоставляют параметр команды, который позволил бы вам указать каталог «start-in» напрямую. Обходные пути, которые предоставили люди, были:

  1. Используйте флаг/v1 для создания XP/2003-совместимой задачи, в этом случае автоматически устанавливается каталог «запуск». Не уверен, что он установлен, но я подозреваю, что это может быть тот же каталог, что и исполняемый файл вашей задачи, который не будет работать для вас.
  2. Создайте свою задачу из файла XML (с помощью параметра/XML), который позволяет вам указать каталог для запуска. Извините, я не знаю синтаксис/структуру этого XML-файла.
  3. Вместо этого создайте свою задачу, используя пользовательский интерфейс планировщика задач. 
14
Amal Sirisena

ОБНОВЛЕНИЕ: Обратите внимание, что начиная с Powershell v3 (но только под Windows 2012 и выше!) Появился новый API, который я считаю гораздо более привлекательным:

$taskPath = "\MyTasksFolder\"
$name = 'MyTask'
$runAt = '5:00 AM'
$exe = 'my.exe'
$params = 'command line arguments'
$location = "C:\Path\To\MyTask"

Unregister-ScheduledTask -TaskName $name -TaskPath $taskPath -Confirm:$false -ErrorAction:SilentlyContinue  

$action = New-ScheduledTaskAction –Execute "$location\$exe" -Argument "$params" -WorkingDirectory $location
$trigger = New-ScheduledTaskTrigger -Daily -At $runAt
Register-ScheduledTask –TaskName $name -TaskPath $taskPath -Action $action –Trigger $trigger –User 'someuser' -Password 'somepassword' | Out-Null

Решение Amal с переключателем /v1 великолепно, но не позволяет создавать задачи в пользовательских папках (т. Е. Вы не можете создать «MyCompany\MyTask», и все заканчивается в корневой папке), поэтому я наконец-то получил сценарий PowerShell, описанный ниже.

Использование:  

CreateScheduledTask -computer:"hostname-or-ip" `
                    -taskName:"MyFolder\MyTask" `
                    -command:"foo.exe" `
                    -arguments:"/some:args /here" `
                    -workingFolder:"C:\path\to\the\folder" `
                    -startTime:"21:00" `
                    -enable:"false" `
                    -runAs:"DOMAIN\user" `
                    -runAsPassword:"[email protected]$$w0rd"

(Обратите внимание, enable должен быть в нижнем регистре - для логического значения вам понадобится $value.ToString().ToLower())

Реализация:

Функция использует определение задачи XML и COM-объект «Schedule.Service».

#####################################################
#
#  Creates a Windows scheduled task triggered DAILY.
#  Assumes TODAY start date, puts "run-as" user as task author.
#
#####################################################
function CreateScheduledTask($computer, $taskName, $command, $arguments, $workingFolder, $startTime, $enable, $runAs, $runAsPassword)
{    
    $xmlTemplate = "<?xml version='1.0' encoding='UTF-16'?>
        <Task version='1.2' xmlns='http://schemas.Microsoft.com/windows/2004/02/mit/task'>
          <RegistrationInfo>
            <Date>{0}</Date>
            <Author>{1}</Author>
          </RegistrationInfo>
          <Triggers>
            <CalendarTrigger>
              <StartBoundary>{2}</StartBoundary>
              <Enabled>true</Enabled>
              <ScheduleByDay>
                <DaysInterval>1</DaysInterval>
              </ScheduleByDay>
            </CalendarTrigger>
          </Triggers>
          <Principals>
            <Principal id='Author'>
              <UserId>{1}</UserId>
              <LogonType>Password</LogonType>
              <RunLevel>LeastPrivilege</RunLevel>
            </Principal>
          </Principals>
          <Settings>
            <IdleSettings>
              <Duration>PT10M</Duration>
              <WaitTimeout>PT1H</WaitTimeout>
              <StopOnIdleEnd>true</StopOnIdleEnd>
              <RestartOnIdle>false</RestartOnIdle>
            </IdleSettings>
            <MultipleInstancesPolicy>IgnoreNew</MultipleInstancesPolicy>
            <DisallowStartIfOnBatteries>true</DisallowStartIfOnBatteries>
            <StopIfGoingOnBatteries>true</StopIfGoingOnBatteries>
            <AllowHardTerminate>true</AllowHardTerminate>
            <StartWhenAvailable>false</StartWhenAvailable>
            <RunOnlyIfNetworkAvailable>false</RunOnlyIfNetworkAvailable>
            <AllowStartOnDemand>true</AllowStartOnDemand>
            <Enabled>{3}</Enabled>
            <Hidden>false</Hidden>
            <RunOnlyIfIdle>false</RunOnlyIfIdle>
            <WakeToRun>false</WakeToRun>
            <ExecutionTimeLimit>P3D</ExecutionTimeLimit>
            <Priority>7</Priority>
          </Settings>
          <Actions Context='Author'>
            <Exec>
              <Command>{4}</Command>
              <Arguments>{5}</Arguments>
              <WorkingDirectory>{6}</WorkingDirectory>
            </Exec>
          </Actions>
        </Task>"
    $registrationDateTime = [DateTime]::Now.ToString("yyyy-MM-dd") + "T" + [DateTime]::Now.ToString("HH:mm:ss")
    $startDateTime = [DateTime]::Now.ToString("yyyy-MM-dd") + "T" + $startTime + ":00"
    $xml = $xmlTemplate -f $registrationDateTime, $runAs, $startDateTime, $enable, $command, $arguments, $workingFolder

    $sch = new-object -ComObject("Schedule.Service")
    $sch.Connect($computer)
    $task = $sch.NewTask($null)
    $task.XmlText = $xml

    $createOrUpdateFlag = 6
    $sch.GetFolder("\").RegisterTaskDefinition($taskName, $task, $createOrUpdateFlag, $runAs, $runAsPassword, $null, $null) | out-null 
}
12
andreister

Если все остальное терпит неудачу, вы можете перенаправить на командный файл, который устанавливает свой собственный CD, а затем вызывает вашу программу.
например: 

Schtasks /Create /TR "C:\example\batch.bat" /SC WEEKLY /TN mytask

Как в счётчик, так и 

cd "%temp%\"
"C:\Program Files\Java\jre6\bin\javaw.exe main.MoveFile input.txt"

как "C:\example\batch.bat". Это должно сохранить текущий каталог как тот, который вы изменили в командном файле, и сохранить все ссылки, относящиеся к этому. 

7
Evan

Пытаться 

cd /d "C:\Program Files\Java\jre6\bin" & schtasks /create /tr "C:\Program Files\Java\jre6\bin\javaw.exe main.MoveFile input.txt" /sc WEEKLY /tn mytask

Измените рабочий каталог, а затем запустите schtasks.

2
Yuh-Rong Leu

Как вы заметили, хитрость использования дополнительных кавычек в параметре/TR позволяет вам использовать только тот же каталог, в котором находится исполняемый файл. Если вы хотите указать другой рабочий каталог, вам следует использовать параметр/XML и указать файл XML, в котором указан рабочий каталог. Команда будет выглядеть примерно так:

SchTasks /Create /TN "Foo" /XML task.xml

Файл XML будет выглядеть примерно так:

<?xml version="1.0" ?>
<Task xmlns="http://schemas.Microsoft.com/windows/2004/02/mit/task">
    <RegistrationInfo>
        <Date>2006-05-02T13:21:17</Date>
        <Author>AuthorName</Author>
        <Version>1.0.0</Version>
        <Description>Call MoveFile</Description>
    </RegistrationInfo>
    <Triggers>
        <CalendarTrigger>
            <StartBoundary>2011-11-02T00:00:00</StartBoundary>
            <ScheduleByDay>
                <DaysInterval>1</DaysInterval>
            </ScheduleByDay>
        </CalendarTrigger>
    </Triggers>
    <Principals>
        <Principal>
            <UserId>Administrator</UserId>
            <LogonType>InteractiveToken</LogonType>
        </Principal>
    </Principals>
    <Settings>
        <Enabled>true</Enabled>
        <AllowStartOnDemand>true</AllowStartOnDemand>
        <AllowHardTerminate>true</AllowHardTerminate>
    </Settings>
    <Actions>
        <Exec>
            <Command>C:\Program Files\Java\jre6\bin\javaw.exe</Command>
            <Arguments>main.MoveFile input.txt</Arguments>
            <WorkingDirectory>C:\My Library</WorkingDirectory>
        </Exec>
    </Actions>
</Task>

Дополнительная информация о схеме XML приведена здесь: http://msdn.Microsoft.com/en-us/library/windows/desktop/aa383609(v=VS.85).aspx

1
Bernard Chen

Я обнаружил, что если вы используете соглашение о присвоении имен 8.3 в командной строке SCHTASKS для пути и имен файлов, поле «Start In» добавляется с путем к файлу - 

например «C:\Progra ~ 1\NBVCl ~ 1\nbv_up ~ 1.exe» приведет к появлению «C:\Progra ~ 1\NBVCl ~ 1» в область "начать в"

0
Chris Roll

Единственным способом было бы использовать XML Flle, используйте следующую команду: schtasks/Create/XML C:\file.xml/TN TaskName/RU домен\username/RP пароль

Пример XML-файла, который будет запускаться каждый день в 23:00, папка C:\task установит запуск в каталоге:

<?xml version="1.0" encoding="UTF-16"?>
<Task version="1.2" xmlns="http://schemas.Microsoft.com/windows/2004/02/mit/task">
  <RegistrationInfo>
    <Date>2016-07-13T07:56:56</Date>
    <Author>Administrator</Author>
  </RegistrationInfo>
  <Triggers>
    <CalendarTrigger>
      <StartBoundary>2016-07-13T23:00:00</StartBoundary>
      <Enabled>true</Enabled>
      <ScheduleByDay>
        <DaysInterval>1</DaysInterval>
      </ScheduleByDay>
    </CalendarTrigger>
  </Triggers>
  <Principals>
    <Principal id="Author">
      <UserId>domain\Administrator</UserId>
      <LogonType>Password</LogonType>
      <RunLevel>HighestAvailable</RunLevel>
    </Principal>
  </Principals>
  <Settings>
    <MultipleInstancesPolicy>IgnoreNew</MultipleInstancesPolicy>
    <DisallowStartIfOnBatteries>true</DisallowStartIfOnBatteries>
    <StopIfGoingOnBatteries>true</StopIfGoingOnBatteries>
    <AllowHardTerminate>true</AllowHardTerminate>
    <StartWhenAvailable>false</StartWhenAvailable>
    <RunOnlyIfNetworkAvailable>false</RunOnlyIfNetworkAvailable>
    <IdleSettings>
      <StopOnIdleEnd>true</StopOnIdleEnd>
      <RestartOnIdle>false</RestartOnIdle>
    </IdleSettings>
    <AllowStartOnDemand>true</AllowStartOnDemand>
    <Enabled>true</Enabled>
    <Hidden>false</Hidden>
    <RunOnlyIfIdle>false</RunOnlyIfIdle>
    <WakeToRun>false</WakeToRun>
    <ExecutionTimeLimit>P3D</ExecutionTimeLimit>
    <Priority>7</Priority>
  </Settings>
  <Actions Context="Author">
    <Exec>
      <Command>C:\taskfolder\task.bat</Command>
      <WorkingDirectory>C:\taskfolder</WorkingDirectory>
    </Exec>
  </Actions>
</Task>
0
Bob

Примечание: вот проблема, которую я только что видел с этим ..

Примечание: у вас должно быть две строки:

REM NOTE:You have to create the schedule first
SCHTASKS /S SERVER /CREATE /TN "SERVER_RESTART" /RU "" /TR "D:\WORK\scripts\__server_restart.bat 1" /SC MONTHLY /MO FIRST /D Sun /ST:02:10
REM The next line is run to set the run in folder as well as set the: run as: NT AUTHORITY\SYSTEM
SCHTASKS /S SERVER /CHANGE /TN "SERVER_RESTART" /RU "" /TR "D:\WORK\scripts\__server_restart.bat 1"

Одна из вещей, которую я заметил в Windows 2008, это то, что она обрабатывает пакетные сценарии, например, намного лучше, чем в 2003 году. Я не думаю, что папка «run in» так важна, как я только что запустил перезапуск сервера на тестовой машине вручную из планировщика заданий, и он работает просто отлично ..

Для людей, которые могут столкнуться с проблемами с экранированием символов и тому подобное, рассмотрите следующее:

SCHTASKS /CHANGE /S SERVER /RU "" /TR "powershell -file "\"D:\WORK\ps\Zip_up_files\Zip_up_files.ps1"\"" /TN "PowerShell - New Archive"

или другой пример:

SCHTASKS /CREATE /S SERVER /RU "" /TR "powershell -file "\"D:\WORK\ps\page_test.ps1"\"" /TN "PowerShell - Page Test" /SC MINUTE /MO 3 /ST:23:00

Примечание: дополнительное цитирование и дополнительная обратная косая черта.

Надеюсь это поможет!

0
Leptonator