Единственный способ, которым я знаю, чтобы сделать, это должно было бы использовать инструмент, чтобы контролировать журнал событий на сервере и исчерпать электронное письмо, когда перерабатывать событие имеет место.
Необходимо будет быть уверены, что перерабатывают вход, включен. Процедура для включения этого и различных идентификаторов события, связанных с пулом приложений, перерабатывает, описаны в этой статье: http://support.microsoft.com/kb/332088
Такой сценарий мог на самом деле работать как служба Windows и не будет слишком плох для кодирования в VBscript. Если Вы уже получили некоторое решение по контролю журнала событий "предприятия", используйте это. В противном случае рассмотрите сценарии его. (Возможно, если у меня будет некоторое свободное время этим днем, то я кодирую что-то... мы будем видеть...),
Следующее могло бы работать, отчасти:
echo list disk > list.txt
for /f "usebackq tokens=1,2" %%a in (`diskpart /s list.txt ^| findstr /r /c:"Disk [0-9]"`) do (
echo sel %%a %%b>abc.txt
echo create part primary>>abc.txt
echo format FS=NTFS label=label2 quick compress>>abc.txt
diskpart /s abc.txt
)
del list.txt abc.txt
Это будет сначала получать список дисков от diskpart и впоследствии использовать их с Вашим файлом сценария (который будет динамично создан в цикле).
Я не попробую его здесь, так как мне нравятся мои диски путем, они в настоящее время.
@echo off
setlocal enabledelayedexpansion
cls
:: Eg. To enable choice prompt, change to set _CHOICE.ENABLE=
:: To disable choice prompt, change to set _CHOICE.ENABLE=::
:: Do the same for set _DISKPART.ENABLE=::
set _CHOICE.ENABLE=
set _DISKPART.ENABLE=::
set _TMP.FILE=%~dp0%~n0.DPS
for /f "skip=1 tokens=1" %%a in ('wmic diskdrive where "MediaType='Fixed Hard Disk Media'" get index') do (set _DISK.AVAIL=!_DISK.AVAIL! %%a)
set _DISK.AVAIL=!_DISK.AVAIL:~1!
for %%a in (!_DISK.AVAIL!) do (set "_DISKPART.SCRIPT=!_DISKPART.SCRIPT!select-disk-%%a create-partition-primary format-fs=ntfs-label="LABEL%%a"-quick-compress ")
:_FN.VAR2FILE
for /f "tokens=1*" %%a in ("!_DISKPART.SCRIPT!") do (
set _DISKPART.SCRIPT.FORMAT=%%a
set _DISKPART.SCRIPT.FORMAT=!_DISKPART.SCRIPT.FORMAT:-= !
if not exist "%_TMP.FILE%" (echo !_DISKPART.SCRIPT.FORMAT! > %_TMP.FILE%) else (echo !_DISKPART.SCRIPT.FORMAT! >> %_TMP.FILE%)
set _DISKPART.SCRIPT=%%b
)
if defined _DISKPART.SCRIPT (goto :_FN.VAR2FILE)
echo Generated Script^:
type %_TMP.FILE% | more
%_CHOICE.ENABLE% CHOICE /C TC /M "[T]erminate, or [C]ontinue"
%_CHOICE.ENABLE% if errorlevel 2 (call :_FN.DISKPART.RUN)
goto :_FN.FINISH
goto :eof
:_FN.DISKPART.RUN
if "!_DISKPART.ENABLE!"=="::" (echo Command is disabled, please see the header for information on how to enable it.)
%_DISKPART.ENABLE% diskpart /s %_TMP.FILE%
goto :eof
:_FN.FINISH
if exist "%_TMP.FILE%" (del /q %_TMP.FILE%)
echo All Done.
goto :eof
Изящное решение.
Если вы всегда повторяете одни и те же диски, вы можете просто вставить их как статические. Я сделал это для USB-ключей.
SELECT DISK 6
CLEAN
CREATE PART PRI
SELECT PART 1
ACTIVE
ASSIGN
FORMAT FS=fat32 quick label="WINPE"
SELECT DISK 7
CLEAN
CREATE PART PRI
SELECT PART 1
ACTIVE
ASSIGN
FORMAT FS=fat32 quick label="WINPE"
EXIT