В шедулере при настройке задачи укажи путь к целевой папке чуть ниже пути к файлу
Не понятный глюк. Создаю ярлык на батник в Автозагрузке, либо в Планировщике задач - он не запускается после старта системы.
В автозагрузке два ярлыка на два батника, listener запускается а майнер нет.
Тот же майнер и в Планировщике - тоже не запускается.
Если запускать руками из автозагрузки - запускается.
Чтото гугл толком ничего не подсказывает
Alexei209
Свой человек
Не понятный глюк. Создаю ярлык на батник в Автозагрузке, либо в Планировщике задач - он не запускается после старта системы.
В автозагрузке два ярлыка на два батника, listener запускается а майнер нет.
Тот же майнер и в Планировщике - тоже не запускается.
Если запускать руками из автозагрузки - запускается.
Чтото гугл толком ничего не подсказывает
Посмотреть вложение 59582
nicehash надо удалить и все заработает.
fozzzzz
Бывалый
В шедулере при настройке задачи укажи путь к целевой папке, чуть ниже пути к файлу.
Попробуй может так.
XoHoL
Свой человек
evgpinsk
Свой человек
XoHoL
Свой человек
Батник лежит в той-же папке что и miner.exe? Вместо timeout попробуйте использовать ping 127.0.0.1 -n 50
evgpinsk
Свой человек
В шедулере при настройке задачи укажи путь к целевой папке, чуть ниже пути к файлу.
Попробуй может так.
И читал про этот способ, но почему-то не попробовал )
Спасибо - помогло
evgpinsk
Свой человек
Батник лежит в той-же папке что и miner.exe? Вместо timeout попробуйте использовать ping 127.0.0.1 -n 50
Да в той же. На других ригах вроде всё тоже самое, и батники стартуют из автозагрузки. А этот какойто особенный. Но проблема решилась способом выше
Мазай33
Пляшущий с бубном
У меня тоже два батники в автозагрузке не стартовали. Только первый запускался . Запилил батник для запуска тех двух и кинул его в автозагрузку. Теперь норм.
Sergeybn
Знающий
Сделайте задержку старта одного из батника на 30 сек-1 минуты. Должно помочь.
evgpinsk
Свой человек
Сделайте задержку старта одного из батника на 30 сек-1 минуты. Должно помочь.
Сверху батник. в нём первой строчкой задержка. Это не помогало, батник тупо не запускался. Помогло только:
В шедулере при настройке задачи укажи путь к целевой папке, чуть ниже пути к файлу.
Ivan_Nsk_54
Пляшущий с бубном
права администратора если стоят на майнере надо убрать
Tonic
Бывалый
Батник в автозагрузке. ну дык у тебя в батнике не прописан путь к файлу. если там просто минер.экзе, то он файл будет искать в папке, в которой лежит.. путь пропиши, и будет тебе счастье (c:\miner\miner.exe . ) а если там ярлык то дай ему права на запуск.
evgpinsk
Свой человек
Батник в автозагрузке. ну дык у тебя в батнике не прописан путь к файлу
Откуда догадались? )
На самом деле всё правильно реализовано, в автозагрузке естественно ярлык на батник, сам батник в одной папке с майнером. Именно глюк в том, что сам батник не запускается, т..е при старте системы я не вижу окна командной строки, в котором идёт пауза в 50 секунд.
Если жи из Автозагрузки руками щёлкнуть по ярлыку - батник запустится. Тоже самое было и с "планировщиком задач". Как вылечить - уже подсказали выше.
На 3х других ригах всё точно также, но Автозагрузка работает
Tonic
Бывалый
Откуда догадались? )
На самом деле всё правильно реализовано, в автозагрузке естественно ярлык на батник, сам батник в одной папке с майнером. Именно глюк в том, что сам батник не запускается, т..е при старте системы я не вижу окна командной строки, в котором идёт пауза в 50 секунд.
Если жи из Автозагрузки руками щёлкнуть по ярлыку - батник запустится. Тоже самое было и с "планировщиком задач". Как вылечить - уже подсказали выше.
На 3х других ригах всё точно также, но Автозагрузка работает
Как закидывали ярлык туда? Через винду? Винда просила права админа при записи в системную папку?
evgpinsk
Свой человек
Как закидывали ярлык туда? Через винду? Винда просила права админа при записи в системную папку?
Да, через винду, простым копированием в папку. Помоему не просила. Ярлык на второй батник запускается оттуда. Поэтому и говорю что непонятный глюк
Навигация по посту
Работа планировщика в Powershell
Отличительной чертой работы Powershell является то, что мы должны создать каждый из объектов (результат команд) планировщика отдельно, а затем объединить их с помощью 1 команды. Сами объекты делятся на следующие:
- Action (Действие) - определяет что мы должны запустить. Действия проявляются как программа (например браузер) с аргументами (открыть определенный сайт). В одной задаче может быть до 32 действий;
- Trigger (Триггер) - это событие при котором должно запуститься действие. Событие может быть привязано к времени или каким-то процессом в системе (включение компьютера, вход пользователя и т.д.). Время можно устанавливать как определенное, например в 14:00, так и интервальное - каждые 2 часа. Так же как и действий триггеров может быть несколько.
- Settings (Настройки) - дополнительные условия обработки задач. Это может быть перезапуск в случае сбоя задачи или самоудаление если задача не используется.
- Security Options (Параметры безопасности) - определяют привилегии и пользователя от имени которого будут запущены задания.
3 и 4 пункт не является обязательными при создании задачи т.к. уже имеет настройки по умолчанию.
За создание задач в планировщике отвечает модуль ScheduledTasks, который имеет следующие команды:
Создание скрипта для тестирования
Создание выполняемого действия для планировщика
Действия выше аналогичны следующим настройкам в интерфейсе (т.е. так мы обычно добавляем скрипт Powershell в планировщик):
Создание временного события - триггера
Системные события, которые мы можем использовать, следующие:
- AtLogOn - во время входа пользователя в систему;
- AtStartup - во время запуска системы.
Аргументы связанные со временем:
- At - точное время выполнение скрипта;
- Daily - ежедневно;
- DaysInterval - интервал в днях. Если указать цифру 1, то подразумевается, что задача будет запускаться ежедневно. Если указать 2 - то задача будет запускаться через день;
- DaysOfWeek - день недели, когда будет выполнен запуск. Возможны варианты: Sunday, Monday, Tuesday, Wednesday, Thursday, Friday, Saturday;
- Once - запуск будет выполнен единожды;
- Weekly - запуск по неделям;
- WeeksInterval - интервал между неделями;
- RandomDelay - указывает задержку между запусками. Задержка определяется случайно от указанного значения. Принимает не число, а объект TimeSpan;
- RepetitionDuration - Срок действия задачи. Принимает не число, а объект TimeSpan.
- RepetitionInterval - время через которое задача будет повторяться. Принимает не число, а объект TimeSpan.
Большую часть команд, связанных со временем, мы можем сочетать вместе. Так, например, мы создадим триггер выполнится однажды в 13:00:
Еще несколько примеров:
Учитывайте, что вы можете использовать несколько триггеров и действий. Для этого вы должны перечислить их через запятую.
TaskPath указывает где была создана задача. В примере выше это произошло в корне планировщика:
Вы можете использовать аналогичный параметр для регистрации задачи в другой директории:
Способа узнать путь два:
В powershell есть еще одна команда, которая может участвовать в создании задач "New-ScheduledTask". Основное отличие такой команды в том, она не регистрирует (добавляет) задачу в сервис планировщика. Если бы мы использовали обе команды это бы выглядело так:
Запуск и получение дополнительной информации
У нас так же есть 2 команды, которые возвращают информацию о задачах.
Первая команда просто возвращает список задач, которые есть в каталогах планировщика их статус и путь:
У команды запуска и получения задач из планировщика можно использовать параметры:
- TaskName - имя объекта;
- TaskPath - путь до объекта.
Более полезная команда следующая, так как вернет немного больше информации:
Само собой все эти команды можно использовать в конвейере:
Если задача занимает много времени и ее нужно остановить - можно выполнить следующие действия:
Фильтрация через Where-Object в Powershell с примерами
Изменение пользователя, параметров безопасности и уровня запуска
- Пользователь, от имени которого будет выполнен запуск;
- Выполняется ли задача для вошедших в систему пользователей;
- Привилегии запуска (от пользователя/администратора);
- Совместимость.
В графическом интерфейсе эти параметры настраиваются в следующем блоке:
С помощью следующих команд мы изменим пользователя, повысим права и изменим совместимость:
Если у вас будет следующая ошибка, то скорее всего она связана с неверным пользователем:
- Set-ScheduledTask : No mapping between account names and security IDs was done.
Само собой эти же объекты можно использовать при создании (регистрации) задачи в планировщике:
Учитывайте, что у New-ScheduledTaskSettingsSet около 30 возможных параметров (работа при отключенной батареи, максимальное количество перезапусков и т.д.). В примере выше рассмотрено лишь несколько.
Изменение триггеров и действий
С помощью Set-ScheduledTask так же добавляются и изменяются триггеры и действия. Изменение будут заключаться в полной замене существующих триггеров и действий у задач. Вам просто нужно создать объект по аналогии с тем, как это делалось в предыдущих разделах:
Бэкап, удаление и восстановление задач планировщика с Powershell
Удобной возможностью использования Powershell является импорт и экспорт задач планировщика. По сути вы можете создать шаблон, который можно использовать на разных компьютерах без особой работы с кодом. По умолчанию, сам Powershell, не предоставляет прямой возможности бэкапа и восстановления, но это можно сделать через другие команды.
Резервное копирование
Для бэкапа мы можем использовать команду Export-CliXml. Для этого нам нужно будет получить задачу и использовать конвейер:
Удаление, отключение и включение
Если требуется только отключить задачу используйте Disable:
Восстановление
Восстановление выполняется в несколько шагов. Первое - мы должны выполнить импорт XML документа в Powershell:
На одном из сайтов я прочитал, что следующий параметр нужно изменять на "Interactive", так как без него не будет работать задача, но у меня этот параметр не изменялся при экспорте:
Этот параметр связан со входом пользователя через GUI. Аналогичное название в интерфейсе планировщика задач "Выполнять только для пользователей, вошедших в систему". Если этот параметр у вас отличается - вы сможете изменить его так:
Далее нам нужно зарегистрировать эту задачу определяя каждый из параметров отдельно:
Как создавать команды и функции в Powershell вызывать их и передавать параметры
Анализ выполнения и завершения, а так же сравнение
Используя предыдущие команды мы можем выполнить некоторую автоматизацию. Например так мы можем увидеть результат выполненных задач:
Часть этих кодов имеет следующую расшифровку (был использован автоматический переводчик):
- 0 - операция успешно завершена.
- 1 - Вызывается неправильная функция или неизвестная функция. 2 Файл не найден.
- 10 - Неправильная среда.
- 267008 - Задача готова к запуску в следующее запланированное время.
- 267009 - В данный момент идет выполнение.
- 267010 - Задача не будет запущена в запланированное время, потому что она отключена.
- 267011 - Запуск еще не был выполнен.
- 267012 - Для этой задачи больше нет запланированных запусков.
- 267013 - Одно или несколько свойств, необходимых для запуска этой задачи по расписанию, не были установлены.
- 267014 - Последний запуск задачи был прерван пользователем.
- 267015 - Либо у задачи нет триггеров, либо существующие триггеры отключены или не установлены.
- 2147750671 - Учетные данные повреждены.
- 2147750687 - Экземпляр этой задачи уже запущен.
- 2147943645 - Служба недоступна (установлен ли флажок «Запускать только при входе пользователя в систему»?).
- 3221225786 - Приложение было закрыто в результате нажатия CTRL + C.
- 3228369022 - Неизвестное программное исключение.
Альтернативное - вы можете открыть интерфейс планировщика и посмотреть какая ошибка отображается там (она будет текстом).
Далее вы можете создать скрипт для поиска сбойных задач. Например меня интересует только задачи со сбоями, а не успешно работающие. Так как я не знаю всех кодов, мне нужно будет исключить только коды успешного выполнения:
Такой же подход можно использовать при поиске странных сервисов-программ. Например у нас есть эталонный компьютер/сервер и на нем созданы все нужные задачи. Всех их мы помещаем в один объект, а затем сравниваем с другими экземплярами:
Далее, через разные средства, мы можем сравнить этот список на других компьютерах:
Итак, предположим, у меня есть скрипт start.ps1, который мне необходимо запускать ежедневно в течении 10 дней. Есть два способа решить эту задачу.
Способ 1
Для запуска скрипта воспользуемся оснасткой Task Scheduler, он же планировщик заданий. Найти его можно в разделе Administrative Tools, либо нажав Win+R и введя команду taskschd.msc. Открываем планировщик и в разделе Actions выбираем пункт Create Task.
На вкладке General указываем имя и описание задания, а также (по необходимости) пользователя, от имени которого задание будет запускаться. Для того, чтобы задание выполнялось вне зависимости от того, залогинен ли пользователь в системе, выбираем опцию «Run whether user is logged on or not». Если для выполнения задания требуется повышение привилегий, то отмечаем опцию «Run with highest privileges».
Примечание. Если вы хотите запускать задание чаще, чем раз в день, то надо выбрать одноразовое выполнение (One time), а в разделе Advanced settings отметить пункт Repeat task every и указать время повторения, минимум 5 минут, максимум 1 час. Если этого недостаточно, то дополнительно в поле Delay task for up to можно указать временную задержку.
И основное. Переходим на вкладку Action и указываем действие для запланированного задания. Напомню, что в целях безопасности PowerShell скрипты могут выполняться только интерактивно, то есть сначала надо запустить оболочку PowerShell и уже в ней указать путь к скрипту. Поэтому в поле «Action» указываем запуск powershell.exe, а в поле «Add Arguments» параметр -File и путь к нашему скрипту, вот так:
Также в поле аргументы можно указать:
Заполнив необходимые поля жмем ОК и сохраняем задание. Теперь скрипт будет запускаться по расписанию ежедневно в заданное время в течении 10 дней.
Способ 2
В PowerShell 3.0 появился новый функционал Sheduled Job, дающий возможность создавать запланированные задания прямо из консоли, не пользуясь оснасткой планировщика. Воспользуемся им для планового запуска нашего скрипта.
Сначала создаем расписание запуска (ежедневно в полпятого вечера, в течении 10 дней):
$t = New-JobTrigger -Daily -At 4:30PM -DaysInterval 10
Затем сохраняем в переменной учетные данные:
$cred = Get-Credential contoso\administrator
В качестве опции указываем запуск задания с повышенными привилегиями:
$o = New-ScheduledJobOption -RunElevated
И регистрируем задание с именем Start:
Register-ScheduledJob -Name Start -FilePath C:\Scripts\start.ps1 -Trigger $t -Credential $cred -ScheduledJobOption $o
Чтобы убедится в том, что задание создано, можно открыть планировщик и найти наше задание в разделе Microsoft\Windows\PowerShell\SheduledJobs.
Execution Policy
В заключение напомню об одном немаловажном моменте, а именно о политике выполнения скриптов Execution Policy. Посмотреть текущее значение политики можно командой Get-ExecutionPolicy . Политика выполнения может иметь значения:
Обычно для безпроблемного выполнения скриптов достаточно задать значение RemoteSigned. Изменить текущее значение можно командой Set-ExecutionPolicy , например:
Set-ExecutionPolicy RemoteSigned -force
Примечание. Если указанная в команде политика выполнения противоречит групповой политике, то параметр запишется в реестр, но действовать не будет.
Большинство пользователей и администраторов привыкли использовать графический интерфейс консоли Taskschd.msc для создания заданий планировщика Windows (Task Scheduler), запускаемых по расписанию. Однако в различных скриптах и автоматизируемых задачах для создания заданий планировщика гораздо удобнее использовать возможности PowerShell. В этой статье мы покажем, как создавать и управлять заданиями планировщика Windows из PowerShell.
Управление заданиями Task Scheduler с помощью PowerShell
В Windows 10/Windows Server 2016 для управления задачами в планировщике используется PowerShell модуль ScheduledTasks. Список командлетов в модуле можно вывести так:
Get-Command -Module ScheduledTasks
- Disable-ScheduledTask
- Enable-ScheduledTask
- Export-ScheduledTask
- Get-ClusteredScheduledTask
- Get-ScheduledTask
- Get-ScheduledTaskInfo
- New-ScheduledTask
- New-ScheduledTaskAction
- New-ScheduledTaskPrincipal
Как создать задание планировщика с помощью PowerShell?
В современных версиях PowerShell (начиная с PowerShell 3.0 в Windows Server 2012/Windows 8) для создания заданию планировщика нужно использовать командлеты New-ScheduledTaskTrigger и Register-ScheduledTask.
Предположим, наша задача создать задание планировщика, которое должно запускаться при загрузке компьютера (или в определенное время) и выполнять какой-то PowerShell скрипт. Создадим задание планировщика с именем StartupScript_PS. Данное задание должно каждый день в 10:00 запускать PowerShell скрипт, хранящийся в файле C:\PS\StartupScript.ps1 из-под учетной записи системы (SYSTEM). Задание будет выполняться с повышенными привилегиями (галка “Run with highest privileges”).
$Trigger= New-ScheduledTaskTrigger -At 10:00am -Daily
$User= "NT AUTHORITY\SYSTEM"
$Action= New-ScheduledTaskAction -Execute "PowerShell.exe" -Argument "C:\PS\StartupScript.ps1"
Register-ScheduledTask -TaskName "StartupScript_PS" -Trigger $Trigger -User $User -Action $Action -RunLevel Highest –Force
Если задание успешно создано, появится надпись Ready.
Теперь ваш PowerShell скрипт будет запускаться по указанному расписанию. Если на вашем компьютере настроена PowerShell Execution Policy, блокирующая запуск скриптов PS1, вы можете запустить скрипт их планировщика с параметром –Bypass.
Используйте такую строку при создании нового задания:
$Action= New-ScheduledTaskAction -Execute "PowerShell.exe" -Argument “-NoProfile -NoLogo -NonInteractive -ExecutionPolicy Bypass -File C:\PS\StartupScript.ps1"
Совет. Если нужно, чтобы задание запускалось каждый раз при загрузке компьютера, первая строка должна быть такой:$Trigger= New-ScheduledTaskTrigger -AtStartup
Если нужно выполнять задание при входе пользователя:
$Trigger= New-ScheduledTaskTrigger –AtLogo n
Откройте консоль Taskschd.msc и проверьте, что проверьте, что в Task Scheduler Library появилось новое задание планировщика.
Получение информации и запуск заданий планировщика из PowerShell
Вы можете вывести список всех активных заданий планировщика в Windows с помощью команды:
Get-ScheduledTask -TaskPath | ? state -ne Disabled
Чтобы получить информацию о конкретном задании:
Get-ScheduledTask CheckServiceState_PS| Get-ScheduledTaskInfo
Вы можете отключить это задание:
Get-ScheduledTask CheckServiceState_PS | Disable-ScheduledTask
Чтобы включить задание:
Get-ScheduledTask CheckServiceState_PS | Enable-ScheduledTask
Чтобы запустить задание немедленно (не дожидаясь расписания), выполните:
Чтобы полностью удалить задание из Task Scheduler:
Unregister-ScheduledTask -TaskName CheckServiceState_PS
Если нужно изменить имя пользователя, из-под которого запускается задание и, например, режим совместимости, используйте командлет Set-ScheduledTask:
$task_user = New-ScheduledTaskPrincipal -UserId 'winitpro\kbuldogov' -RunLevel Highest
$task_settings = New-ScheduledTaskSettingsSet -Compatibility 'Win7'
Set-ScheduledTask -TaskName CheckServiceState_PS -Principal $task_user -Settings $task_settings
Экспорт и импорт заданий планировщика в XML файл
С помощью PowerShell можно экспортировать любое задания планировщика в текстовый XML файл для распространения на другие компьютеры. Вы можете экспортировать задание из графического интерфейса Task Scheduler или из консоли PowerShell.
Следующая команда экспортирует задание StartupScript_PS в файл StartupScript_PS.xml:
Export-ScheduledTask "StartupScript_PS" | out-file c:\temp\StartupScript_PS.xml
schtasks /query /tn "NewPsTask" /xml >> "c:\ps\NewPsTask.xml"
После того, как настройки задания планировщика экспортированы в XML файл, его можно импортировать на любой другой компьютер с помощи графической консоли, SchTasks.exe или PowerShell.
Воспользуйте командлетом PowerShell Register-ScheduledTask чтобы параметры задания из файла и зарегистрировать его:
Register-ScheduledTask -Xml (Get-Content “\\Server1\public\NewPsTask.xml” | out-string) -TaskName "NewPsTask"
Примечание. В PowerShell 2.0 (Windows 7/Server 2008 R2) импорт задания также проще выполнить с помощью утилиты schtasks. Первая команда создаст новое задание. Вторая – сразу запустит его (не дожидаясь срабатывания триггера).schtasks /create /tn "NewPsTask" /xml "\\Server1\public\NewPsTask.xml " /ru corp\aaivanov /rp Pa$$w0rd
schtasks /Run /TN "NewPsTask"
Обратите внимание, что в этом примере указаны данные учетной записи, из-под которой будет запускаться задание. Если имя и пароль учетной записи не указаны, то т.к. они не хранятся в задании, они будут запрошены при импорте.
Читайте также: